ydb-embedded-ui 9.3.0 → 9.4.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 (288) hide show
  1. package/dist/components/AutoRefreshControl/i18n/index.d.ts +1 -1
  2. package/dist/components/Drawer/Drawer.d.ts +2 -1
  3. package/dist/components/Drawer/Drawer.js +10 -6
  4. package/dist/components/Drawer/Drawer.js.map +1 -1
  5. package/dist/components/Drawer/DrawerContext.d.ts +1 -0
  6. package/dist/components/Drawer/DrawerContext.js +5 -2
  7. package/dist/components/Drawer/DrawerContext.js.map +1 -1
  8. package/dist/{containers/Storage → components}/EmptyFilter/EmptyFilter.js +2 -2
  9. package/dist/components/EmptyFilter/EmptyFilter.js.map +1 -0
  10. package/dist/{containers/App → components/EmptyFilter}/i18n/index.js +1 -1
  11. package/dist/components/EmptyFilter/i18n/index.js.map +1 -0
  12. package/dist/components/EmptyState/EmptyState.d.ts +1 -0
  13. package/dist/components/EmptyState/EmptyState.js +1 -0
  14. package/dist/components/EmptyState/EmptyState.js.map +1 -1
  15. package/dist/components/EmptyState/EmptyState.scss +9 -0
  16. package/dist/components/EnableFullscreenButton/EnableFullscreenButton.js +3 -2
  17. package/dist/components/EnableFullscreenButton/EnableFullscreenButton.js.map +1 -1
  18. package/dist/components/EnableFullscreenButton/i18n/en.json +3 -0
  19. package/dist/components/EnableFullscreenButton/i18n/index.d.ts +2 -0
  20. package/dist/components/EnableFullscreenButton/i18n/index.js +5 -0
  21. package/dist/components/EnableFullscreenButton/i18n/index.js.map +1 -0
  22. package/dist/components/FixedHeightQuery/FixedHeightQuery.d.ts +9 -0
  23. package/dist/components/FixedHeightQuery/FixedHeightQuery.js +23 -0
  24. package/dist/components/FixedHeightQuery/FixedHeightQuery.js.map +1 -0
  25. package/dist/components/FixedHeightQuery/FixedHeightQuery.scss +42 -0
  26. package/dist/components/HealthcheckStatus/HealthcheckStatus.d.ts +8 -0
  27. package/dist/components/HealthcheckStatus/HealthcheckStatus.js +41 -0
  28. package/dist/components/HealthcheckStatus/HealthcheckStatus.js.map +1 -0
  29. package/dist/components/HealthcheckStatus/i18n/en.json +7 -0
  30. package/dist/components/HealthcheckStatus/i18n/index.d.ts +2 -0
  31. package/dist/components/HealthcheckStatus/i18n/index.js +5 -0
  32. package/dist/components/HealthcheckStatus/i18n/index.js.map +1 -0
  33. package/dist/components/PaginatedTable/PaginatedTable.js +21 -21
  34. package/dist/components/PaginatedTable/PaginatedTable.js.map +1 -1
  35. package/dist/components/PaginatedTable/PaginatedTableContext.d.ts +3 -1
  36. package/dist/components/PaginatedTable/PaginatedTableContext.js +3 -2
  37. package/dist/components/PaginatedTable/PaginatedTableContext.js.map +1 -1
  38. package/dist/components/PaginatedTable/PaginatedTableWithLayout.d.ts +5 -4
  39. package/dist/components/PaginatedTable/PaginatedTableWithLayout.js +29 -2
  40. package/dist/components/PaginatedTable/PaginatedTableWithLayout.js.map +1 -1
  41. package/dist/components/PaginatedTable/TableChunk.d.ts +3 -2
  42. package/dist/components/PaginatedTable/TableChunk.js +12 -18
  43. package/dist/components/PaginatedTable/TableChunk.js.map +1 -1
  44. package/dist/components/PaginatedTable/TableChunksRenderer.d.ts +21 -0
  45. package/dist/components/PaginatedTable/TableChunksRenderer.js +96 -0
  46. package/dist/components/PaginatedTable/TableChunksRenderer.js.map +1 -0
  47. package/dist/components/PaginatedTable/TableRow.d.ts +2 -1
  48. package/dist/components/PaginatedTable/TableRow.js +4 -4
  49. package/dist/components/PaginatedTable/TableRow.js.map +1 -1
  50. package/dist/components/PaginatedTable/requestBatcher.d.ts +28 -0
  51. package/dist/components/PaginatedTable/requestBatcher.js +128 -0
  52. package/dist/components/PaginatedTable/requestBatcher.js.map +1 -0
  53. package/dist/components/PaginatedTable/useScrollBasedChunks.d.ts +8 -2
  54. package/dist/components/PaginatedTable/useScrollBasedChunks.js +35 -20
  55. package/dist/components/PaginatedTable/useScrollBasedChunks.js.map +1 -1
  56. package/dist/components/ProgressViewer/ProgressViewer.d.ts +2 -1
  57. package/dist/components/ProgressViewer/ProgressViewer.js +3 -2
  58. package/dist/components/ProgressViewer/ProgressViewer.js.map +1 -1
  59. package/dist/components/ResizeableDataTable/ResizeableDataTable.d.ts +3 -2
  60. package/dist/components/ResizeableDataTable/ResizeableDataTable.js +7 -2
  61. package/dist/components/ResizeableDataTable/ResizeableDataTable.js.map +1 -1
  62. package/dist/components/SplitPane/SplitPane.scss +0 -1
  63. package/dist/components/TableWithControlsLayout/TableWithControlsLayout.d.ts +4 -3
  64. package/dist/components/TableWithControlsLayout/TableWithControlsLayout.js.map +1 -1
  65. package/dist/containers/App/Content.js +18 -14
  66. package/dist/containers/App/Content.js.map +1 -1
  67. package/dist/containers/Clusters/Clusters.js +19 -7
  68. package/dist/containers/Clusters/Clusters.js.map +1 -1
  69. package/dist/containers/Clusters/Clusters.scss +7 -53
  70. package/dist/containers/Clusters/columns.d.ts +18 -1
  71. package/dist/containers/Clusters/columns.js +43 -9
  72. package/dist/containers/Clusters/columns.js.map +1 -1
  73. package/dist/containers/Clusters/i18n/en.json +3 -1
  74. package/dist/containers/Clusters/i18n/index.d.ts +1 -1
  75. package/dist/containers/Clusters/i18n/index.js +1 -2
  76. package/dist/containers/Clusters/i18n/index.js.map +1 -1
  77. package/dist/containers/Header/Header.d.ts +1 -5
  78. package/dist/containers/Header/Header.js +14 -10
  79. package/dist/containers/Header/Header.js.map +1 -1
  80. package/dist/containers/Header/Header.scss +1 -1
  81. package/dist/containers/Header/breadcrumbs.d.ts +3 -1
  82. package/dist/containers/Header/breadcrumbs.js +18 -6
  83. package/dist/containers/Header/breadcrumbs.js.map +1 -1
  84. package/dist/containers/Header/i18n/en.json +3 -1
  85. package/dist/containers/Header/i18n/index.d.ts +1 -1
  86. package/dist/containers/Nodes/PaginatedNodes/GroupedNodesComponent.js +5 -3
  87. package/dist/containers/Nodes/PaginatedNodes/GroupedNodesComponent.js.map +1 -1
  88. package/dist/containers/Nodes/PaginatedNodes/NodesComponent.js +2 -2
  89. package/dist/containers/Nodes/PaginatedNodes/NodesComponent.js.map +1 -1
  90. package/dist/containers/Operations/columns.js +2 -2
  91. package/dist/containers/Operations/columns.js.map +1 -1
  92. package/dist/containers/Storage/PaginatedStorageGroups/GroupedStorageGroupsComponent.js +4 -2
  93. package/dist/containers/Storage/PaginatedStorageGroups/GroupedStorageGroupsComponent.js.map +1 -1
  94. package/dist/containers/Storage/PaginatedStorageGroups/StorageGroupsComponent.js +2 -2
  95. package/dist/containers/Storage/PaginatedStorageGroups/StorageGroupsComponent.js.map +1 -1
  96. package/dist/containers/Storage/PaginatedStorageGroupsTable/StorageGroupsEmptyDataMessage.js +1 -1
  97. package/dist/containers/Storage/PaginatedStorageGroupsTable/StorageGroupsEmptyDataMessage.js.map +1 -1
  98. package/dist/containers/Storage/PaginatedStorageNodes/GroupedStorageNodesComponent.js +4 -2
  99. package/dist/containers/Storage/PaginatedStorageNodes/GroupedStorageNodesComponent.js.map +1 -1
  100. package/dist/containers/Storage/PaginatedStorageNodes/StorageNodesComponent.js +2 -2
  101. package/dist/containers/Storage/PaginatedStorageNodes/StorageNodesComponent.js.map +1 -1
  102. package/dist/containers/Storage/PaginatedStorageNodesTable/StorageNodesEmptyDataMessage.js +1 -1
  103. package/dist/containers/Storage/PaginatedStorageNodesTable/StorageNodesEmptyDataMessage.js.map +1 -1
  104. package/dist/containers/Tablet/components/TabletStorageInfo/i18n/index.d.ts +1 -1
  105. package/dist/containers/Tablets/TabletsTable.js +3 -1
  106. package/dist/containers/Tablets/TabletsTable.js.map +1 -1
  107. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/HealthcheckPreview.d.ts +1 -1
  108. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/HealthcheckPreview.js +30 -29
  109. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/HealthcheckPreview.js.map +1 -1
  110. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/HealthcheckPreview.scss +41 -0
  111. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/i18n/en.json +8 -6
  112. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/i18n/index.d.ts +1 -1
  113. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/i18n/index.js +1 -2
  114. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/i18n/index.js.map +1 -1
  115. package/dist/containers/Tenant/Diagnostics/TenantOverview/MetricsCards/MetricCard/MetricCard.d.ts +3 -1
  116. package/dist/containers/Tenant/Diagnostics/TenantOverview/MetricsCards/MetricCard/MetricCard.js +9 -2
  117. package/dist/containers/Tenant/Diagnostics/TenantOverview/MetricsCards/MetricCard/MetricCard.js.map +1 -1
  118. package/dist/containers/Tenant/Diagnostics/TenantOverview/MetricsCards/MetricCard/MetricCard.scss +7 -0
  119. package/dist/containers/Tenant/Diagnostics/TenantOverview/MetricsCards/MetricsCards.d.ts +2 -2
  120. package/dist/containers/Tenant/Diagnostics/TenantOverview/MetricsCards/MetricsCards.js +27 -8
  121. package/dist/containers/Tenant/Diagnostics/TenantOverview/MetricsCards/MetricsCards.js.map +1 -1
  122. package/dist/containers/Tenant/Diagnostics/TenantOverview/TenantOverview.js +5 -10
  123. package/dist/containers/Tenant/Diagnostics/TenantOverview/TenantOverview.js.map +1 -1
  124. package/dist/containers/Tenant/Diagnostics/TenantOverview/TenantOverview.scss +1 -5
  125. package/dist/containers/Tenant/Diagnostics/TenantOverview/i18n/en.json +2 -0
  126. package/dist/containers/Tenant/Diagnostics/TenantOverview/i18n/index.d.ts +1 -1
  127. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.js +11 -1
  128. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.js.map +1 -1
  129. package/dist/containers/Tenant/Diagnostics/TopQueries/columns/columns.js +2 -3
  130. package/dist/containers/Tenant/Diagnostics/TopQueries/columns/columns.js.map +1 -1
  131. package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useScrollToSelected.d.ts +19 -0
  132. package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useScrollToSelected.js +31 -0
  133. package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useScrollToSelected.js.map +1 -0
  134. package/dist/containers/Tenant/Diagnostics/TopQueries/utils.js +1 -0
  135. package/dist/containers/Tenant/Diagnostics/TopQueries/utils.js.map +1 -1
  136. package/dist/containers/Tenant/Diagnostics/TopicData/TopicData.js +3 -3
  137. package/dist/containers/Tenant/Diagnostics/TopicData/TopicData.js.map +1 -1
  138. package/dist/containers/Tenant/Diagnostics/TopicData/i18n/index.d.ts +1 -1
  139. package/dist/containers/Tenant/Healthcheck/Healthcheck.d.ts +9 -0
  140. package/dist/containers/Tenant/Healthcheck/Healthcheck.js +49 -0
  141. package/dist/containers/Tenant/Healthcheck/Healthcheck.js.map +1 -0
  142. package/dist/containers/Tenant/Healthcheck/Healthcheck.scss +112 -0
  143. package/dist/containers/Tenant/Healthcheck/components/HealthcheckFilter.d.ts +1 -0
  144. package/dist/containers/Tenant/Healthcheck/components/HealthcheckFilter.js +9 -0
  145. package/dist/containers/Tenant/Healthcheck/components/HealthcheckFilter.js.map +1 -0
  146. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssue.d.ts +7 -0
  147. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssue.js +25 -0
  148. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssue.js.map +1 -0
  149. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/ComputeLocation.d.ts +9 -0
  150. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/ComputeLocation.js +67 -0
  151. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/ComputeLocation.js.map +1 -0
  152. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/HealthcheckIssueDetails.d.ts +6 -0
  153. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/HealthcheckIssueDetails.js +67 -0
  154. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/HealthcheckIssueDetails.js.map +1 -0
  155. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/NodeInfo.d.ts +7 -0
  156. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/NodeInfo.js +19 -0
  157. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/NodeInfo.js.map +1 -0
  158. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/PoolInfo.d.ts +6 -0
  159. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/PoolInfo.js +12 -0
  160. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/PoolInfo.js.map +1 -0
  161. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/StorageLocation.d.ts +9 -0
  162. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/StorageLocation.js +95 -0
  163. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/StorageLocation.js.map +1 -0
  164. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/utils.d.ts +25 -0
  165. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/utils.js +17 -0
  166. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/utils.js.map +1 -0
  167. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueTabs.d.ts +8 -0
  168. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueTabs.js +23 -0
  169. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueTabs.js.map +1 -0
  170. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssues.d.ts +6 -0
  171. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssues.js +41 -0
  172. package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssues.js.map +1 -0
  173. package/dist/containers/Tenant/Healthcheck/components/HealthcheckRefresh.d.ts +6 -0
  174. package/dist/containers/Tenant/Healthcheck/components/HealthcheckRefresh.js +47 -0
  175. package/dist/containers/Tenant/Healthcheck/components/HealthcheckRefresh.js.map +1 -0
  176. package/dist/containers/Tenant/Healthcheck/components/HealthcheckView.d.ts +8 -0
  177. package/dist/containers/Tenant/Healthcheck/components/HealthcheckView.js +42 -0
  178. package/dist/containers/Tenant/Healthcheck/components/HealthcheckView.js.map +1 -0
  179. package/dist/containers/Tenant/Healthcheck/i18n/en.json +41 -0
  180. package/dist/containers/Tenant/Healthcheck/i18n/index.d.ts +2 -0
  181. package/dist/containers/Tenant/Healthcheck/i18n/index.js +5 -0
  182. package/dist/containers/Tenant/Healthcheck/i18n/index.js.map +1 -0
  183. package/dist/containers/Tenant/Healthcheck/shared.d.ts +11 -0
  184. package/dist/containers/Tenant/Healthcheck/shared.js +36 -0
  185. package/dist/containers/Tenant/Healthcheck/shared.js.map +1 -0
  186. package/dist/containers/Tenant/Healthcheck/useHealthcheck.d.ts +14 -0
  187. package/dist/containers/Tenant/Healthcheck/useHealthcheck.js +19 -0
  188. package/dist/containers/Tenant/Healthcheck/useHealthcheck.js.map +1 -0
  189. package/dist/containers/Tenant/Query/Preview/components/TopicPreview.js +1 -1
  190. package/dist/containers/Tenant/Query/Preview/components/TopicPreview.js.map +1 -1
  191. package/dist/containers/Tenant/Query/QueryEditorControls/QueryEditorControls.js +1 -1
  192. package/dist/containers/Tenant/Query/QueryEditorControls/QueryEditorControls.js.map +1 -1
  193. package/dist/containers/Tenant/Query/QueryResult/components/QueryInfoDropdown/useQueryInfoMenuItems.js +1 -1
  194. package/dist/containers/Tenant/Query/QueryResult/components/QueryInfoDropdown/useQueryInfoMenuItems.js.map +1 -1
  195. package/dist/containers/Tenant/Tenant.js +14 -25
  196. package/dist/containers/Tenant/Tenant.js.map +1 -1
  197. package/dist/containers/Tenant/TenantDrawerWrappers.d.ts +7 -0
  198. package/dist/containers/Tenant/TenantDrawerWrappers.js +47 -0
  199. package/dist/containers/Tenant/TenantDrawerWrappers.js.map +1 -0
  200. package/dist/containers/Tenant/TenantPages.d.ts +2 -0
  201. package/dist/containers/Tenant/TenantPages.js.map +1 -1
  202. package/dist/containers/Tenant/constants.d.ts +4 -0
  203. package/dist/containers/Tenant/constants.js +18 -0
  204. package/dist/containers/Tenant/constants.js.map +1 -0
  205. package/dist/containers/Tenant/i18n/en.json +7 -1
  206. package/dist/containers/Tenant/i18n/index.d.ts +1 -1
  207. package/dist/containers/Tenant/useTenantQueryParams.d.ts +12 -0
  208. package/dist/containers/Tenant/useTenantQueryParams.js +39 -0
  209. package/dist/containers/Tenant/useTenantQueryParams.js.map +1 -0
  210. package/dist/containers/Tenant/utils/schemaActions.js +2 -2
  211. package/dist/containers/Tenant/utils/schemaActions.js.map +1 -1
  212. package/dist/containers/Tenants/Tenants.js +8 -2
  213. package/dist/containers/Tenants/Tenants.js.map +1 -1
  214. package/dist/containers/UserSettings/i18n/en.json +1 -1
  215. package/dist/services/api/streaming.js +1 -0
  216. package/dist/services/api/streaming.js.map +1 -1
  217. package/dist/store/reducers/capabilities/hooks.d.ts +3 -0
  218. package/dist/store/reducers/capabilities/hooks.js +9 -0
  219. package/dist/store/reducers/capabilities/hooks.js.map +1 -1
  220. package/dist/store/reducers/clusters/selectors.d.ts +1 -2
  221. package/dist/store/reducers/clusters/selectors.js +0 -28
  222. package/dist/store/reducers/clusters/selectors.js.map +1 -1
  223. package/dist/store/reducers/clusters/types.d.ts +0 -10
  224. package/dist/store/reducers/header/types.d.ts +4 -2
  225. package/dist/store/reducers/healthcheckInfo/healthcheckInfo.d.ts +631 -331
  226. package/dist/store/reducers/healthcheckInfo/healthcheckInfo.js +8 -35
  227. package/dist/store/reducers/healthcheckInfo/healthcheckInfo.js.map +1 -1
  228. package/dist/store/reducers/healthcheckInfo/types.d.ts +2 -0
  229. package/dist/store/reducers/healthcheckInfo/utils.d.ts +3 -0
  230. package/dist/store/reducers/healthcheckInfo/utils.js +34 -0
  231. package/dist/store/reducers/healthcheckInfo/utils.js.map +1 -1
  232. package/dist/store/reducers/tableData.d.ts +1 -0
  233. package/dist/store/reducers/tableData.js +29 -10
  234. package/dist/store/reducers/tableData.js.map +1 -1
  235. package/dist/store/reducers/tenant/constants.d.ts +0 -1
  236. package/dist/store/reducers/tenant/constants.js +0 -1
  237. package/dist/store/reducers/tenant/constants.js.map +1 -1
  238. package/dist/store/reducers/tenants/utils.d.ts +2 -1
  239. package/dist/store/reducers/tenants/utils.js +15 -2
  240. package/dist/store/reducers/tenants/utils.js.map +1 -1
  241. package/dist/styles/index.scss +3 -0
  242. package/dist/types/api/capabilities.d.ts +1 -1
  243. package/dist/types/api/healthcheck.d.ts +80 -13
  244. package/dist/types/api/healthcheck.js +1 -0
  245. package/dist/types/api/healthcheck.js.map +1 -1
  246. package/dist/types/api/tenant.d.ts +4 -0
  247. package/dist/types/api/tenant.js.map +1 -1
  248. package/dist/uiFactory/types.d.ts +18 -0
  249. package/dist/uiFactory/uiFactory.js +6 -0
  250. package/dist/uiFactory/uiFactory.js.map +1 -1
  251. package/dist/utils/createToast.d.ts +2 -9
  252. package/dist/utils/createToast.js +5 -6
  253. package/dist/utils/createToast.js.map +1 -1
  254. package/package.json +1 -1
  255. package/dist/containers/App/i18n/en.json +0 -3
  256. package/dist/containers/App/i18n/index.d.ts +0 -2
  257. package/dist/containers/App/i18n/index.js.map +0 -1
  258. package/dist/containers/App/i18n/ru.json +0 -3
  259. package/dist/containers/Clusters/ClustersStatistics.d.ts +0 -7
  260. package/dist/containers/Clusters/ClustersStatistics.js +0 -10
  261. package/dist/containers/Clusters/ClustersStatistics.js.map +0 -1
  262. package/dist/containers/Clusters/i18n/ru.json +0 -15
  263. package/dist/containers/Storage/EmptyFilter/EmptyFilter.js.map +0 -1
  264. package/dist/containers/Storage/EmptyFilter/i18n/index.js +0 -6
  265. package/dist/containers/Storage/EmptyFilter/i18n/index.js.map +0 -1
  266. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/Healthcheck.scss +0 -106
  267. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/HealthcheckDetails.d.ts +0 -6
  268. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/HealthcheckDetails.js +0 -34
  269. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/HealthcheckDetails.js.map +0 -1
  270. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTree.d.ts +0 -7
  271. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTree.js +0 -37
  272. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTree.js.map +0 -1
  273. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTree.scss +0 -51
  274. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTreeItem/IssueTreeItem.d.ts +0 -10
  275. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTreeItem/IssueTreeItem.js +0 -9
  276. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTreeItem/IssueTreeItem.js.map +0 -1
  277. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTreeItem/IssueTreeItem.scss +0 -50
  278. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTreeItem/index.d.ts +0 -1
  279. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTreeItem/index.js +0 -2
  280. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTreeItem/index.js.map +0 -1
  281. package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/i18n/ru.json +0 -8
  282. package/dist/containers/Tenant/Diagnostics/TenantOverview/useHealthcheck.d.ts +0 -15
  283. package/dist/containers/Tenant/Diagnostics/TenantOverview/useHealthcheck.js +0 -20
  284. package/dist/containers/Tenant/Diagnostics/TenantOverview/useHealthcheck.js.map +0 -1
  285. /package/dist/{containers/Storage → components}/EmptyFilter/EmptyFilter.d.ts +0 -0
  286. /package/dist/{containers/Storage → components}/EmptyFilter/i18n/en.json +0 -0
  287. /package/dist/{containers/Storage → components}/EmptyFilter/i18n/index.d.ts +0 -0
  288. /package/dist/{containers/Storage → components}/EmptyFilter/i18n/ru.json +0 -0
@@ -1,12 +1,13 @@
1
1
  import React from 'react';
2
- import type { TableProps } from '../TableWithControlsLayout/TableWithControlsLayout';
2
+ import type { TableWrapperProps } from '../TableWithControlsLayout/TableWithControlsLayout';
3
3
  import type { PaginatedTableState } from './types';
4
4
  export interface PaginatedTableWithLayoutProps {
5
- controls: React.ReactNode;
5
+ controls?: React.ReactNode;
6
6
  table: React.ReactNode;
7
- tableProps?: TableProps;
7
+ tableWrapperProps?: Omit<TableWrapperProps, 'children'>;
8
8
  error?: React.ReactNode;
9
9
  initialState?: Partial<PaginatedTableState>;
10
10
  fullHeight?: boolean;
11
+ noBatching?: boolean;
11
12
  }
12
- export declare const PaginatedTableWithLayout: ({ controls, table, tableProps, error, initialState, fullHeight, }: PaginatedTableWithLayoutProps) => import("react/jsx-runtime").JSX.Element;
13
+ export declare const PaginatedTableWithLayout: ({ controls, table, tableWrapperProps, error, initialState, noBatching, fullHeight, }: PaginatedTableWithLayoutProps) => import("react/jsx-runtime").JSX.Element;
@@ -1,5 +1,32 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React from 'react';
2
3
  import { TableWithControlsLayout } from '../TableWithControlsLayout/TableWithControlsLayout';
3
- import { PaginatedTableProvider } from './PaginatedTableContext';
4
- export const PaginatedTableWithLayout = ({ controls, table, tableProps, error, initialState, fullHeight = true, }) => (_jsx(PaginatedTableProvider, { initialState: initialState, children: _jsxs(TableWithControlsLayout, { fullHeight: fullHeight, children: [_jsx(TableWithControlsLayout.Controls, { children: controls }), error, _jsx(TableWithControlsLayout.Table, { ...(tableProps || {}), children: table })] }) }));
4
+ import { PaginatedTableProvider, usePaginatedTableState } from './PaginatedTableContext';
5
+ const TableWrapper = ({ table, tableWrapperProps, }) => {
6
+ const { tableState } = usePaginatedTableState();
7
+ const { sortParams } = tableState;
8
+ const enhancedTableWrapperProps = React.useMemo(() => {
9
+ const existingScrollDependencies = (tableWrapperProps === null || tableWrapperProps === void 0 ? void 0 : tableWrapperProps.scrollDependencies) || [];
10
+ return {
11
+ ...tableWrapperProps,
12
+ scrollDependencies: [...existingScrollDependencies, sortParams],
13
+ };
14
+ }, [tableWrapperProps, sortParams]);
15
+ return (_jsx(TableWithControlsLayout.Table, { ...enhancedTableWrapperProps, children: table }));
16
+ };
17
+ const ControlsSection = ({ controls }) => {
18
+ if (!controls) {
19
+ return null;
20
+ }
21
+ return _jsx(TableWithControlsLayout.Controls, { children: controls });
22
+ };
23
+ const ErrorSection = ({ error }) => {
24
+ if (!error) {
25
+ return null;
26
+ }
27
+ return _jsx(React.Fragment, { children: error });
28
+ };
29
+ export const PaginatedTableWithLayout = ({ controls, table, tableWrapperProps, error, initialState, noBatching, fullHeight = true, }) => {
30
+ return (_jsx(PaginatedTableProvider, { initialState: initialState, noBatching: noBatching, children: _jsxs(TableWithControlsLayout, { fullHeight: fullHeight, children: [_jsx(ControlsSection, { controls: controls }), _jsx(ErrorSection, { error: error }), _jsx(TableWrapper, { table: table, tableWrapperProps: tableWrapperProps })] }) }));
31
+ };
5
32
  //# sourceMappingURL=PaginatedTableWithLayout.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PaginatedTableWithLayout.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/PaginatedTableWithLayout.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAC,uBAAuB,EAAC,MAAM,oDAAoD,CAAC;AAG3F,OAAO,EAAC,sBAAsB,EAAC,MAAM,yBAAyB,CAAC;AAY/D,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,EACrC,QAAQ,EACR,KAAK,EACL,UAAU,EACV,KAAK,EACL,YAAY,EACZ,UAAU,GAAG,IAAI,GACW,EAAE,EAAE,CAAC,CACjC,KAAC,sBAAsB,IAAC,YAAY,EAAE,YAAY,YAC9C,MAAC,uBAAuB,IAAC,UAAU,EAAE,UAAU,aAC3C,KAAC,uBAAuB,CAAC,QAAQ,cAAE,QAAQ,GAAoC,EAC9E,KAAK,EACN,KAAC,uBAAuB,CAAC,KAAK,OAAK,CAAC,UAAU,IAAI,EAAE,CAAC,YAChD,KAAK,GACsB,IACV,GACL,CAC5B,CAAC"}
1
+ {"version":3,"file":"PaginatedTableWithLayout.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/PaginatedTableWithLayout.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAC,uBAAuB,EAAC,MAAM,oDAAoD,CAAC;AAG3F,OAAO,EAAC,sBAAsB,EAAE,sBAAsB,EAAC,MAAM,yBAAyB,CAAC;AAavF,MAAM,YAAY,GAAG,CAAC,EAClB,KAAK,EACL,iBAAiB,GAIpB,EAAE,EAAE;IACD,MAAM,EAAC,UAAU,EAAC,GAAG,sBAAsB,EAAE,CAAC;IAC9C,MAAM,EAAC,UAAU,EAAC,GAAG,UAAU,CAAC;IAEhC,MAAM,yBAAyB,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACjD,MAAM,0BAA0B,GAAG,CAAA,iBAAiB,aAAjB,iBAAiB,uBAAjB,iBAAiB,CAAE,kBAAkB,KAAI,EAAE,CAAC;QAE/E,OAAO;YACH,GAAG,iBAAiB;YACpB,kBAAkB,EAAE,CAAC,GAAG,0BAA0B,EAAE,UAAU,CAAC;SAClE,CAAC;IACN,CAAC,EAAE,CAAC,iBAAiB,EAAE,UAAU,CAAC,CAAC,CAAC;IAEpC,OAAO,CACH,KAAC,uBAAuB,CAAC,KAAK,OAAK,yBAAyB,YACvD,KAAK,GACsB,CACnC,CAAC;AACN,CAAC,CAAC;AAEF,MAAM,eAAe,GAAG,CAAC,EAAC,QAAQ,EAA+B,EAAE,EAAE;IACjE,IAAI,CAAC,QAAQ,EAAE,CAAC;QACZ,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,OAAO,KAAC,uBAAuB,CAAC,QAAQ,cAAE,QAAQ,GAAoC,CAAC;AAC3F,CAAC,CAAC;AAEF,MAAM,YAAY,GAAG,CAAC,EAAC,KAAK,EAA4B,EAAE,EAAE;IACxD,IAAI,CAAC,KAAK,EAAE,CAAC;QACT,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,OAAO,KAAC,KAAK,CAAC,QAAQ,cAAE,KAAK,GAAkB,CAAC;AACpD,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,EACrC,QAAQ,EACR,KAAK,EACL,iBAAiB,EACjB,KAAK,EACL,YAAY,EACZ,UAAU,EACV,UAAU,GAAG,IAAI,GACW,EAAE,EAAE;IAChC,OAAO,CACH,KAAC,sBAAsB,IAAC,YAAY,EAAE,YAAY,EAAE,UAAU,EAAE,UAAU,YACtE,MAAC,uBAAuB,IAAC,UAAU,EAAE,UAAU,aAC3C,KAAC,eAAe,IAAC,QAAQ,EAAE,QAAQ,GAAI,EACvC,KAAC,YAAY,IAAC,KAAK,EAAE,KAAK,GAAI,EAC9B,KAAC,YAAY,IAAC,KAAK,EAAE,KAAK,EAAE,iBAAiB,EAAE,iBAAiB,GAAI,IAC9C,GACL,CAC5B,CAAC;AACN,CAAC,CAAC"}
@@ -7,7 +7,8 @@ interface TableChunkProps<T, F> {
7
7
  columns: Column<T>[];
8
8
  filters?: F;
9
9
  sortParams?: SortParams;
10
- isActive: boolean;
10
+ shouldFetch: boolean;
11
+ shouldRender: boolean;
11
12
  tableName: string;
12
13
  fetchData: FetchData<T, F>;
13
14
  getRowClassName?: GetRowClassName<T>;
@@ -16,5 +17,5 @@ interface TableChunkProps<T, F> {
16
17
  onDataFetched: (data?: PaginatedTableData<T>) => void;
17
18
  keepCache?: boolean;
18
19
  }
19
- export declare const TableChunk: <T, F>({ id, chunkSize, calculatedCount, rowHeight, columns, fetchData, tableName, filters, sortParams, getRowClassName, renderErrorMessage, renderEmptyDataMessage, onDataFetched, isActive, keepCache, }: TableChunkProps<T, F>) => import("react/jsx-runtime").JSX.Element;
20
+ export declare const TableChunk: <T, F>({ id, chunkSize, calculatedCount, rowHeight, columns, fetchData, tableName, filters, sortParams, getRowClassName, renderErrorMessage, renderEmptyDataMessage, onDataFetched, shouldFetch, shouldRender, keepCache, }: TableChunkProps<T, F>) => import("react/jsx-runtime").JSX.Element | import("react/jsx-runtime").JSX.Element[] | null;
20
21
  export {};
@@ -4,15 +4,17 @@ import { tableDataApi } from '../../store/reducers/tableData';
4
4
  import { getArray } from '../../utils';
5
5
  import { useAutoRefreshInterval } from '../../utils/hooks';
6
6
  import { ResponseError } from '../Errors/ResponseError';
7
+ import { usePaginatedTableState } from './PaginatedTableContext';
7
8
  import { EmptyTableRow, LoadingTableRow, TableRow } from './TableRow';
8
9
  import i18n from './i18n';
9
10
  import { typedMemo } from './utils';
10
11
  const DEBOUNCE_TIMEOUT = 200;
11
12
  // Memoisation prevents chunks rerenders that could cause perfomance issues on big tables
12
- export const TableChunk = typedMemo(function TableChunk({ id, chunkSize, calculatedCount, rowHeight, columns, fetchData, tableName, filters, sortParams, getRowClassName, renderErrorMessage, renderEmptyDataMessage, onDataFetched, isActive, keepCache, }) {
13
+ export const TableChunk = typedMemo(function TableChunk({ id, chunkSize, calculatedCount, rowHeight, columns, fetchData, tableName, filters, sortParams, getRowClassName, renderErrorMessage, renderEmptyDataMessage, onDataFetched, shouldFetch, shouldRender, keepCache, }) {
13
14
  var _a;
14
15
  const [isTimeoutActive, setIsTimeoutActive] = React.useState(true);
15
16
  const [autoRefreshInterval] = useAutoRefreshInterval();
17
+ const { noBatching } = usePaginatedTableState();
16
18
  const columnsIds = columns.map((column) => column.name);
17
19
  const queryParams = {
18
20
  offset: id * chunkSize,
@@ -22,16 +24,17 @@ export const TableChunk = typedMemo(function TableChunk({ id, chunkSize, calcula
22
24
  sortParams,
23
25
  columnsIds,
24
26
  tableName,
27
+ noBatching,
25
28
  };
26
29
  tableDataApi.useFetchTableChunkQuery(queryParams, {
27
- skip: isTimeoutActive || !isActive,
30
+ skip: isTimeoutActive || !shouldFetch,
28
31
  pollingInterval: autoRefreshInterval,
29
32
  refetchOnMountOrArgChange: !keepCache,
30
33
  });
31
34
  const { currentData, error } = tableDataApi.endpoints.fetchTableChunk.useQueryState(queryParams);
32
35
  React.useEffect(() => {
33
36
  let timeout = 0;
34
- if (isActive && isTimeoutActive) {
37
+ if (shouldFetch && isTimeoutActive) {
35
38
  timeout = window.setTimeout(() => {
36
39
  setIsTimeoutActive(false);
37
40
  }, DEBOUNCE_TIMEOUT);
@@ -39,9 +42,9 @@ export const TableChunk = typedMemo(function TableChunk({ id, chunkSize, calcula
39
42
  return () => {
40
43
  window.clearTimeout(timeout);
41
44
  };
42
- }, [isActive, isTimeoutActive]);
45
+ }, [shouldFetch, isTimeoutActive]);
43
46
  React.useEffect(() => {
44
- if (currentData && isActive) {
47
+ if (currentData) {
45
48
  onDataFetched({
46
49
  ...currentData,
47
50
  data: currentData.data,
@@ -49,17 +52,14 @@ export const TableChunk = typedMemo(function TableChunk({ id, chunkSize, calcula
49
52
  total: currentData.total || 0,
50
53
  });
51
54
  }
52
- }, [currentData, isActive, onDataFetched]);
55
+ }, [currentData, onDataFetched]);
53
56
  const dataLength = ((_a = currentData === null || currentData === void 0 ? void 0 : currentData.data) === null || _a === void 0 ? void 0 : _a.length) || calculatedCount;
54
57
  const renderContent = () => {
55
58
  var _a;
56
- if (!isActive) {
57
- return null;
58
- }
59
59
  if (!currentData) {
60
60
  if (error) {
61
61
  const errorData = error;
62
- return (_jsx(EmptyTableRow, { columns: columns, children: renderErrorMessage ? (renderErrorMessage(errorData)) : (_jsx(ResponseError, { error: errorData })) }));
62
+ return (_jsx(EmptyTableRow, { columns: columns, height: dataLength * rowHeight, children: renderErrorMessage ? (renderErrorMessage(errorData)) : (_jsx(ResponseError, { error: errorData })) }));
63
63
  }
64
64
  else {
65
65
  return getArray(dataLength).map((value) => (_jsx(LoadingTableRow, { columns: columns, height: rowHeight }, value)));
@@ -67,16 +67,10 @@ export const TableChunk = typedMemo(function TableChunk({ id, chunkSize, calcula
67
67
  }
68
68
  // Data is loaded, but there are no entities in the chunk
69
69
  if (!((_a = currentData.data) === null || _a === void 0 ? void 0 : _a.length)) {
70
- return (_jsx(EmptyTableRow, { columns: columns, children: renderEmptyDataMessage ? renderEmptyDataMessage() : i18n('empty') }));
70
+ return (_jsx(EmptyTableRow, { columns: columns, height: dataLength * rowHeight, children: renderEmptyDataMessage ? renderEmptyDataMessage() : i18n('empty') }));
71
71
  }
72
72
  return currentData.data.map((rowData, index) => (_jsx(TableRow, { row: rowData, columns: columns, height: rowHeight, getRowClassName: getRowClassName }, index)));
73
73
  };
74
- return (_jsx("tbody", { id: id.toString(), style: {
75
- height: `${dataLength * rowHeight}px`,
76
- // Default display: table-row-group doesn't work in Safari and breaks the table
77
- // display: block works in Safari, but disconnects thead and tbody cell grids
78
- // Hack to make it work in all cases
79
- display: isActive ? 'table-row-group' : 'block',
80
- }, children: renderContent() }));
74
+ return shouldRender ? renderContent() : null;
81
75
  });
82
76
  //# sourceMappingURL=TableChunk.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TableChunk.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/TableChunk.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAC,YAAY,EAAC,MAAM,gCAAgC,CAAC;AAE5D,OAAO,EAAC,QAAQ,EAAC,MAAM,aAAa,CAAC;AACrC,OAAO,EAAC,sBAAsB,EAAC,MAAM,mBAAmB,CAAC;AACzD,OAAO,EAAC,aAAa,EAAC,MAAM,yBAAyB,CAAC;AAEtD,OAAO,EAAC,aAAa,EAAE,eAAe,EAAE,QAAQ,EAAC,MAAM,YAAY,CAAC;AACpE,OAAO,IAAI,MAAM,QAAQ,CAAC;AAU1B,OAAO,EAAC,SAAS,EAAC,MAAM,SAAS,CAAC;AAElC,MAAM,gBAAgB,GAAG,GAAG,CAAC;AAsB7B,yFAAyF;AACzF,MAAM,CAAC,MAAM,UAAU,GAAG,SAAS,CAAC,SAAS,UAAU,CAAO,EAC1D,EAAE,EACF,SAAS,EACT,eAAe,EACf,SAAS,EACT,OAAO,EACP,SAAS,EACT,SAAS,EACT,OAAO,EACP,UAAU,EACV,eAAe,EACf,kBAAkB,EAClB,sBAAsB,EACtB,aAAa,EACb,QAAQ,EACR,SAAS,GACW;;IACpB,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IACnE,MAAM,CAAC,mBAAmB,CAAC,GAAG,sBAAsB,EAAE,CAAC;IAEvD,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAExD,MAAM,WAAW,GAAG;QAChB,MAAM,EAAE,EAAE,GAAG,SAAS;QACtB,KAAK,EAAE,SAAS;QAChB,SAAS,EAAE,SAAkC;QAC7C,OAAO;QACP,UAAU;QACV,UAAU;QACV,SAAS;KACZ,CAAC;IAEF,YAAY,CAAC,uBAAuB,CAAC,WAAW,EAAE;QAC9C,IAAI,EAAE,eAAe,IAAI,CAAC,QAAQ;QAClC,eAAe,EAAE,mBAAmB;QACpC,yBAAyB,EAAE,CAAC,SAAS;KACxC,CAAC,CAAC;IAEH,MAAM,EAAC,WAAW,EAAE,KAAK,EAAC,GAAG,YAAY,CAAC,SAAS,CAAC,eAAe,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;IAE/F,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACjB,IAAI,OAAO,GAAG,CAAC,CAAC;QAEhB,IAAI,QAAQ,IAAI,eAAe,EAAE,CAAC;YAC9B,OAAO,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;gBAC7B,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAC9B,CAAC,EAAE,gBAAgB,CAAC,CAAC;QACzB,CAAC;QAED,OAAO,GAAG,EAAE;YACR,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;QACjC,CAAC,CAAC;IACN,CAAC,EAAE,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC,CAAC;IAEhC,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACjB,IAAI,WAAW,IAAI,QAAQ,EAAE,CAAC;YAC1B,aAAa,CAAC;gBACV,GAAG,WAAW;gBACd,IAAI,EAAE,WAAW,CAAC,IAAW;gBAC7B,KAAK,EAAE,WAAW,CAAC,KAAK,IAAI,CAAC;gBAC7B,KAAK,EAAE,WAAW,CAAC,KAAK,IAAI,CAAC;aAChC,CAAC,CAAC;QACP,CAAC;IACL,CAAC,EAAE,CAAC,WAAW,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC,CAAC;IAE3C,MAAM,UAAU,GAAG,CAAA,MAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,IAAI,0CAAE,MAAM,KAAI,eAAe,CAAC;IAEhE,MAAM,aAAa,GAAG,GAAG,EAAE;;QACvB,IAAI,CAAC,QAAQ,EAAE,CAAC;YACZ,OAAO,IAAI,CAAC;QAChB,CAAC;QAED,IAAI,CAAC,WAAW,EAAE,CAAC;YACf,IAAI,KAAK,EAAE,CAAC;gBACR,MAAM,SAAS,GAAG,KAAuB,CAAC;gBAC1C,OAAO,CACH,KAAC,aAAa,IAAC,OAAO,EAAE,OAAO,YAC1B,kBAAkB,CAAC,CAAC,CAAC,CAClB,kBAAkB,CAAC,SAAS,CAAC,CAChC,CAAC,CAAC,CAAC,CACA,KAAC,aAAa,IAAC,KAAK,EAAE,SAAS,GAAI,CACtC,GACW,CACnB,CAAC;YACN,CAAC;iBAAM,CAAC;gBACJ,OAAO,QAAQ,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CACvC,KAAC,eAAe,IAAa,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,IAA1C,KAAK,CAAyC,CACvE,CAAC,CAAC;YACP,CAAC;QACL,CAAC;QAED,yDAAyD;QACzD,IAAI,CAAC,CAAA,MAAA,WAAW,CAAC,IAAI,0CAAE,MAAM,CAAA,EAAE,CAAC;YAC5B,OAAO,CACH,KAAC,aAAa,IAAC,OAAO,EAAE,OAAO,YAC1B,sBAAsB,CAAC,CAAC,CAAC,sBAAsB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,GACtD,CACnB,CAAC;QACN,CAAC;QAED,OAAO,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,CAAC,CAC5C,KAAC,QAAQ,IAEL,GAAG,EAAE,OAAY,EACjB,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,SAAS,EACjB,eAAe,EAAE,eAAe,IAJ3B,KAAK,CAKZ,CACL,CAAC,CAAC;IACP,CAAC,CAAC;IAEF,OAAO,CACH,gBACI,EAAE,EAAE,EAAE,CAAC,QAAQ,EAAE,EACjB,KAAK,EAAE;YACH,MAAM,EAAE,GAAG,UAAU,GAAG,SAAS,IAAI;YACrC,+EAA+E;YAC/E,6EAA6E;YAC7E,oCAAoC;YACpC,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,OAAO;SAClD,YAEA,aAAa,EAAE,GACZ,CACX,CAAC;AACN,CAAC,CAAC,CAAC"}
1
+ {"version":3,"file":"TableChunk.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/TableChunk.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ import React from 'react';
2
+ import type { Column, FetchData, GetRowClassName, PaginatedTableData, RenderEmptyDataMessage, RenderErrorMessage, SortParams } from './types';
3
+ export interface TableChunksRendererProps<T, F> {
4
+ scrollContainerRef: React.RefObject<HTMLElement>;
5
+ tableRef: React.RefObject<HTMLElement>;
6
+ foundEntities: number;
7
+ tableOffset: number;
8
+ chunkSize: number;
9
+ rowHeight: number;
10
+ columns: Column<T>[];
11
+ fetchData: FetchData<T, F>;
12
+ filters?: F;
13
+ tableName: string;
14
+ sortParams?: SortParams;
15
+ getRowClassName?: GetRowClassName<T>;
16
+ renderErrorMessage?: RenderErrorMessage;
17
+ renderEmptyDataMessage?: RenderEmptyDataMessage;
18
+ onDataFetched: (data?: PaginatedTableData<T>) => void;
19
+ keepCache: boolean;
20
+ }
21
+ export declare const TableChunksRenderer: <T, F>({ scrollContainerRef, tableRef, foundEntities, tableOffset, chunkSize, rowHeight, columns, fetchData, filters, tableName, sortParams, getRowClassName, renderErrorMessage, renderEmptyDataMessage, onDataFetched, keepCache, }: TableChunksRendererProps<T, F>) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,96 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import { TableChunk } from './TableChunk';
4
+ import { b } from './shared';
5
+ import { useScrollBasedChunks } from './useScrollBasedChunks';
6
+ export const TableChunksRenderer = ({ scrollContainerRef, tableRef, foundEntities, tableOffset, chunkSize, rowHeight, columns, fetchData, filters, tableName, sortParams, getRowClassName, renderErrorMessage, renderEmptyDataMessage, onDataFetched, keepCache, }) => {
7
+ const chunkStates = useScrollBasedChunks({
8
+ scrollContainerRef,
9
+ tableRef,
10
+ totalItems: foundEntities || 1,
11
+ rowHeight,
12
+ chunkSize,
13
+ tableOffset,
14
+ });
15
+ const lastChunkSize = React.useMemo(() => {
16
+ // If foundEntities = 0, there will only first chunk
17
+ // Display it with 1 row, to display empty data message
18
+ if (!foundEntities) {
19
+ return 1;
20
+ }
21
+ return foundEntities % chunkSize || chunkSize;
22
+ }, [foundEntities, chunkSize]);
23
+ const findRenderChunkRange = React.useCallback(() => {
24
+ const firstRenderIndex = chunkStates.findIndex((state) => state.shouldRender);
25
+ const lastRenderIndex = chunkStates.findLastIndex((state) => state.shouldRender);
26
+ return { firstRenderIndex, lastRenderIndex };
27
+ }, [chunkStates]);
28
+ const findFetchChunkRange = React.useCallback(() => {
29
+ const firstFetchIndex = chunkStates.findIndex((state) => state.shouldFetch);
30
+ const lastFetchIndex = chunkStates.findLastIndex((state) => state.shouldFetch);
31
+ return { firstFetchIndex, lastFetchIndex };
32
+ }, [chunkStates]);
33
+ const calculateSeparatorHeight = React.useCallback((startIndex, endIndex) => {
34
+ let totalHeight = 0;
35
+ for (let i = startIndex; i < endIndex; i++) {
36
+ const currentChunkSize = i === chunkStates.length - 1 ? lastChunkSize : chunkSize;
37
+ totalHeight += currentChunkSize * rowHeight;
38
+ }
39
+ return totalHeight;
40
+ }, [chunkSize, chunkStates.length, lastChunkSize, rowHeight]);
41
+ const createSeparator = React.useCallback((startIndex, endIndex, key) => {
42
+ const height = calculateSeparatorHeight(startIndex, endIndex);
43
+ return (_jsx("tr", { style: { height: `${height}px` }, className: b(key), children: _jsx("td", { colSpan: columns.length, style: { padding: 0, border: 'none' } }) }, key));
44
+ }, [calculateSeparatorHeight, columns.length]);
45
+ const createChunk = React.useCallback((chunkIndex) => {
46
+ const chunkState = chunkStates[chunkIndex];
47
+ return (_jsx(TableChunk, { id: chunkIndex, calculatedCount: chunkIndex === chunkStates.length - 1 ? lastChunkSize : chunkSize, chunkSize: chunkSize, rowHeight: rowHeight, columns: columns, fetchData: fetchData, filters: filters, tableName: tableName, sortParams: sortParams, getRowClassName: getRowClassName, renderErrorMessage: renderErrorMessage, renderEmptyDataMessage: renderEmptyDataMessage, onDataFetched: onDataFetched, shouldFetch: chunkState.shouldFetch, shouldRender: chunkState.shouldRender, keepCache: keepCache }, chunkIndex));
48
+ }, [
49
+ chunkSize,
50
+ chunkStates,
51
+ columns,
52
+ fetchData,
53
+ filters,
54
+ getRowClassName,
55
+ keepCache,
56
+ lastChunkSize,
57
+ onDataFetched,
58
+ renderEmptyDataMessage,
59
+ renderErrorMessage,
60
+ rowHeight,
61
+ sortParams,
62
+ tableName,
63
+ ]);
64
+ const renderChunks = React.useCallback(() => {
65
+ // Chunk states are distrubuted like [null, null, fetch, fetch, render+fetch, render+fetch, fetch, fetch, null, null]
66
+ // i.e. fetched chunks include rendered chunks
67
+ const { firstFetchIndex, lastFetchIndex } = findFetchChunkRange();
68
+ const { firstRenderIndex, lastRenderIndex } = findRenderChunkRange();
69
+ const elements = [];
70
+ // No fetch chunks found
71
+ if (firstFetchIndex === -1) {
72
+ return elements;
73
+ }
74
+ // Beginning separator (for chunks before first render chunk)
75
+ if (firstRenderIndex > 0) {
76
+ elements.push(createSeparator(0, firstRenderIndex, 'separator-beginning'));
77
+ }
78
+ // All fetch chunks (shouldFetch = true) get rendered as TableChunk components
79
+ for (let i = firstFetchIndex; i <= lastFetchIndex; i++) {
80
+ elements.push(createChunk(i));
81
+ }
82
+ // End separator (for chunks after last render chunk)
83
+ if (lastRenderIndex < chunkStates.length - 1) {
84
+ elements.push(createSeparator(lastRenderIndex + 1, chunkStates.length, 'separator-end'));
85
+ }
86
+ return elements;
87
+ }, [
88
+ chunkStates.length,
89
+ createChunk,
90
+ createSeparator,
91
+ findFetchChunkRange,
92
+ findRenderChunkRange,
93
+ ]);
94
+ return _jsx(React.Fragment, { children: renderChunks() });
95
+ };
96
+ //# sourceMappingURL=TableChunksRenderer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableChunksRenderer.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/TableChunksRenderer.tsx"],"names":[],"mappings":"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"}
@@ -14,6 +14,7 @@ export declare const TableRow: <T>({ row, columns, getRowClassName, height }: Ta
14
14
  interface EmptyTableRowProps<T> {
15
15
  columns: Column<T>[];
16
16
  children?: React.ReactNode;
17
+ height: number;
17
18
  }
18
- export declare const EmptyTableRow: <T>({ columns, children }: EmptyTableRowProps<T>) => import("react/jsx-runtime").JSX.Element;
19
+ export declare const EmptyTableRow: <T>({ columns, children, height }: EmptyTableRowProps<T>) => import("react/jsx-runtime").JSX.Element;
19
20
  export {};
@@ -12,7 +12,7 @@ const TableRowCell = ({ children, className, height, width, align = DEFAULT_ALIG
12
12
  }, children: children }));
13
13
  };
14
14
  export const LoadingTableRow = typedMemo(function ({ columns, height }) {
15
- return (_jsx("tr", { className: b('row', { loading: true }), children: columns.map((column) => {
15
+ return (_jsx("tr", { className: b('row', { loading: true }), style: { height }, children: columns.map((column) => {
16
16
  var _a;
17
17
  const resizeable = (_a = column.resizeable) !== null && _a !== void 0 ? _a : DEFAULT_RESIZEABLE;
18
18
  return (_jsx(TableRowCell, { height: height, width: column.width, align: column.align, className: column.className, resizeable: resizeable, children: _jsx(Skeleton, { className: b('row-skeleton'), style: { width: '80%', height: '50%' } }) }, column.name));
@@ -20,13 +20,13 @@ export const LoadingTableRow = typedMemo(function ({ columns, height }) {
20
20
  });
21
21
  export const TableRow = ({ row, columns, getRowClassName, height }) => {
22
22
  const additionalClassName = getRowClassName === null || getRowClassName === void 0 ? void 0 : getRowClassName(row);
23
- return (_jsx("tr", { className: b('row', additionalClassName), children: columns.map((column) => {
23
+ return (_jsx("tr", { className: b('row', additionalClassName), style: { height }, children: columns.map((column) => {
24
24
  var _a;
25
25
  const resizeable = (_a = column.resizeable) !== null && _a !== void 0 ? _a : DEFAULT_RESIZEABLE;
26
26
  return (_jsx(TableRowCell, { height: height, width: column.width, align: column.align, className: column.className, resizeable: resizeable, children: column.render({ row }) }, column.name));
27
27
  }) }));
28
28
  };
29
- export const EmptyTableRow = ({ columns, children }) => {
30
- return (_jsx("tr", { className: b('row', { empty: true }), children: _jsx("td", { colSpan: columns.length, className: b('td'), children: children }) }));
29
+ export const EmptyTableRow = ({ columns, children, height }) => {
30
+ return (_jsx("tr", { className: b('row', { empty: true }), style: { height }, children: _jsx("td", { colSpan: columns.length, className: b('td'), children: children }) }));
31
31
  };
32
32
  //# sourceMappingURL=TableRow.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TableRow.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/TableRow.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"TableRow.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/TableRow.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,28 @@
1
+ import type { FetchData, PaginatedTableData, SortParams } from './types';
2
+ interface PaginatedTableParams<T, F> {
3
+ offset: number;
4
+ fetchData: FetchData<T, F>;
5
+ filters: F;
6
+ limit: number;
7
+ sortParams?: SortParams;
8
+ columnsIds: string[];
9
+ tableName: string;
10
+ }
11
+ declare class RequestBatcher {
12
+ private requestQueue;
13
+ private batchTimeout;
14
+ private readonly BATCH_DELAY;
15
+ queueRequest<T, F>(params: PaginatedTableParams<T, F>, signal?: AbortSignal): Promise<{
16
+ data: PaginatedTableData<T>;
17
+ } | {
18
+ error: unknown;
19
+ }>;
20
+ private createBatchKey;
21
+ private groupConsecutiveRequests;
22
+ private createBatchGroup;
23
+ private executeBatch;
24
+ private splitAndDistributeResponse;
25
+ private processBatch;
26
+ }
27
+ export declare const requestBatcher: RequestBatcher;
28
+ export {};
@@ -0,0 +1,128 @@
1
+ class RequestBatcher {
2
+ constructor() {
3
+ this.requestQueue = new Map();
4
+ this.batchTimeout = null;
5
+ this.BATCH_DELAY = 50; // ms
6
+ }
7
+ queueRequest(params, signal) {
8
+ return new Promise((resolve, reject) => {
9
+ const batchKey = this.createBatchKey(params);
10
+ if (!this.requestQueue.has(batchKey)) {
11
+ this.requestQueue.set(batchKey, []);
12
+ }
13
+ this.requestQueue.get(batchKey).push({
14
+ params,
15
+ resolve,
16
+ reject,
17
+ signal,
18
+ });
19
+ // Reset the batch timeout
20
+ if (this.batchTimeout) {
21
+ clearTimeout(this.batchTimeout);
22
+ }
23
+ this.batchTimeout = setTimeout(() => {
24
+ this.processBatch();
25
+ }, this.BATCH_DELAY);
26
+ });
27
+ }
28
+ createBatchKey(params) {
29
+ return JSON.stringify({
30
+ tableName: params.tableName,
31
+ filters: params.filters,
32
+ sortParams: params.sortParams,
33
+ columnsIds: params.columnsIds,
34
+ limit: params.limit,
35
+ });
36
+ }
37
+ groupConsecutiveRequests(requests) {
38
+ if (requests.length === 0) {
39
+ return [];
40
+ }
41
+ const sorted = requests.sort((a, b) => a.params.offset - b.params.offset);
42
+ const groups = [];
43
+ let currentGroup = [sorted[0]];
44
+ const limit = sorted[0].params.limit;
45
+ for (let i = 1; i < sorted.length; i++) {
46
+ const expectedOffset = currentGroup[currentGroup.length - 1].params.offset + limit;
47
+ if (sorted[i].params.offset === expectedOffset) {
48
+ // Consecutive request
49
+ currentGroup.push(sorted[i]);
50
+ }
51
+ else {
52
+ // Non-consecutive, create a new group
53
+ groups.push(this.createBatchGroup(currentGroup));
54
+ currentGroup = [sorted[i]];
55
+ }
56
+ }
57
+ // Add the last group
58
+ groups.push(this.createBatchGroup(currentGroup));
59
+ return groups;
60
+ }
61
+ createBatchGroup(requests) {
62
+ const minOffset = Math.min(...requests.map((r) => r.params.offset));
63
+ const maxOffset = Math.max(...requests.map((r) => r.params.offset));
64
+ const limit = requests[0].params.limit;
65
+ const totalLimit = requests.length * limit;
66
+ return {
67
+ requests,
68
+ batchKey: this.createBatchKey(requests[0].params),
69
+ minOffset,
70
+ maxOffset,
71
+ totalLimit,
72
+ };
73
+ }
74
+ async executeBatch(group) {
75
+ const firstRequest = group.requests[0];
76
+ const batchParams = {
77
+ ...firstRequest.params,
78
+ offset: group.minOffset,
79
+ limit: group.totalLimit,
80
+ };
81
+ try {
82
+ const response = await firstRequest.params.fetchData({
83
+ limit: batchParams.limit,
84
+ offset: batchParams.offset,
85
+ filters: batchParams.filters,
86
+ sortParams: batchParams.sortParams,
87
+ columnsIds: batchParams.columnsIds,
88
+ signal: firstRequest.signal,
89
+ });
90
+ // Split the response data among individual requests
91
+ this.splitAndDistributeResponse(group, response);
92
+ }
93
+ catch (error) {
94
+ // If batch fails, reject all requests in the group
95
+ group.requests.forEach((request) => {
96
+ request.resolve({ error });
97
+ });
98
+ }
99
+ }
100
+ splitAndDistributeResponse(group, batchResponse) {
101
+ const limit = group.requests[0].params.limit;
102
+ group.requests.forEach((request, index) => {
103
+ const startIndex = index * limit;
104
+ const endIndex = startIndex + limit;
105
+ const chunkData = batchResponse.data.slice(startIndex, endIndex);
106
+ const chunkResponse = {
107
+ ...batchResponse,
108
+ data: chunkData,
109
+ total: batchResponse.total,
110
+ found: batchResponse.found,
111
+ };
112
+ request.resolve({ data: chunkResponse });
113
+ });
114
+ }
115
+ async processBatch() {
116
+ const allQueues = Array.from(this.requestQueue.entries());
117
+ this.requestQueue.clear();
118
+ this.batchTimeout = null;
119
+ for (const [_batchKey, requests] of allQueues) {
120
+ const groups = this.groupConsecutiveRequests(requests);
121
+ // Execute each group (consecutive chunks) as a separate batch
122
+ await Promise.all(groups.map((group) => this.executeBatch(group)));
123
+ }
124
+ }
125
+ }
126
+ // Singleton instance
127
+ export const requestBatcher = new RequestBatcher();
128
+ //# sourceMappingURL=requestBatcher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"requestBatcher.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/requestBatcher.ts"],"names":[],"mappings":"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"}
@@ -5,7 +5,13 @@ interface UseScrollBasedChunksProps {
5
5
  totalItems: number;
6
6
  rowHeight: number;
7
7
  chunkSize: number;
8
- overscanCount?: number;
8
+ renderOverscan?: number;
9
+ fetchOverscan?: number;
10
+ tableOffset: number;
9
11
  }
10
- export declare const useScrollBasedChunks: ({ scrollContainerRef, tableRef, totalItems, rowHeight, chunkSize, overscanCount, }: UseScrollBasedChunksProps) => boolean[];
12
+ interface ChunkState {
13
+ shouldRender: boolean;
14
+ shouldFetch: boolean;
15
+ }
16
+ export declare const useScrollBasedChunks: ({ scrollContainerRef, tableRef, totalItems, rowHeight, chunkSize, tableOffset, renderOverscan, fetchOverscan, }: UseScrollBasedChunksProps) => ChunkState[];
11
17
  export {};