ydb-embedded-ui 8.26.2 → 9.1.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 (218) hide show
  1. package/dist/components/DiskStateProgressBar/DiskStateProgressBar.js +1 -1
  2. package/dist/components/Drawer/Drawer.d.ts +1 -1
  3. package/dist/components/Drawer/Drawer.js +11 -4
  4. package/dist/components/Drawer/Drawer.js.map +1 -1
  5. package/dist/components/Drawer/Drawer.scss +6 -1
  6. package/dist/components/EnableFullscreenButton/EnableFullscreenButton.d.ts +3 -1
  7. package/dist/components/EnableFullscreenButton/EnableFullscreenButton.js +2 -2
  8. package/dist/components/EnableFullscreenButton/EnableFullscreenButton.js.map +1 -1
  9. package/dist/components/EntityStatus/EntityStatus.d.ts +2 -1
  10. package/dist/components/EntityStatus/EntityStatus.js +6 -3
  11. package/dist/components/EntityStatus/EntityStatus.js.map +1 -1
  12. package/dist/components/EntityStatusNew/i18n/en.json +1 -1
  13. package/dist/components/JsonViewer/JsonViewer.d.ts +2 -0
  14. package/dist/components/JsonViewer/JsonViewer.js +4 -4
  15. package/dist/components/JsonViewer/JsonViewer.js.map +1 -1
  16. package/dist/components/JsonViewer/JsonViewer.scss +2 -0
  17. package/dist/components/JsonViewer/components/Cell.d.ts +1 -0
  18. package/dist/components/JsonViewer/components/Cell.js +6 -6
  19. package/dist/components/JsonViewer/components/Cell.js.map +1 -1
  20. package/dist/components/JsonViewer/components/FullValueDialog.js +5 -1
  21. package/dist/components/JsonViewer/components/FullValueDialog.js.map +1 -1
  22. package/dist/components/MemoryViewer/MemoryViewer.js +1 -1
  23. package/dist/components/ProgressViewer/ProgressViewer.js +1 -1
  24. package/dist/components/ShortyString/ShortyString.scss +1 -1
  25. package/dist/components/TableWithControlsLayout/TableWithControlsLayout.scss +1 -1
  26. package/dist/components/Tags/Tags.js +2 -1
  27. package/dist/components/Tags/Tags.js.map +1 -1
  28. package/dist/components/VDisk/utils.d.ts +2 -2
  29. package/dist/components/VDisk/utils.js +12 -13
  30. package/dist/components/VDisk/utils.js.map +1 -1
  31. package/dist/components/VDiskInfo/VDiskInfo.js +5 -1
  32. package/dist/components/VDiskInfo/VDiskInfo.js.map +1 -1
  33. package/dist/components/VDiskPopup/VDiskPopup.js +15 -12
  34. package/dist/components/VDiskPopup/VDiskPopup.js.map +1 -1
  35. package/dist/containers/AppWithClusters/AppWithClusters.d.ts +1 -5
  36. package/dist/containers/AppWithClusters/AppWithClusters.js +4 -5
  37. package/dist/containers/AppWithClusters/AppWithClusters.js.map +1 -1
  38. package/dist/containers/AppWithClusters/ExtendedCluster/ExtendedCluster.d.ts +2 -1
  39. package/dist/containers/AppWithClusters/ExtendedCluster/ExtendedCluster.js.map +1 -1
  40. package/dist/containers/AppWithClusters/ExtendedTenant/ExtendedTenant.d.ts +2 -1
  41. package/dist/containers/AppWithClusters/ExtendedTenant/ExtendedTenant.js.map +1 -1
  42. package/dist/containers/Cluster/ClusterInfo/ClusterInfo.js +3 -3
  43. package/dist/containers/Cluster/ClusterInfo/ClusterInfo.scss +2 -0
  44. package/dist/containers/Cluster/ClusterInfo/components/DiskGroupsStatsBars/DiskGroupsStats.js +3 -3
  45. package/dist/containers/Cluster/ClusterInfo/components/DiskGroupsStatsBars/DiskGroupsStats.js.map +1 -1
  46. package/dist/containers/Cluster/ClusterInfo/components/DiskGroupsStatsBars/DiskGroupsStats.scss +6 -1
  47. package/dist/containers/Cluster/ClusterInfo/utils/utils.js +3 -3
  48. package/dist/containers/Cluster/ClusterInfo/utils/utils.js.map +1 -1
  49. package/dist/containers/Node/Node.js +1 -1
  50. package/dist/containers/Node/Node.js.map +1 -1
  51. package/dist/containers/Operations/constants.js +1 -0
  52. package/dist/containers/Operations/constants.js.map +1 -1
  53. package/dist/containers/Operations/i18n/en.json +1 -0
  54. package/dist/containers/Operations/i18n/index.d.ts +1 -1
  55. package/dist/containers/Operations/useOperationsQueryParams.js +1 -1
  56. package/dist/containers/Operations/useOperationsQueryParams.js.map +1 -1
  57. package/dist/containers/PDiskPage/PDiskSpaceDistribution/PDiskSpaceDistribution.js +1 -1
  58. package/dist/containers/PDiskPage/PDiskSpaceDistribution/PDiskSpaceDistribution.js.map +1 -1
  59. package/dist/containers/Tablets/Tablets.d.ts +6 -1
  60. package/dist/containers/Tablets/Tablets.js +4 -3
  61. package/dist/containers/Tablets/Tablets.js.map +1 -1
  62. package/dist/containers/Tenant/Diagnostics/Describe/Describe.d.ts +1 -3
  63. package/dist/containers/Tenant/Diagnostics/Describe/Describe.js +9 -33
  64. package/dist/containers/Tenant/Diagnostics/Describe/Describe.js.map +1 -1
  65. package/dist/containers/Tenant/Diagnostics/Diagnostics.d.ts +2 -1
  66. package/dist/containers/Tenant/Diagnostics/Diagnostics.js +2 -2
  67. package/dist/containers/Tenant/Diagnostics/Diagnostics.js.map +1 -1
  68. package/dist/containers/Tenant/Diagnostics/DiagnosticsPages.d.ts +2 -2
  69. package/dist/containers/Tenant/Diagnostics/DiagnosticsPages.js +13 -7
  70. package/dist/containers/Tenant/Diagnostics/DiagnosticsPages.js.map +1 -1
  71. package/dist/containers/Tenant/Diagnostics/Overview/ChangefeedInfo/ChangefeedInfo.d.ts +1 -1
  72. package/dist/containers/Tenant/Diagnostics/Overview/ChangefeedInfo/ChangefeedInfo.js +7 -10
  73. package/dist/containers/Tenant/Diagnostics/Overview/ChangefeedInfo/ChangefeedInfo.js.map +1 -1
  74. package/dist/containers/Tenant/Diagnostics/Overview/Overview.js +8 -32
  75. package/dist/containers/Tenant/Diagnostics/Overview/Overview.js.map +1 -1
  76. package/dist/containers/Tenant/Diagnostics/Overview/TopicInfo/TopicInfo.js +10 -1
  77. package/dist/containers/Tenant/Diagnostics/Overview/TopicInfo/TopicInfo.js.map +1 -1
  78. package/dist/containers/Tenant/Diagnostics/Partitions/PartitionsControls/PartitionsControls.js +1 -1
  79. package/dist/containers/Tenant/Diagnostics/Partitions/PartitionsControls/PartitionsControls.js.map +1 -1
  80. package/dist/containers/Tenant/Diagnostics/Partitions/columns/columns.js +1 -1
  81. package/dist/containers/Tenant/Diagnostics/Partitions/columns/columns.js.map +1 -1
  82. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/NotFoundContainer.d.ts +5 -0
  83. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/NotFoundContainer.js +10 -0
  84. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/NotFoundContainer.js.map +1 -0
  85. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetails.d.ts +9 -0
  86. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetails.js +13 -0
  87. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetails.js.map +1 -0
  88. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetails.scss +43 -0
  89. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetailsDrawerContent.d.ts +7 -0
  90. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetailsDrawerContent.js +35 -0
  91. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetailsDrawerContent.js.map +1 -0
  92. package/dist/containers/Tenant/Diagnostics/TopQueries/RunningQueriesData.d.ts +1 -2
  93. package/dist/containers/Tenant/Diagnostics/TopQueries/RunningQueriesData.js +28 -7
  94. package/dist/containers/Tenant/Diagnostics/TopQueries/RunningQueriesData.js.map +1 -1
  95. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueries.js +5 -25
  96. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueries.js.map +1 -1
  97. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueries.scss +29 -0
  98. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.d.ts +1 -2
  99. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.js +37 -8
  100. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.js.map +1 -1
  101. package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useSetSelectedTopQueryRowFromParams.d.ts +8 -0
  102. package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useSetSelectedTopQueryRowFromParams.js +33 -0
  103. package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useSetSelectedTopQueryRowFromParams.js.map +1 -0
  104. package/dist/containers/Tenant/Diagnostics/TopQueries/i18n/en.json +7 -1
  105. package/dist/containers/Tenant/Diagnostics/TopQueries/i18n/index.d.ts +1 -1
  106. package/dist/containers/Tenant/Diagnostics/TopQueries/utils/generateShareableUrl.d.ts +7 -0
  107. package/dist/containers/Tenant/Diagnostics/TopQueries/utils/generateShareableUrl.js +20 -0
  108. package/dist/containers/Tenant/Diagnostics/TopQueries/utils/generateShareableUrl.js.map +1 -0
  109. package/dist/containers/Tenant/Diagnostics/TopQueries/utils/getTopQueryRowQueryParams.d.ts +8 -0
  110. package/dist/containers/Tenant/Diagnostics/TopQueries/utils/getTopQueryRowQueryParams.js +16 -0
  111. package/dist/containers/Tenant/Diagnostics/TopQueries/utils/getTopQueryRowQueryParams.js.map +1 -0
  112. package/dist/containers/Tenant/Diagnostics/TopQueries/utils.d.ts +3 -0
  113. package/dist/containers/Tenant/Diagnostics/TopQueries/utils.js +69 -0
  114. package/dist/containers/Tenant/Diagnostics/TopQueries/utils.js.map +1 -1
  115. package/dist/containers/Tenant/Diagnostics/TopicData/TopicData.js +67 -24
  116. package/dist/containers/Tenant/Diagnostics/TopicData/TopicData.js.map +1 -1
  117. package/dist/containers/Tenant/Diagnostics/TopicData/TopicData.scss +8 -2
  118. package/dist/containers/Tenant/Diagnostics/TopicData/TopicDataControls/TopicDataControls.d.ts +2 -1
  119. package/dist/containers/Tenant/Diagnostics/TopicData/TopicDataControls/TopicDataControls.js +15 -7
  120. package/dist/containers/Tenant/Diagnostics/TopicData/TopicDataControls/TopicDataControls.js.map +1 -1
  121. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/TopicMessageDetails.d.ts +7 -0
  122. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/TopicMessageDetails.js +82 -0
  123. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/TopicMessageDetails.js.map +1 -0
  124. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/TopicMessageDetails.scss +53 -0
  125. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicDataSection.d.ts +8 -0
  126. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicDataSection.js +7 -0
  127. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicDataSection.js.map +1 -0
  128. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessage.d.ts +7 -0
  129. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessage.js +65 -0
  130. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessage.js.map +1 -0
  131. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessageGeneralInfo.d.ts +6 -0
  132. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessageGeneralInfo.js +39 -0
  133. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessageGeneralInfo.js.map +1 -0
  134. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessageMetadata.d.ts +6 -0
  135. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessageMetadata.js +9 -0
  136. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessageMetadata.js.map +1 -0
  137. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/fields.d.ts +10 -0
  138. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/fields.js +67 -0
  139. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/fields.js.map +1 -0
  140. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/shared.d.ts +2 -0
  141. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/shared.js +4 -0
  142. package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/shared.js.map +1 -0
  143. package/dist/containers/Tenant/Diagnostics/TopicData/__test__/getData.test.js +116 -42
  144. package/dist/containers/Tenant/Diagnostics/TopicData/__test__/getData.test.js.map +1 -1
  145. package/dist/containers/Tenant/Diagnostics/TopicData/columns/Columns.scss +25 -4
  146. package/dist/containers/Tenant/Diagnostics/TopicData/columns/columns.d.ts +16 -0
  147. package/dist/containers/Tenant/Diagnostics/TopicData/columns/columns.js +153 -117
  148. package/dist/containers/Tenant/Diagnostics/TopicData/columns/columns.js.map +1 -1
  149. package/dist/containers/Tenant/Diagnostics/TopicData/getData.d.ts +6 -4
  150. package/dist/containers/Tenant/Diagnostics/TopicData/getData.js +30 -15
  151. package/dist/containers/Tenant/Diagnostics/TopicData/getData.js.map +1 -1
  152. package/dist/containers/Tenant/Diagnostics/TopicData/i18n/en.json +10 -2
  153. package/dist/containers/Tenant/Diagnostics/TopicData/i18n/index.d.ts +1 -1
  154. package/dist/containers/Tenant/Diagnostics/TopicData/useTopicDataQueryParams.d.ts +2 -0
  155. package/dist/containers/Tenant/Diagnostics/TopicData/useTopicDataQueryParams.js +7 -1
  156. package/dist/containers/Tenant/Diagnostics/TopicData/useTopicDataQueryParams.js.map +1 -1
  157. package/dist/containers/Tenant/Diagnostics/TopicData/utils/constants.js +3 -0
  158. package/dist/containers/Tenant/Diagnostics/TopicData/utils/constants.js.map +1 -1
  159. package/dist/containers/Tenant/Diagnostics/TopicData/utils/types.d.ts +1 -0
  160. package/dist/containers/Tenant/Diagnostics/TopicData/utils/types.js +1 -0
  161. package/dist/containers/Tenant/Diagnostics/TopicData/utils/types.js.map +1 -1
  162. package/dist/containers/Tenant/ObjectGeneral/ObjectGeneral.d.ts +2 -1
  163. package/dist/containers/Tenant/ObjectGeneral/ObjectGeneral.js +2 -2
  164. package/dist/containers/Tenant/ObjectGeneral/ObjectGeneral.js.map +1 -1
  165. package/dist/containers/Tenant/Query/QueryResult/QueryResultViewer.js +1 -1
  166. package/dist/containers/Tenant/Query/QueryResult/QueryResultViewer.js.map +1 -1
  167. package/dist/containers/Tenant/Tenant.js +1 -1
  168. package/dist/containers/Tenant/Tenant.js.map +1 -1
  169. package/dist/containers/Tenant/TenantPages.d.ts +1 -0
  170. package/dist/containers/Tenant/TenantPages.js.map +1 -1
  171. package/dist/containers/Tenant/utils/schema.d.ts +0 -1
  172. package/dist/containers/Tenant/utils/schema.js +2 -22
  173. package/dist/containers/Tenant/utils/schema.js.map +1 -1
  174. package/dist/containers/Tenants/Tenants.js +1 -1
  175. package/dist/containers/Tenants/Tenants.js.map +1 -1
  176. package/dist/containers/VDiskPage/VDiskPage.js +19 -3
  177. package/dist/containers/VDiskPage/VDiskPage.js.map +1 -1
  178. package/dist/routes.d.ts +9 -1
  179. package/dist/routes.js +2 -2
  180. package/dist/routes.js.map +1 -1
  181. package/dist/services/api/viewer.d.ts +2 -5
  182. package/dist/services/api/viewer.js +2 -1
  183. package/dist/services/api/viewer.js.map +1 -1
  184. package/dist/store/reducers/capabilities/hooks.js +1 -1
  185. package/dist/store/reducers/overview/overview.d.ts +0 -36
  186. package/dist/store/reducers/overview/overview.js +0 -55
  187. package/dist/store/reducers/overview/overview.js.map +1 -1
  188. package/dist/store/reducers/partitions/types.d.ts +1 -1
  189. package/dist/store/reducers/storage/prepareGroupsDisks.js +6 -0
  190. package/dist/store/reducers/storage/prepareGroupsDisks.js.map +1 -1
  191. package/dist/store/reducers/topic.d.ts +1 -1
  192. package/dist/store/reducers/topic.js +1 -1
  193. package/dist/store/reducers/topic.js.map +1 -1
  194. package/dist/store/state-url-mapping.d.ts +1 -0
  195. package/dist/store/state-url-mapping.js +1 -0
  196. package/dist/store/state-url-mapping.js.map +1 -1
  197. package/dist/types/api/operations.d.ts +1 -1
  198. package/dist/types/api/topic.d.ts +1 -0
  199. package/dist/types/store/tablets.d.ts +1 -0
  200. package/dist/uiFactory/types.d.ts +5 -0
  201. package/dist/uiFactory/uiFactory.js +5 -1
  202. package/dist/uiFactory/uiFactory.js.map +1 -1
  203. package/dist/utils/disks/__test__/prepareDisks.test.js +2 -2
  204. package/dist/utils/disks/prepareDisks.js +2 -2
  205. package/dist/utils/downloadFile.d.ts +1 -0
  206. package/dist/utils/downloadFile.js +8 -4
  207. package/dist/utils/downloadFile.js.map +1 -1
  208. package/dist/utils/logs.d.ts +1 -3
  209. package/dist/utils/logs.js +1 -23
  210. package/dist/utils/logs.js.map +1 -1
  211. package/dist/utils/monitoring.d.ts +0 -5
  212. package/dist/utils/utils.d.ts +1 -0
  213. package/dist/utils/utils.js +1 -1
  214. package/dist/utils/utils.js.map +1 -1
  215. package/package.json +1 -1
  216. package/dist/utils/__test__/logs.test.d.ts +0 -1
  217. package/dist/utils/__test__/logs.test.js +0 -36
  218. package/dist/utils/__test__/logs.test.js.map +0 -1
@@ -1,6 +1,8 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import React from 'react';
3
3
  import { TableColumnSetup } from '@gravity-ui/uikit';
4
+ import { isEqual } from 'lodash';
5
+ import { DrawerWrapper } from '../../../../components/Drawer';
4
6
  import { ResponseError } from '../../../../components/Errors/ResponseError';
5
7
  import { ResizeableDataTable } from '../../../../components/ResizeableDataTable/ResizeableDataTable';
6
8
  import { Search } from '../../../../components/Search';
@@ -10,16 +12,20 @@ import { cn } from '../../../../utils/cn';
10
12
  import { useAutoRefreshInterval, useTypedSelector } from '../../../../utils/hooks';
11
13
  import { useSelectedColumns } from '../../../../utils/hooks/useSelectedColumns';
12
14
  import { parseQueryErrorToString } from '../../../../utils/query';
15
+ import { QueryDetailsDrawerContent } from './QueryDetails/QueryDetailsDrawerContent';
13
16
  import { getRunningQueriesColumns } from './columns/columns';
14
17
  import { DEFAULT_RUNNING_QUERIES_COLUMNS, QUERIES_COLUMNS_TITLES, REQUIRED_RUNNING_QUERIES_COLUMNS, RUNNING_QUERIES_COLUMNS_WIDTH_LS_KEY, RUNNING_QUERIES_SELECTED_COLUMNS_LS_KEY, } from './columns/constants';
15
18
  import { useRunningQueriesSort } from './hooks/useRunningQueriesSort';
16
19
  import i18n from './i18n';
17
20
  import { TOP_QUERIES_TABLE_SETTINGS } from './utils';
18
21
  const b = cn('kv-top-queries');
19
- export const RunningQueriesData = ({ tenantName, renderQueryModeControl, onRowClick, handleTextSearchUpdate, }) => {
20
- var _a;
22
+ export const RunningQueriesData = ({ tenantName, renderQueryModeControl, handleTextSearchUpdate, }) => {
23
+ var _a, _b;
21
24
  const [autoRefreshInterval] = useAutoRefreshInterval();
22
25
  const filters = useTypedSelector((state) => state.executeTopQueries);
26
+ // Internal state for selected row
27
+ // null is reserved for not found state
28
+ const [selectedRow, setSelectedRow] = React.useState(undefined);
23
29
  // Get columns for running queries
24
30
  const columns = React.useMemo(() => {
25
31
  return getRunningQueriesColumns();
@@ -27,14 +33,29 @@ export const RunningQueriesData = ({ tenantName, renderQueryModeControl, onRowCl
27
33
  // Use selected columns hook
28
34
  const { columnsToShow, columnsToSelect, setColumns } = useSelectedColumns(columns, RUNNING_QUERIES_SELECTED_COLUMNS_LS_KEY, QUERIES_COLUMNS_TITLES, DEFAULT_RUNNING_QUERIES_COLUMNS, REQUIRED_RUNNING_QUERIES_COLUMNS);
29
35
  const { tableSort, handleTableSort, backendSort } = useRunningQueriesSort();
30
- const { currentData, data, isFetching, isLoading, error } = topQueriesApi.useGetRunningQueriesQuery({
36
+ const { currentData, isFetching, isLoading, error } = topQueriesApi.useGetRunningQueriesQuery({
31
37
  database: tenantName,
32
38
  filters,
33
39
  sortOrder: backendSort,
34
40
  }, { pollingInterval: autoRefreshInterval });
35
- const handleRowClick = (row) => {
36
- return onRowClick(row.QueryText);
37
- };
38
- return (_jsxs(TableWithControlsLayout, { children: [_jsxs(TableWithControlsLayout.Controls, { children: [renderQueryModeControl(), _jsx(Search, { value: filters.text, onChange: handleTextSearchUpdate, placeholder: i18n('filter.text.placeholder'), className: b('search') }), _jsx(TableColumnSetup, { popupWidth: 200, items: columnsToSelect, showStatus: true, onUpdate: setColumns, sortable: false })] }), error ? _jsx(ResponseError, { error: parseQueryErrorToString(error) }) : null, _jsx(TableWithControlsLayout.Table, { loading: isLoading, children: _jsx(ResizeableDataTable, { emptyDataMessage: i18n('no-data'), columnsWidthLSKey: RUNNING_QUERIES_COLUMNS_WIDTH_LS_KEY, columns: columnsToShow, data: ((_a = data === null || data === void 0 ? void 0 : data.resultSets) === null || _a === void 0 ? void 0 : _a[0].result) || [], loading: isFetching && currentData === undefined, settings: TOP_QUERIES_TABLE_SETTINGS, onRowClick: handleRowClick, rowClassName: () => b('row'), sortOrder: tableSort, onSort: handleTableSort }) })] }));
41
+ const rows = (_b = (_a = currentData === null || currentData === void 0 ? void 0 : currentData.resultSets) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.result;
42
+ const isDrawerVisible = selectedRow !== undefined;
43
+ const handleCloseDetails = React.useCallback(() => {
44
+ setSelectedRow(undefined);
45
+ }, [setSelectedRow]);
46
+ const renderDrawerContent = React.useCallback(() => _jsx(QueryDetailsDrawerContent, { row: selectedRow, onClose: handleCloseDetails }), [selectedRow, handleCloseDetails]);
47
+ const onRowClick = React.useCallback((row, _index, event) => {
48
+ event === null || event === void 0 ? void 0 : event.stopPropagation();
49
+ setSelectedRow(row);
50
+ }, [setSelectedRow]);
51
+ const inputRef = React.useRef(null);
52
+ React.useEffect(() => {
53
+ var _a;
54
+ if (isDrawerVisible) {
55
+ (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.blur();
56
+ }
57
+ }, [isDrawerVisible]);
58
+ const drawerControls = React.useMemo(() => [{ type: 'close' }], []);
59
+ return (_jsx(DrawerWrapper, { isDrawerVisible: isDrawerVisible, onCloseDrawer: handleCloseDetails, renderDrawerContent: renderDrawerContent, drawerId: "running-query-details", storageKey: "running-queries-drawer-width", detectClickOutside: true, isPercentageWidth: true, title: i18n('query-details.title'), drawerControls: drawerControls, children: _jsxs(TableWithControlsLayout, { children: [_jsxs(TableWithControlsLayout.Controls, { children: [renderQueryModeControl(), _jsx(Search, { value: filters.text, onChange: handleTextSearchUpdate, placeholder: i18n('filter.text.placeholder'), className: b('search'), inputRef: inputRef }), _jsx(TableColumnSetup, { popupWidth: 200, items: columnsToSelect, showStatus: true, onUpdate: setColumns, sortable: false })] }), error ? _jsx(ResponseError, { error: parseQueryErrorToString(error) }) : null, _jsx(TableWithControlsLayout.Table, { loading: isLoading, children: _jsx(ResizeableDataTable, { emptyDataMessage: i18n('no-data'), columnsWidthLSKey: RUNNING_QUERIES_COLUMNS_WIDTH_LS_KEY, columns: columnsToShow, data: rows || [], loading: isFetching && currentData === undefined, settings: TOP_QUERIES_TABLE_SETTINGS, onRowClick: onRowClick, rowClassName: (row) => b('row', { active: isEqual(row, selectedRow) }), sortOrder: tableSort, onSort: handleTableSort }) })] }) }));
39
60
  };
40
61
  //# sourceMappingURL=RunningQueriesData.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"RunningQueriesData.js","sourceRoot":"","sources":["../../../../../src/containers/Tenant/Diagnostics/TopQueries/RunningQueriesData.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"RunningQueriesData.js","sourceRoot":"","sources":["../../../../../src/containers/Tenant/Diagnostics/TopQueries/RunningQueriesData.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,EAAC,gBAAgB,EAAC,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAC,OAAO,EAAC,MAAM,QAAQ,CAAC;AAE/B,OAAO,EAAC,aAAa,EAAC,MAAM,+BAA+B,CAAC;AAE5D,OAAO,EAAC,aAAa,EAAC,MAAM,6CAA6C,CAAC;AAC1E,OAAO,EAAC,mBAAmB,EAAC,MAAM,gEAAgE,CAAC;AACnG,OAAO,EAAC,MAAM,EAAC,MAAM,+BAA+B,CAAC;AACrD,OAAO,EAAC,uBAAuB,EAAC,MAAM,wEAAwE,CAAC;AAC/G,OAAO,EAAC,aAAa,EAAC,MAAM,gEAAgE,CAAC;AAE7F,OAAO,EAAC,EAAE,EAAC,MAAM,sBAAsB,CAAC;AACxC,OAAO,EAAC,sBAAsB,EAAE,gBAAgB,EAAC,MAAM,yBAAyB,CAAC;AACjF,OAAO,EAAC,kBAAkB,EAAC,MAAM,4CAA4C,CAAC;AAC9E,OAAO,EAAC,uBAAuB,EAAC,MAAM,yBAAyB,CAAC;AAEhE,OAAO,EAAC,yBAAyB,EAAC,MAAM,0CAA0C,CAAC;AACnF,OAAO,EAAC,wBAAwB,EAAC,MAAM,mBAAmB,CAAC;AAC3D,OAAO,EACH,+BAA+B,EAC/B,sBAAsB,EACtB,gCAAgC,EAChC,oCAAoC,EACpC,uCAAuC,GAC1C,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAC,qBAAqB,EAAC,MAAM,+BAA+B,CAAC;AACpE,OAAO,IAAI,MAAM,QAAQ,CAAC;AAC1B,OAAO,EAAC,0BAA0B,EAAC,MAAM,SAAS,CAAC;AAEnD,MAAM,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,CAAC;AAQ/B,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,EAC/B,UAAU,EACV,sBAAsB,EACtB,sBAAsB,GACA,EAAE,EAAE;;IAC1B,MAAM,CAAC,mBAAmB,CAAC,GAAG,sBAAsB,EAAE,CAAC;IACvD,MAAM,OAAO,GAAG,gBAAgB,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;IACrE,kCAAkC;IAClC,uCAAuC;IACvC,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAiC,SAAS,CAAC,CAAC;IAEhG,kCAAkC;IAClC,MAAM,OAAO,GAA0B,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACtD,OAAO,wBAAwB,EAAE,CAAC;IACtC,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,4BAA4B;IAC5B,MAAM,EAAC,aAAa,EAAE,eAAe,EAAE,UAAU,EAAC,GAAG,kBAAkB,CACnE,OAAO,EACP,uCAAuC,EACvC,sBAAsB,EACtB,+BAA+B,EAC/B,gCAAgC,CACnC,CAAC;IAEF,MAAM,EAAC,SAAS,EAAE,eAAe,EAAE,WAAW,EAAC,GAAG,qBAAqB,EAAE,CAAC;IAE1E,MAAM,EAAC,WAAW,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAC,GAAG,aAAa,CAAC,yBAAyB,CACvF;QACI,QAAQ,EAAE,UAAU;QACpB,OAAO;QACP,SAAS,EAAE,WAAW;KACzB,EACD,EAAC,eAAe,EAAE,mBAAmB,EAAC,CACzC,CAAC;IAEF,MAAM,IAAI,GAAG,MAAA,MAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,UAAU,0CAAG,CAAC,CAAC,0CAAE,MAAM,CAAC;IAElD,MAAM,eAAe,GAAG,WAAW,KAAK,SAAS,CAAC;IAElD,MAAM,kBAAkB,GAAG,KAAK,CAAC,WAAW,CAAC,GAAG,EAAE;QAC9C,cAAc,CAAC,SAAS,CAAC,CAAC;IAC9B,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC;IAErB,MAAM,mBAAmB,GAAG,KAAK,CAAC,WAAW,CACzC,GAAG,EAAE,CAAC,KAAC,yBAAyB,IAAC,GAAG,EAAE,WAAW,EAAE,OAAO,EAAE,kBAAkB,GAAI,EAClF,CAAC,WAAW,EAAE,kBAAkB,CAAC,CACpC,CAAC;IAEF,MAAM,UAAU,GAAG,KAAK,CAAC,WAAW,CAChC,CACI,GAAuB,EACvB,MAAe,EACf,KAA6C,EAC/C,EAAE;QACA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,eAAe,EAAE,CAAC;QACzB,cAAc,CAAC,GAAG,CAAC,CAAC;IACxB,CAAC,EACD,CAAC,cAAc,CAAC,CACnB,CAAC;IAEF,MAAM,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAmB,IAAI,CAAC,CAAC;IAEtD,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;;QACjB,IAAI,eAAe,EAAE,CAAC;YAClB,MAAA,QAAQ,CAAC,OAAO,0CAAE,IAAI,EAAE,CAAC;QAC7B,CAAC;IACL,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC,CAAC;IAEtB,MAAM,cAAc,GAAoB,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,EAAC,IAAI,EAAE,OAAO,EAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAEnF,OAAO,CACH,KAAC,aAAa,IACV,eAAe,EAAE,eAAe,EAChC,aAAa,EAAE,kBAAkB,EACjC,mBAAmB,EAAE,mBAAmB,EACxC,QAAQ,EAAC,uBAAuB,EAChC,UAAU,EAAC,8BAA8B,EACzC,kBAAkB,QAClB,iBAAiB,QACjB,KAAK,EAAE,IAAI,CAAC,qBAAqB,CAAC,EAClC,cAAc,EAAE,cAAc,YAE9B,MAAC,uBAAuB,eACpB,MAAC,uBAAuB,CAAC,QAAQ,eAC5B,sBAAsB,EAAE,EACzB,KAAC,MAAM,IACH,KAAK,EAAE,OAAO,CAAC,IAAI,EACnB,QAAQ,EAAE,sBAAsB,EAChC,WAAW,EAAE,IAAI,CAAC,yBAAyB,CAAC,EAC5C,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,EACtB,QAAQ,EAAE,QAAQ,GACpB,EACF,KAAC,gBAAgB,IACb,UAAU,EAAE,GAAG,EACf,KAAK,EAAE,eAAe,EACtB,UAAU,QACV,QAAQ,EAAE,UAAU,EACpB,QAAQ,EAAE,KAAK,GACjB,IAC6B,EAElC,KAAK,CAAC,CAAC,CAAC,KAAC,aAAa,IAAC,KAAK,EAAE,uBAAuB,CAAC,KAAK,CAAC,GAAI,CAAC,CAAC,CAAC,IAAI,EACxE,KAAC,uBAAuB,CAAC,KAAK,IAAC,OAAO,EAAE,SAAS,YAC7C,KAAC,mBAAmB,IAChB,gBAAgB,EAAE,IAAI,CAAC,SAAS,CAAC,EACjC,iBAAiB,EAAE,oCAAoC,EACvD,OAAO,EAAE,aAAa,EACtB,IAAI,EAAE,IAAI,IAAI,EAAE,EAChB,OAAO,EAAE,UAAU,IAAI,WAAW,KAAK,SAAS,EAChD,QAAQ,EAAE,0BAA0B,EACpC,UAAU,EAAE,UAAU,EACtB,YAAY,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,EAAE,EAAC,MAAM,EAAE,OAAO,CAAC,GAAG,EAAE,WAAW,CAAC,EAAC,CAAC,EACpE,SAAS,EAAE,SAAS,EACpB,MAAM,EAAE,eAAe,GACzB,GAC0B,IACV,GACd,CACnB,CAAC;AACN,CAAC,CAAC"}
@@ -1,16 +1,10 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
2
  import React from 'react';
3
3
  import { RadioButton } from '@gravity-ui/uikit';
4
- import { useHistory, useLocation } from 'react-router-dom';
5
4
  import { StringParam, useQueryParam } from 'use-query-params';
6
5
  import { z } from 'zod';
7
- import { parseQuery } from '../../../../routes';
8
6
  import { setTopQueriesFilters } from '../../../../store/reducers/executeTopQueries/executeTopQueries';
9
- import { changeUserInput, setIsDirty } from '../../../../store/reducers/query/query';
10
- import { TENANT_PAGE, TENANT_PAGES_IDS, TENANT_QUERY_TABS_ID, } from '../../../../store/reducers/tenant/constants';
11
7
  import { useTypedDispatch } from '../../../../utils/hooks';
12
- import { useChangeInputWithConfirmation } from '../../../../utils/hooks/withConfirmation/useChangeInputWithConfirmation';
13
- import { TenantTabsGroups, getTenantPath } from '../../TenantPages';
14
8
  import { RunningQueriesData } from './RunningQueriesData';
15
9
  import { TopQueriesData } from './TopQueriesData';
16
10
  import { TimeFrameIds } from './constants';
@@ -38,25 +32,11 @@ const queryModeSchema = z.nativeEnum(QueryModeIds).catch(QueryModeIds.top);
38
32
  const timeFrameSchema = z.nativeEnum(TimeFrameIds).catch(TimeFrameIds.hour);
39
33
  export const TopQueries = ({ tenantName }) => {
40
34
  const dispatch = useTypedDispatch();
41
- const location = useLocation();
42
- const history = useHistory();
43
- const [_queryMode = QueryModeIds.top, setQueryMode] = useQueryParam('queryMode', StringParam);
44
- const [_timeFrame = TimeFrameIds.hour, setTimeFrame] = useQueryParam('timeFrame', StringParam);
45
- const queryMode = queryModeSchema.parse(_queryMode);
46
- const timeFrame = timeFrameSchema.parse(_timeFrame);
35
+ const [rawQueryMode = QueryModeIds.top, setQueryMode] = useQueryParam('queryMode', StringParam);
36
+ const [rawTimeFrame = TimeFrameIds.hour, setTimeFrame] = useQueryParam('timeFrame', StringParam);
37
+ const queryMode = queryModeSchema.parse(rawQueryMode);
38
+ const timeFrame = timeFrameSchema.parse(rawTimeFrame);
47
39
  const isTopQueries = queryMode === QueryModeIds.top;
48
- const applyRowClick = React.useCallback((input) => {
49
- dispatch(changeUserInput({ input }));
50
- dispatch(setIsDirty(false));
51
- const queryParams = parseQuery(location);
52
- const queryPath = getTenantPath({
53
- ...queryParams,
54
- [TENANT_PAGE]: TENANT_PAGES_IDS.query,
55
- [TenantTabsGroups.queryTab]: TENANT_QUERY_TABS_ID.newQuery,
56
- });
57
- history.push(queryPath);
58
- }, [dispatch, history, location]);
59
- const onRowClick = useChangeInputWithConfirmation(applyRowClick);
60
40
  const handleTextSearchUpdate = (text) => {
61
41
  dispatch(setTopQueriesFilters({ text }));
62
42
  };
@@ -69,6 +49,6 @@ export const TopQueries = ({ tenantName }) => {
69
49
  const renderQueryModeControl = React.useCallback(() => {
70
50
  return (_jsx(RadioButton, { options: QUERY_MODE_OPTIONS, value: queryMode, onUpdate: setQueryMode }));
71
51
  }, [queryMode, setQueryMode]);
72
- return isTopQueries ? (_jsx(TopQueriesData, { tenantName: tenantName, timeFrame: timeFrame, renderQueryModeControl: renderQueryModeControl, onRowClick: onRowClick, handleTimeFrameChange: handleTimeFrameChange, handleDateRangeChange: handleDateRangeChange, handleTextSearchUpdate: handleTextSearchUpdate })) : (_jsx(RunningQueriesData, { tenantName: tenantName, renderQueryModeControl: renderQueryModeControl, onRowClick: onRowClick, handleTextSearchUpdate: handleTextSearchUpdate }));
52
+ return isTopQueries ? (_jsx(TopQueriesData, { tenantName: tenantName, timeFrame: timeFrame, renderQueryModeControl: renderQueryModeControl, handleTimeFrameChange: handleTimeFrameChange, handleDateRangeChange: handleDateRangeChange, handleTextSearchUpdate: handleTextSearchUpdate })) : (_jsx(RunningQueriesData, { tenantName: tenantName, renderQueryModeControl: renderQueryModeControl, handleTextSearchUpdate: handleTextSearchUpdate }));
73
53
  };
74
54
  //# sourceMappingURL=TopQueries.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TopQueries.js","sourceRoot":"","sources":["../../../../../src/containers/Tenant/Diagnostics/TopQueries/TopQueries.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"TopQueries.js","sourceRoot":"","sources":["../../../../../src/containers/Tenant/Diagnostics/TopQueries/TopQueries.tsx"],"names":[],"mappings":"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"}
@@ -14,6 +14,14 @@
14
14
 
15
15
  &__row {
16
16
  cursor: pointer;
17
+
18
+ &_active {
19
+ background-color: var(--g-color-base-selection);
20
+
21
+ &:hover {
22
+ background: var(--g-color-base-selection-hover) !important;
23
+ }
24
+ }
17
25
  }
18
26
 
19
27
  &__query {
@@ -32,4 +40,25 @@
32
40
 
33
41
  text-overflow: ellipsis;
34
42
  }
43
+
44
+ &__drawer {
45
+ margin-top: calc(-1 * var(--g-spacing-4));
46
+ }
47
+
48
+ &__empty-state-icon {
49
+ color: var(--g-color-text-primary);
50
+ }
51
+
52
+ &__not-found-container {
53
+ height: 100%;
54
+ padding: var(--g-spacing-5) 0;
55
+ }
56
+
57
+ &__not-found-description {
58
+ margin-top: var(--g-spacing-2);
59
+ }
60
+
61
+ &__not-found-close {
62
+ margin-top: var(--g-spacing-5);
63
+ }
35
64
  }
@@ -5,10 +5,9 @@ interface TopQueriesDataProps {
5
5
  tenantName: string;
6
6
  timeFrame: TimeFrame;
7
7
  renderQueryModeControl: () => React.ReactNode;
8
- onRowClick: (query: string) => void;
9
8
  handleTimeFrameChange: (value: string[]) => void;
10
9
  handleDateRangeChange: (value: DateRangeValues) => void;
11
10
  handleTextSearchUpdate: (text: string) => void;
12
11
  }
13
- export declare const TopQueriesData: ({ tenantName, timeFrame, renderQueryModeControl, onRowClick, handleTimeFrameChange, handleDateRangeChange, handleTextSearchUpdate, }: TopQueriesDataProps) => import("react/jsx-runtime").JSX.Element;
12
+ export declare const TopQueriesData: ({ tenantName, timeFrame, renderQueryModeControl, handleTimeFrameChange, handleDateRangeChange, handleTextSearchUpdate, }: TopQueriesDataProps) => import("react/jsx-runtime").JSX.Element;
14
13
  export {};
@@ -1,7 +1,9 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import React from 'react';
3
3
  import { Select, TableColumnSetup } from '@gravity-ui/uikit';
4
+ import { isEqual } from 'lodash';
4
5
  import { DateRange } from '../../../../components/DateRange';
6
+ import { DrawerWrapper } from '../../../../components/Drawer';
5
7
  import { ResponseError } from '../../../../components/Errors/ResponseError';
6
8
  import { ResizeableDataTable } from '../../../../components/ResizeableDataTable/ResizeableDataTable';
7
9
  import { Search } from '../../../../components/Search';
@@ -11,34 +13,61 @@ import { cn } from '../../../../utils/cn';
11
13
  import { useAutoRefreshInterval, useTypedSelector } from '../../../../utils/hooks';
12
14
  import { useSelectedColumns } from '../../../../utils/hooks/useSelectedColumns';
13
15
  import { parseQueryErrorToString } from '../../../../utils/query';
16
+ import { QueryDetailsDrawerContent } from './QueryDetails/QueryDetailsDrawerContent';
14
17
  import { getTopQueriesColumns } from './columns/columns';
15
18
  import { DEFAULT_TOP_QUERIES_COLUMNS, QUERIES_COLUMNS_TITLES, REQUIRED_TOP_QUERIES_COLUMNS, TOP_QUERIES_COLUMNS_WIDTH_LS_KEY, TOP_QUERIES_SELECTED_COLUMNS_LS_KEY, } from './columns/constants';
16
19
  import { DEFAULT_TIME_FILTER_VALUE, TIME_FRAME_OPTIONS } from './constants';
20
+ import { useSetSelectedTopQueryRowFromParams } from './hooks/useSetSelectedTopQueryRowFromParams';
17
21
  import { useTopQueriesSort } from './hooks/useTopQueriesSort';
18
22
  import i18n from './i18n';
19
23
  import { TOP_QUERIES_TABLE_SETTINGS } from './utils';
24
+ import { generateShareableUrl } from './utils/generateShareableUrl';
20
25
  const b = cn('kv-top-queries');
21
- export const TopQueriesData = ({ tenantName, timeFrame, renderQueryModeControl, onRowClick, handleTimeFrameChange, handleDateRangeChange, handleTextSearchUpdate, }) => {
22
- var _a;
26
+ export const TopQueriesData = ({ tenantName, timeFrame, renderQueryModeControl, handleTimeFrameChange, handleDateRangeChange, handleTextSearchUpdate, }) => {
27
+ var _a, _b;
23
28
  const [autoRefreshInterval] = useAutoRefreshInterval();
24
29
  const filters = useTypedSelector((state) => state.executeTopQueries);
30
+ // Internal state for selected row
31
+ // null is reserved for not found state
32
+ const [selectedRow, setSelectedRow] = React.useState(undefined);
25
33
  // Get columns for top queries
26
34
  const columns = React.useMemo(() => {
27
35
  return getTopQueriesColumns();
28
36
  }, []);
29
37
  // Use selected columns hook
30
38
  const { columnsToShow, columnsToSelect, setColumns } = useSelectedColumns(columns, TOP_QUERIES_SELECTED_COLUMNS_LS_KEY, QUERIES_COLUMNS_TITLES, DEFAULT_TOP_QUERIES_COLUMNS, REQUIRED_TOP_QUERIES_COLUMNS);
31
- // Use the sort params from URL in the hook
32
39
  const { tableSort, handleTableSort, backendSort } = useTopQueriesSort();
33
- const { currentData, data, isFetching, isLoading, error } = topQueriesApi.useGetTopQueriesQuery({
40
+ const { currentData, isFetching, isLoading, error } = topQueriesApi.useGetTopQueriesQuery({
34
41
  database: tenantName,
35
42
  filters,
36
43
  sortOrder: backendSort,
37
44
  timeFrame,
38
45
  }, { pollingInterval: autoRefreshInterval });
39
- const handleRowClick = (row) => {
40
- return onRowClick(row.QueryText);
41
- };
42
- return (_jsxs(TableWithControlsLayout, { children: [_jsxs(TableWithControlsLayout.Controls, { children: [renderQueryModeControl(), _jsx(Select, { options: TIME_FRAME_OPTIONS, value: [timeFrame], onUpdate: handleTimeFrameChange }), _jsx(DateRange, { from: filters.from, to: filters.to, onChange: handleDateRangeChange, defaultValue: DEFAULT_TIME_FILTER_VALUE }), _jsx(Search, { value: filters.text, onChange: handleTextSearchUpdate, placeholder: i18n('filter.text.placeholder'), className: b('search') }), _jsx(TableColumnSetup, { popupWidth: 200, items: columnsToSelect, showStatus: true, onUpdate: setColumns, sortable: false })] }), error ? _jsx(ResponseError, { error: parseQueryErrorToString(error) }) : null, _jsx(TableWithControlsLayout.Table, { loading: isLoading, children: _jsx(ResizeableDataTable, { emptyDataMessage: i18n('no-data'), columnsWidthLSKey: TOP_QUERIES_COLUMNS_WIDTH_LS_KEY, columns: columnsToShow, data: ((_a = data === null || data === void 0 ? void 0 : data.resultSets) === null || _a === void 0 ? void 0 : _a[0].result) || [], loading: isFetching && currentData === undefined, settings: TOP_QUERIES_TABLE_SETTINGS, onRowClick: handleRowClick, rowClassName: () => b('row'), sortOrder: tableSort, onSort: handleTableSort }) })] }));
46
+ const rows = (_b = (_a = currentData === null || currentData === void 0 ? void 0 : currentData.resultSets) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.result;
47
+ useSetSelectedTopQueryRowFromParams(setSelectedRow, rows);
48
+ const handleCloseDetails = React.useCallback(() => {
49
+ setSelectedRow(undefined);
50
+ }, [setSelectedRow]);
51
+ const isDrawerVisible = selectedRow !== undefined;
52
+ const getTopQueryUrl = React.useCallback(() => {
53
+ if (selectedRow) {
54
+ return generateShareableUrl(selectedRow);
55
+ }
56
+ return '';
57
+ }, [selectedRow]);
58
+ const renderDrawerContent = React.useCallback(() => _jsx(QueryDetailsDrawerContent, { row: selectedRow, onClose: handleCloseDetails }), [selectedRow, handleCloseDetails]);
59
+ const onRowClick = React.useCallback((row, _index, event) => {
60
+ event === null || event === void 0 ? void 0 : event.stopPropagation();
61
+ setSelectedRow(row);
62
+ }, [setSelectedRow]);
63
+ const inputRef = React.useRef(null);
64
+ React.useEffect(() => {
65
+ var _a;
66
+ if (isDrawerVisible) {
67
+ (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.blur();
68
+ }
69
+ }, [isDrawerVisible]);
70
+ const drawerControls = React.useMemo(() => [{ type: 'copyLink', link: getTopQueryUrl() }, { type: 'close' }], [getTopQueryUrl]);
71
+ return (_jsx(DrawerWrapper, { isDrawerVisible: isDrawerVisible, onCloseDrawer: handleCloseDetails, renderDrawerContent: renderDrawerContent, drawerId: "query-details", storageKey: "kv-top-queries-drawer-width", detectClickOutside: true, isPercentageWidth: true, title: i18n('query-details.title'), drawerControls: drawerControls, children: _jsxs(TableWithControlsLayout, { children: [_jsxs(TableWithControlsLayout.Controls, { children: [renderQueryModeControl(), _jsx(Select, { options: TIME_FRAME_OPTIONS, value: [timeFrame], onUpdate: handleTimeFrameChange }), _jsx(DateRange, { from: filters.from, to: filters.to, onChange: handleDateRangeChange, defaultValue: DEFAULT_TIME_FILTER_VALUE }), _jsx(Search, { value: filters.text, inputRef: inputRef, onChange: handleTextSearchUpdate, placeholder: i18n('filter.text.placeholder'), className: b('search') }), _jsx(TableColumnSetup, { popupWidth: 200, items: columnsToSelect, showStatus: true, onUpdate: setColumns, sortable: false })] }), error ? _jsx(ResponseError, { error: parseQueryErrorToString(error) }) : null, _jsx(TableWithControlsLayout.Table, { loading: isLoading, children: _jsx(ResizeableDataTable, { emptyDataMessage: i18n('no-data'), columnsWidthLSKey: TOP_QUERIES_COLUMNS_WIDTH_LS_KEY, columns: columnsToShow, data: rows || [], loading: isFetching && currentData === undefined, settings: TOP_QUERIES_TABLE_SETTINGS, onRowClick: onRowClick, rowClassName: (row) => b('row', { active: isEqual(row, selectedRow) }), sortOrder: tableSort, onSort: handleTableSort }) })] }) }));
43
72
  };
44
73
  //# sourceMappingURL=TopQueriesData.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TopQueriesData.js","sourceRoot":"","sources":["../../../../../src/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"TopQueriesData.js","sourceRoot":"","sources":["../../../../../src/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type { KeyValueRow } from '../../../../../types/api/query';
2
+ export interface SearchParamsQueryParams {
3
+ rank?: string;
4
+ intervalEnd?: string;
5
+ endTime?: string;
6
+ queryHash?: string;
7
+ }
8
+ export declare function useSetSelectedTopQueryRowFromParams(setSelectedRow: (row: KeyValueRow | null) => void, rows?: KeyValueRow[] | null): null;
@@ -0,0 +1,33 @@
1
+ import React from 'react';
2
+ import { StringParam, useQueryParams } from 'use-query-params';
3
+ import { getTopQueryRowQueryParams } from '../utils/getTopQueryRowQueryParams';
4
+ export function useSetSelectedTopQueryRowFromParams(setSelectedRow, rows) {
5
+ const [queryParams, setQueryParams] = useQueryParams({
6
+ selectedRow: StringParam,
7
+ });
8
+ // Handle initialization from URL params
9
+ React.useEffect(() => {
10
+ if (rows && queryParams.selectedRow) {
11
+ const searchParamsQuery = JSON.parse(decodeURIComponent(queryParams.selectedRow));
12
+ const matchedRow = rows.find((row) => {
13
+ const params = getTopQueryRowQueryParams(row);
14
+ return (params.rank === searchParamsQuery.rank &&
15
+ params.intervalEnd === searchParamsQuery.intervalEnd &&
16
+ params.endTime === searchParamsQuery.endTime &&
17
+ searchParamsQuery.queryHash === params.queryHash);
18
+ });
19
+ if (matchedRow) {
20
+ setSelectedRow(matchedRow);
21
+ }
22
+ else {
23
+ // If we had a selectedRow in URL but couldn't find a matching row,
24
+ // explicitly set selectedRow to null to indicate empty state
25
+ setSelectedRow(null);
26
+ }
27
+ // Clear URL params after using them
28
+ setQueryParams({ selectedRow: undefined });
29
+ }
30
+ }, [queryParams.selectedRow, setQueryParams, rows, setSelectedRow]);
31
+ return null;
32
+ }
33
+ //# sourceMappingURL=useSetSelectedTopQueryRowFromParams.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useSetSelectedTopQueryRowFromParams.js","sourceRoot":"","sources":["../../../../../../src/containers/Tenant/Diagnostics/TopQueries/hooks/useSetSelectedTopQueryRowFromParams.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAC,WAAW,EAAE,cAAc,EAAC,MAAM,kBAAkB,CAAC;AAG7D,OAAO,EAAC,yBAAyB,EAAC,MAAM,oCAAoC,CAAC;AAS7E,MAAM,UAAU,mCAAmC,CAC/C,cAAiD,EACjD,IAA2B;IAE3B,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,cAAc,CAAC;QACjD,WAAW,EAAE,WAAW;KAC3B,CAAC,CAAC;IAEH,wCAAwC;IACxC,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACjB,IAAI,IAAI,IAAI,WAAW,CAAC,WAAW,EAAE,CAAC;YAClC,MAAM,iBAAiB,GAA4B,IAAI,CAAC,KAAK,CACzD,kBAAkB,CAAC,WAAW,CAAC,WAAW,CAAC,CAC9C,CAAC;YACF,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE;gBACjC,MAAM,MAAM,GAAG,yBAAyB,CAAC,GAAG,CAAC,CAAC;gBAC9C,OAAO,CACH,MAAM,CAAC,IAAI,KAAK,iBAAiB,CAAC,IAAI;oBACtC,MAAM,CAAC,WAAW,KAAK,iBAAiB,CAAC,WAAW;oBACpD,MAAM,CAAC,OAAO,KAAK,iBAAiB,CAAC,OAAO;oBAC5C,iBAAiB,CAAC,SAAS,KAAK,MAAM,CAAC,SAAS,CACnD,CAAC;YACN,CAAC,CAAC,CAAC;YAEH,IAAI,UAAU,EAAE,CAAC;gBACb,cAAc,CAAC,UAAU,CAAC,CAAC;YAC/B,CAAC;iBAAM,CAAC;gBACJ,mEAAmE;gBACnE,6DAA6D;gBAC7D,cAAc,CAAC,IAAI,CAAC,CAAC;YACzB,CAAC;YAED,oCAAoC;YACpC,cAAc,CAAC,EAAC,WAAW,EAAE,SAAS,EAAC,CAAC,CAAC;QAC7C,CAAC;IACL,CAAC,EAAE,CAAC,WAAW,CAAC,WAAW,EAAE,cAAc,EAAE,IAAI,EAAE,cAAc,CAAC,CAAC,CAAC;IAEpE,OAAO,IAAI,CAAC;AAChB,CAAC"}
@@ -4,5 +4,11 @@
4
4
  "mode_top": "Top",
5
5
  "mode_running": "Running",
6
6
  "timeframe_hour": "Per hour",
7
- "timeframe_minute": "Per minute"
7
+ "timeframe_minute": "Per minute",
8
+ "query-details.title": "Query",
9
+ "query-details.open-in-editor": "Open in Editor",
10
+ "query-details.close": "Close",
11
+ "query-details.query.title": "Query Text",
12
+ "query-details.not-found.title": "Not found",
13
+ "query-details.not-found.description": "This query no longer exists"
8
14
  }
@@ -1,2 +1,2 @@
1
- declare const _default: (key: "no-data" | "filter.text.placeholder" | "mode_top" | "mode_running" | "timeframe_hour" | "timeframe_minute", params?: import("@gravity-ui/i18n").Params) => string;
1
+ declare const _default: (key: "no-data" | "filter.text.placeholder" | "mode_top" | "mode_running" | "timeframe_hour" | "timeframe_minute" | "query-details.title" | "query-details.open-in-editor" | "query-details.close" | "query-details.query.title" | "query-details.not-found.title" | "query-details.not-found.description", params?: import("@gravity-ui/i18n").Params) => string;
2
2
  export default _default;
@@ -0,0 +1,7 @@
1
+ import type { KeyValueRow } from '../../../../../types/api/query';
2
+ /**
3
+ * Generates a shareable URL with query parameters for a top query row
4
+ * @param row The top query row data
5
+ * @returns A shareable URL string with the row's parameters encoded in the URL
6
+ */
7
+ export declare function generateShareableUrl(row: KeyValueRow): string;
@@ -0,0 +1,20 @@
1
+ import { getTopQueryRowQueryParams } from './getTopQueryRowQueryParams';
2
+ /**
3
+ * Generates a shareable URL with query parameters for a top query row
4
+ * @param row The top query row data
5
+ * @returns A shareable URL string with the row's parameters encoded in the URL
6
+ */
7
+ export function generateShareableUrl(row) {
8
+ const params = getTopQueryRowQueryParams(row);
9
+ const url = new URL(window.location.href);
10
+ const searchParams = new URLSearchParams(url.search);
11
+ searchParams.set('selectedRow', encodeURIComponent(JSON.stringify({
12
+ rank: params.rank || undefined,
13
+ intervalEnd: params.intervalEnd || undefined,
14
+ endTime: params.endTime || undefined,
15
+ queryHash: params.queryHash || undefined,
16
+ })));
17
+ url.search = searchParams.toString();
18
+ return url.toString();
19
+ }
20
+ //# sourceMappingURL=generateShareableUrl.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generateShareableUrl.js","sourceRoot":"","sources":["../../../../../../src/containers/Tenant/Diagnostics/TopQueries/utils/generateShareableUrl.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,yBAAyB,EAAC,MAAM,6BAA6B,CAAC;AAEtE;;;;GAIG;AACH,MAAM,UAAU,oBAAoB,CAAC,GAAgB;IACjD,MAAM,MAAM,GAAG,yBAAyB,CAAC,GAAG,CAAC,CAAC;IAE9C,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAE1C,MAAM,YAAY,GAAG,IAAI,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAErD,YAAY,CAAC,GAAG,CACZ,aAAa,EACb,kBAAkB,CACd,IAAI,CAAC,SAAS,CAAC;QACX,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,SAAS;QAC9B,WAAW,EAAE,MAAM,CAAC,WAAW,IAAI,SAAS;QAC5C,OAAO,EAAE,MAAM,CAAC,OAAO,IAAI,SAAS;QACpC,SAAS,EAAE,MAAM,CAAC,SAAS,IAAI,SAAS;KAC3C,CAAC,CACL,CACJ,CAAC;IAEF,GAAG,CAAC,MAAM,GAAG,YAAY,CAAC,QAAQ,EAAE,CAAC;IAErC,OAAO,GAAG,CAAC,QAAQ,EAAE,CAAC;AAC1B,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { KeyValueRow } from '../../../../../types/api/query';
2
+ import type { SearchParamsQueryParams } from '../hooks/useSetSelectedTopQueryRowFromParams';
3
+ /**
4
+ * Extract query parameters from a row for use in URL search params
5
+ * @param row The top query row data
6
+ * @returns Parameters for URL search params
7
+ */
8
+ export declare function getTopQueryRowQueryParams(row: KeyValueRow): SearchParamsQueryParams;
@@ -0,0 +1,16 @@
1
+ import { generateHash } from '../../../../../utils/generateHash';
2
+ /**
3
+ * Extract query parameters from a row for use in URL search params
4
+ * @param row The top query row data
5
+ * @returns Parameters for URL search params
6
+ */
7
+ export function getTopQueryRowQueryParams(row) {
8
+ const queryHash = generateHash(String(row.QueryText));
9
+ return {
10
+ rank: String(row.Rank),
11
+ intervalEnd: String(row.IntervalEnd),
12
+ endTime: String(row.EndTime),
13
+ queryHash,
14
+ };
15
+ }
16
+ //# sourceMappingURL=getTopQueryRowQueryParams.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getTopQueryRowQueryParams.js","sourceRoot":"","sources":["../../../../../../src/containers/Tenant/Diagnostics/TopQueries/utils/getTopQueryRowQueryParams.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,YAAY,EAAC,MAAM,mCAAmC,CAAC;AAG/D;;;;GAIG;AACH,MAAM,UAAU,yBAAyB,CAAC,GAAgB;IACtD,MAAM,SAAS,GAAG,YAAY,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;IAEtD,OAAO;QACH,IAAI,EAAE,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC;QACtB,WAAW,EAAE,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC;QACpC,OAAO,EAAE,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC;QAC5B,SAAS;KACZ,CAAC;AACN,CAAC"}
@@ -1,2 +1,5 @@
1
1
  import type { Settings } from '@gravity-ui/react-data-table';
2
+ import type { InfoViewerItem } from '../../../../components/InfoViewer';
3
+ import type { KeyValueRow } from '../../../../types/api/query';
2
4
  export declare const TOP_QUERIES_TABLE_SETTINGS: Settings;
5
+ export declare function createQueryInfoItems(data: KeyValueRow): InfoViewerItem[];
@@ -1,7 +1,76 @@
1
+ import { formatDateTime, formatNumber } from '../../../../utils/dataFormatters/dataFormatters';
2
+ import { generateHash } from '../../../../utils/generateHash';
3
+ import { formatToMs, parseUsToMs } from '../../../../utils/timeParsers';
1
4
  import { QUERY_TABLE_SETTINGS } from '../../utils/constants';
5
+ import columnsI18n from './columns/i18n';
2
6
  export const TOP_QUERIES_TABLE_SETTINGS = {
3
7
  ...QUERY_TABLE_SETTINGS,
4
8
  disableSortReset: true,
5
9
  externalSort: true,
6
10
  };
11
+ export function createQueryInfoItems(data) {
12
+ var _a, _b;
13
+ const items = [];
14
+ if (data.QueryText) {
15
+ items.push({
16
+ label: columnsI18n('query-hash'),
17
+ value: generateHash(String(data.QueryText)),
18
+ });
19
+ }
20
+ if (data.CPUTimeUs !== undefined) {
21
+ items.push({
22
+ label: columnsI18n('cpu-time'),
23
+ value: formatToMs(parseUsToMs((_a = data.CPUTimeUs) !== null && _a !== void 0 ? _a : undefined)),
24
+ });
25
+ }
26
+ if (data.Duration !== undefined) {
27
+ items.push({
28
+ label: columnsI18n('duration'),
29
+ value: formatToMs(parseUsToMs((_b = data.Duration) !== null && _b !== void 0 ? _b : undefined)),
30
+ });
31
+ }
32
+ if (data.ReadBytes !== undefined) {
33
+ items.push({
34
+ label: columnsI18n('read-bytes'),
35
+ value: formatNumber(data.ReadBytes),
36
+ });
37
+ }
38
+ if (data.RequestUnits !== undefined) {
39
+ items.push({
40
+ label: columnsI18n('request-units'),
41
+ value: formatNumber(data.RequestUnits),
42
+ });
43
+ }
44
+ if (data.EndTime) {
45
+ items.push({
46
+ label: columnsI18n('end-time'),
47
+ value: formatDateTime(new Date(data.EndTime).getTime()),
48
+ });
49
+ }
50
+ if (data.ReadRows !== undefined) {
51
+ items.push({
52
+ label: columnsI18n('read-rows'),
53
+ value: formatNumber(data.ReadRows),
54
+ });
55
+ }
56
+ if (data.UserSID) {
57
+ items.push({
58
+ label: columnsI18n('user'),
59
+ value: data.UserSID,
60
+ });
61
+ }
62
+ if (data.ApplicationName) {
63
+ items.push({
64
+ label: columnsI18n('application'),
65
+ value: data.ApplicationName,
66
+ });
67
+ }
68
+ if (data.QueryStartAt) {
69
+ items.push({
70
+ label: columnsI18n('start-time'),
71
+ value: formatDateTime(new Date(data.QueryStartAt).getTime()),
72
+ });
73
+ }
74
+ return items;
75
+ }
7
76
  //# sourceMappingURL=utils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../src/containers/Tenant/Diagnostics/TopQueries/utils.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,oBAAoB,EAAC,MAAM,uBAAuB,CAAC;AAE3D,MAAM,CAAC,MAAM,0BAA0B,GAAa;IAChD,GAAG,oBAAoB;IACvB,gBAAgB,EAAE,IAAI;IACtB,YAAY,EAAE,IAAI;CACrB,CAAC"}
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../src/containers/Tenant/Diagnostics/TopQueries/utils.ts"],"names":[],"mappings":"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"}