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.
- package/dist/components/DiskStateProgressBar/DiskStateProgressBar.js +1 -1
- package/dist/components/Drawer/Drawer.d.ts +1 -1
- package/dist/components/Drawer/Drawer.js +11 -4
- package/dist/components/Drawer/Drawer.js.map +1 -1
- package/dist/components/Drawer/Drawer.scss +6 -1
- package/dist/components/EnableFullscreenButton/EnableFullscreenButton.d.ts +3 -1
- package/dist/components/EnableFullscreenButton/EnableFullscreenButton.js +2 -2
- package/dist/components/EnableFullscreenButton/EnableFullscreenButton.js.map +1 -1
- package/dist/components/EntityStatus/EntityStatus.d.ts +2 -1
- package/dist/components/EntityStatus/EntityStatus.js +6 -3
- package/dist/components/EntityStatus/EntityStatus.js.map +1 -1
- package/dist/components/EntityStatusNew/i18n/en.json +1 -1
- package/dist/components/JsonViewer/JsonViewer.d.ts +2 -0
- package/dist/components/JsonViewer/JsonViewer.js +4 -4
- package/dist/components/JsonViewer/JsonViewer.js.map +1 -1
- package/dist/components/JsonViewer/JsonViewer.scss +2 -0
- package/dist/components/JsonViewer/components/Cell.d.ts +1 -0
- package/dist/components/JsonViewer/components/Cell.js +6 -6
- package/dist/components/JsonViewer/components/Cell.js.map +1 -1
- package/dist/components/JsonViewer/components/FullValueDialog.js +5 -1
- package/dist/components/JsonViewer/components/FullValueDialog.js.map +1 -1
- package/dist/components/MemoryViewer/MemoryViewer.js +1 -1
- package/dist/components/ProgressViewer/ProgressViewer.js +1 -1
- package/dist/components/ShortyString/ShortyString.scss +1 -1
- package/dist/components/TableWithControlsLayout/TableWithControlsLayout.scss +1 -1
- package/dist/components/Tags/Tags.js +2 -1
- package/dist/components/Tags/Tags.js.map +1 -1
- package/dist/components/VDisk/utils.d.ts +2 -2
- package/dist/components/VDisk/utils.js +12 -13
- package/dist/components/VDisk/utils.js.map +1 -1
- package/dist/components/VDiskInfo/VDiskInfo.js +5 -1
- package/dist/components/VDiskInfo/VDiskInfo.js.map +1 -1
- package/dist/components/VDiskPopup/VDiskPopup.js +15 -12
- package/dist/components/VDiskPopup/VDiskPopup.js.map +1 -1
- package/dist/containers/AppWithClusters/AppWithClusters.d.ts +1 -5
- package/dist/containers/AppWithClusters/AppWithClusters.js +4 -5
- package/dist/containers/AppWithClusters/AppWithClusters.js.map +1 -1
- package/dist/containers/AppWithClusters/ExtendedCluster/ExtendedCluster.d.ts +2 -1
- package/dist/containers/AppWithClusters/ExtendedCluster/ExtendedCluster.js.map +1 -1
- package/dist/containers/AppWithClusters/ExtendedTenant/ExtendedTenant.d.ts +2 -1
- package/dist/containers/AppWithClusters/ExtendedTenant/ExtendedTenant.js.map +1 -1
- package/dist/containers/Cluster/ClusterInfo/ClusterInfo.js +3 -3
- package/dist/containers/Cluster/ClusterInfo/ClusterInfo.scss +2 -0
- package/dist/containers/Cluster/ClusterInfo/components/DiskGroupsStatsBars/DiskGroupsStats.js +3 -3
- package/dist/containers/Cluster/ClusterInfo/components/DiskGroupsStatsBars/DiskGroupsStats.js.map +1 -1
- package/dist/containers/Cluster/ClusterInfo/components/DiskGroupsStatsBars/DiskGroupsStats.scss +6 -1
- package/dist/containers/Cluster/ClusterInfo/utils/utils.js +3 -3
- package/dist/containers/Cluster/ClusterInfo/utils/utils.js.map +1 -1
- package/dist/containers/Node/Node.js +1 -1
- package/dist/containers/Node/Node.js.map +1 -1
- package/dist/containers/Operations/constants.js +1 -0
- package/dist/containers/Operations/constants.js.map +1 -1
- package/dist/containers/Operations/i18n/en.json +1 -0
- package/dist/containers/Operations/i18n/index.d.ts +1 -1
- package/dist/containers/Operations/useOperationsQueryParams.js +1 -1
- package/dist/containers/Operations/useOperationsQueryParams.js.map +1 -1
- package/dist/containers/PDiskPage/PDiskSpaceDistribution/PDiskSpaceDistribution.js +1 -1
- package/dist/containers/PDiskPage/PDiskSpaceDistribution/PDiskSpaceDistribution.js.map +1 -1
- package/dist/containers/Tablets/Tablets.d.ts +6 -1
- package/dist/containers/Tablets/Tablets.js +4 -3
- package/dist/containers/Tablets/Tablets.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/Describe/Describe.d.ts +1 -3
- package/dist/containers/Tenant/Diagnostics/Describe/Describe.js +9 -33
- package/dist/containers/Tenant/Diagnostics/Describe/Describe.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/Diagnostics.d.ts +2 -1
- package/dist/containers/Tenant/Diagnostics/Diagnostics.js +2 -2
- package/dist/containers/Tenant/Diagnostics/Diagnostics.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/DiagnosticsPages.d.ts +2 -2
- package/dist/containers/Tenant/Diagnostics/DiagnosticsPages.js +13 -7
- package/dist/containers/Tenant/Diagnostics/DiagnosticsPages.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/Overview/ChangefeedInfo/ChangefeedInfo.d.ts +1 -1
- package/dist/containers/Tenant/Diagnostics/Overview/ChangefeedInfo/ChangefeedInfo.js +7 -10
- package/dist/containers/Tenant/Diagnostics/Overview/ChangefeedInfo/ChangefeedInfo.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/Overview/Overview.js +8 -32
- package/dist/containers/Tenant/Diagnostics/Overview/Overview.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/Overview/TopicInfo/TopicInfo.js +10 -1
- package/dist/containers/Tenant/Diagnostics/Overview/TopicInfo/TopicInfo.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/Partitions/PartitionsControls/PartitionsControls.js +1 -1
- package/dist/containers/Tenant/Diagnostics/Partitions/PartitionsControls/PartitionsControls.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/Partitions/columns/columns.js +1 -1
- package/dist/containers/Tenant/Diagnostics/Partitions/columns/columns.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/NotFoundContainer.d.ts +5 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/NotFoundContainer.js +10 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/NotFoundContainer.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetails.d.ts +9 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetails.js +13 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetails.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetails.scss +43 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetailsDrawerContent.d.ts +7 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetailsDrawerContent.js +35 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetailsDrawerContent.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/RunningQueriesData.d.ts +1 -2
- package/dist/containers/Tenant/Diagnostics/TopQueries/RunningQueriesData.js +28 -7
- package/dist/containers/Tenant/Diagnostics/TopQueries/RunningQueriesData.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueries.js +5 -25
- package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueries.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueries.scss +29 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.d.ts +1 -2
- package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.js +37 -8
- package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useSetSelectedTopQueryRowFromParams.d.ts +8 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useSetSelectedTopQueryRowFromParams.js +33 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useSetSelectedTopQueryRowFromParams.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/i18n/en.json +7 -1
- package/dist/containers/Tenant/Diagnostics/TopQueries/i18n/index.d.ts +1 -1
- package/dist/containers/Tenant/Diagnostics/TopQueries/utils/generateShareableUrl.d.ts +7 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/utils/generateShareableUrl.js +20 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/utils/generateShareableUrl.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/utils/getTopQueryRowQueryParams.d.ts +8 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/utils/getTopQueryRowQueryParams.js +16 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/utils/getTopQueryRowQueryParams.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/utils.d.ts +3 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/utils.js +69 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/utils.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicData.js +67 -24
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicData.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicData.scss +8 -2
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicDataControls/TopicDataControls.d.ts +2 -1
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicDataControls/TopicDataControls.js +15 -7
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicDataControls/TopicDataControls.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/TopicMessageDetails.d.ts +7 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/TopicMessageDetails.js +82 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/TopicMessageDetails.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/TopicMessageDetails.scss +53 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicDataSection.d.ts +8 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicDataSection.js +7 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicDataSection.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessage.d.ts +7 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessage.js +65 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessage.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessageGeneralInfo.d.ts +6 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessageGeneralInfo.js +39 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessageGeneralInfo.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessageMetadata.d.ts +6 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessageMetadata.js +9 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/TopicMessageMetadata.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/fields.d.ts +10 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/fields.js +67 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/components/fields.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/shared.d.ts +2 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/shared.js +4 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicMessageDetails/shared.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/__test__/getData.test.js +116 -42
- package/dist/containers/Tenant/Diagnostics/TopicData/__test__/getData.test.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopicData/columns/Columns.scss +25 -4
- package/dist/containers/Tenant/Diagnostics/TopicData/columns/columns.d.ts +16 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/columns/columns.js +153 -117
- package/dist/containers/Tenant/Diagnostics/TopicData/columns/columns.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopicData/getData.d.ts +6 -4
- package/dist/containers/Tenant/Diagnostics/TopicData/getData.js +30 -15
- package/dist/containers/Tenant/Diagnostics/TopicData/getData.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopicData/i18n/en.json +10 -2
- package/dist/containers/Tenant/Diagnostics/TopicData/i18n/index.d.ts +1 -1
- package/dist/containers/Tenant/Diagnostics/TopicData/useTopicDataQueryParams.d.ts +2 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/useTopicDataQueryParams.js +7 -1
- package/dist/containers/Tenant/Diagnostics/TopicData/useTopicDataQueryParams.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopicData/utils/constants.js +3 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/utils/constants.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopicData/utils/types.d.ts +1 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/utils/types.js +1 -0
- package/dist/containers/Tenant/Diagnostics/TopicData/utils/types.js.map +1 -1
- package/dist/containers/Tenant/ObjectGeneral/ObjectGeneral.d.ts +2 -1
- package/dist/containers/Tenant/ObjectGeneral/ObjectGeneral.js +2 -2
- package/dist/containers/Tenant/ObjectGeneral/ObjectGeneral.js.map +1 -1
- package/dist/containers/Tenant/Query/QueryResult/QueryResultViewer.js +1 -1
- package/dist/containers/Tenant/Query/QueryResult/QueryResultViewer.js.map +1 -1
- package/dist/containers/Tenant/Tenant.js +1 -1
- package/dist/containers/Tenant/Tenant.js.map +1 -1
- package/dist/containers/Tenant/TenantPages.d.ts +1 -0
- package/dist/containers/Tenant/TenantPages.js.map +1 -1
- package/dist/containers/Tenant/utils/schema.d.ts +0 -1
- package/dist/containers/Tenant/utils/schema.js +2 -22
- package/dist/containers/Tenant/utils/schema.js.map +1 -1
- package/dist/containers/Tenants/Tenants.js +1 -1
- package/dist/containers/Tenants/Tenants.js.map +1 -1
- package/dist/containers/VDiskPage/VDiskPage.js +19 -3
- package/dist/containers/VDiskPage/VDiskPage.js.map +1 -1
- package/dist/routes.d.ts +9 -1
- package/dist/routes.js +2 -2
- package/dist/routes.js.map +1 -1
- package/dist/services/api/viewer.d.ts +2 -5
- package/dist/services/api/viewer.js +2 -1
- package/dist/services/api/viewer.js.map +1 -1
- package/dist/store/reducers/capabilities/hooks.js +1 -1
- package/dist/store/reducers/overview/overview.d.ts +0 -36
- package/dist/store/reducers/overview/overview.js +0 -55
- package/dist/store/reducers/overview/overview.js.map +1 -1
- package/dist/store/reducers/partitions/types.d.ts +1 -1
- package/dist/store/reducers/storage/prepareGroupsDisks.js +6 -0
- package/dist/store/reducers/storage/prepareGroupsDisks.js.map +1 -1
- package/dist/store/reducers/topic.d.ts +1 -1
- package/dist/store/reducers/topic.js +1 -1
- package/dist/store/reducers/topic.js.map +1 -1
- package/dist/store/state-url-mapping.d.ts +1 -0
- package/dist/store/state-url-mapping.js +1 -0
- package/dist/store/state-url-mapping.js.map +1 -1
- package/dist/types/api/operations.d.ts +1 -1
- package/dist/types/api/topic.d.ts +1 -0
- package/dist/types/store/tablets.d.ts +1 -0
- package/dist/uiFactory/types.d.ts +5 -0
- package/dist/uiFactory/uiFactory.js +5 -1
- package/dist/uiFactory/uiFactory.js.map +1 -1
- package/dist/utils/disks/__test__/prepareDisks.test.js +2 -2
- package/dist/utils/disks/prepareDisks.js +2 -2
- package/dist/utils/downloadFile.d.ts +1 -0
- package/dist/utils/downloadFile.js +8 -4
- package/dist/utils/downloadFile.js.map +1 -1
- package/dist/utils/logs.d.ts +1 -3
- package/dist/utils/logs.js +1 -23
- package/dist/utils/logs.js.map +1 -1
- package/dist/utils/monitoring.d.ts +0 -5
- package/dist/utils/utils.d.ts +1 -0
- package/dist/utils/utils.js +1 -1
- package/dist/utils/utils.js.map +1 -1
- package/package.json +1 -1
- package/dist/utils/__test__/logs.test.d.ts +0 -1
- package/dist/utils/__test__/logs.test.js +0 -36
- 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,
|
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,
|
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
|
36
|
-
|
37
|
-
|
38
|
-
|
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":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,EAAC,gBAAgB,EAAC,MAAM,mBAAmB,CAAC;
|
1
|
+
{"version":3,"file":"RunningQueriesData.js","sourceRoot":"","sources":["../../../../../src/containers/Tenant/Diagnostics/TopQueries/RunningQueriesData.tsx"],"names":[],"mappings":"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"}
|
@@ -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
|
42
|
-
const
|
43
|
-
const
|
44
|
-
const
|
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,
|
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":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,EAAC,WAAW,EAAC,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAC,
|
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,
|
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,
|
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,
|
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
|
40
|
-
|
41
|
-
|
42
|
-
|
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":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,EAAC,MAAM,EAAE,gBAAgB,EAAC,MAAM,mBAAmB,CAAC;
|
1
|
+
{"version":3,"file":"TopQueriesData.js","sourceRoot":"","sources":["../../../../../src/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.tsx"],"names":[],"mappings":"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"}
|
package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useSetSelectedTopQueryRowFromParams.d.ts
ADDED
@@ -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;
|
package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useSetSelectedTopQueryRowFromParams.js
ADDED
@@ -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":"
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../src/containers/Tenant/Diagnostics/TopQueries/utils.ts"],"names":[],"mappings":"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"}
|