ydb-embedded-ui 8.26.1 → 9.0.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 (93) 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/EntityStatusNew/i18n/en.json +1 -1
  7. package/dist/components/MemoryViewer/MemoryViewer.js +1 -1
  8. package/dist/components/PaginatedTable/useScrollBasedChunks.js +18 -16
  9. package/dist/components/PaginatedTable/useScrollBasedChunks.js.map +1 -1
  10. package/dist/components/ProgressViewer/ProgressViewer.js +1 -1
  11. package/dist/components/TableWithControlsLayout/TableWithControlsLayout.scss +1 -1
  12. package/dist/containers/AppWithClusters/AppWithClusters.d.ts +1 -5
  13. package/dist/containers/AppWithClusters/AppWithClusters.js +4 -5
  14. package/dist/containers/AppWithClusters/AppWithClusters.js.map +1 -1
  15. package/dist/containers/AppWithClusters/ExtendedCluster/ExtendedCluster.d.ts +2 -1
  16. package/dist/containers/AppWithClusters/ExtendedCluster/ExtendedCluster.js.map +1 -1
  17. package/dist/containers/AppWithClusters/ExtendedTenant/ExtendedTenant.d.ts +2 -1
  18. package/dist/containers/AppWithClusters/ExtendedTenant/ExtendedTenant.js.map +1 -1
  19. package/dist/containers/Cluster/ClusterInfo/components/DiskGroupsStatsBars/DiskGroupsStats.js +1 -1
  20. package/dist/containers/Cluster/ClusterOverview/ClusterOverview.js +1 -1
  21. package/dist/containers/Cluster/ClusterOverview/ClusterOverview.js.map +1 -1
  22. package/dist/containers/Cluster/ClusterOverview/ClusterOverview.scss +5 -0
  23. package/dist/containers/Cluster/ClusterOverview/components/ClusterMetricsCard.d.ts +5 -2
  24. package/dist/containers/Cluster/ClusterOverview/components/ClusterMetricsCard.js +6 -6
  25. package/dist/containers/Cluster/ClusterOverview/components/ClusterMetricsCard.js.map +1 -1
  26. package/dist/containers/Node/Node.js +1 -1
  27. package/dist/containers/Node/Node.js.map +1 -1
  28. package/dist/containers/Operations/constants.js +1 -0
  29. package/dist/containers/Operations/constants.js.map +1 -1
  30. package/dist/containers/Operations/i18n/en.json +1 -0
  31. package/dist/containers/Operations/i18n/index.d.ts +1 -1
  32. package/dist/containers/Operations/useOperationsQueryParams.js +1 -1
  33. package/dist/containers/Operations/useOperationsQueryParams.js.map +1 -1
  34. package/dist/containers/Tablets/Tablets.d.ts +6 -1
  35. package/dist/containers/Tablets/Tablets.js +4 -3
  36. package/dist/containers/Tablets/Tablets.js.map +1 -1
  37. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/NotFoundContainer.d.ts +5 -0
  38. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/NotFoundContainer.js +10 -0
  39. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/NotFoundContainer.js.map +1 -0
  40. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetails.d.ts +9 -0
  41. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetails.js +13 -0
  42. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetails.js.map +1 -0
  43. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetails.scss +43 -0
  44. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetailsDrawerContent.d.ts +7 -0
  45. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetailsDrawerContent.js +35 -0
  46. package/dist/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetailsDrawerContent.js.map +1 -0
  47. package/dist/containers/Tenant/Diagnostics/TopQueries/RunningQueriesData.d.ts +1 -2
  48. package/dist/containers/Tenant/Diagnostics/TopQueries/RunningQueriesData.js +28 -7
  49. package/dist/containers/Tenant/Diagnostics/TopQueries/RunningQueriesData.js.map +1 -1
  50. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueries.js +5 -25
  51. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueries.js.map +1 -1
  52. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueries.scss +29 -0
  53. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.d.ts +1 -2
  54. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.js +37 -8
  55. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.js.map +1 -1
  56. package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useSetSelectedTopQueryRowFromParams.d.ts +8 -0
  57. package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useSetSelectedTopQueryRowFromParams.js +33 -0
  58. package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useSetSelectedTopQueryRowFromParams.js.map +1 -0
  59. package/dist/containers/Tenant/Diagnostics/TopQueries/i18n/en.json +7 -1
  60. package/dist/containers/Tenant/Diagnostics/TopQueries/i18n/index.d.ts +1 -1
  61. package/dist/containers/Tenant/Diagnostics/TopQueries/utils/generateShareableUrl.d.ts +7 -0
  62. package/dist/containers/Tenant/Diagnostics/TopQueries/utils/generateShareableUrl.js +20 -0
  63. package/dist/containers/Tenant/Diagnostics/TopQueries/utils/generateShareableUrl.js.map +1 -0
  64. package/dist/containers/Tenant/Diagnostics/TopQueries/utils/getTopQueryRowQueryParams.d.ts +8 -0
  65. package/dist/containers/Tenant/Diagnostics/TopQueries/utils/getTopQueryRowQueryParams.js +16 -0
  66. package/dist/containers/Tenant/Diagnostics/TopQueries/utils/getTopQueryRowQueryParams.js.map +1 -0
  67. package/dist/containers/Tenant/Diagnostics/TopQueries/utils.d.ts +3 -0
  68. package/dist/containers/Tenant/Diagnostics/TopQueries/utils.js +69 -0
  69. package/dist/containers/Tenant/Diagnostics/TopQueries/utils.js.map +1 -1
  70. package/dist/containers/Tenant/Diagnostics/TopicData/__test__/getData.test.js +113 -39
  71. package/dist/containers/Tenant/Diagnostics/TopicData/__test__/getData.test.js.map +1 -1
  72. package/dist/containers/Tenant/Diagnostics/TopicData/getData.js +28 -12
  73. package/dist/containers/Tenant/Diagnostics/TopicData/getData.js.map +1 -1
  74. package/dist/containers/Tenants/Tenants.js +1 -1
  75. package/dist/containers/Tenants/Tenants.js.map +1 -1
  76. package/dist/services/api/viewer.d.ts +2 -5
  77. package/dist/services/api/viewer.js +2 -1
  78. package/dist/services/api/viewer.js.map +1 -1
  79. package/dist/types/api/operations.d.ts +1 -1
  80. package/dist/types/store/tablets.d.ts +1 -0
  81. package/dist/uiFactory/types.d.ts +5 -0
  82. package/dist/uiFactory/uiFactory.js +5 -1
  83. package/dist/uiFactory/uiFactory.js.map +1 -1
  84. package/dist/utils/disks/__test__/prepareDisks.test.js +2 -2
  85. package/dist/utils/disks/prepareDisks.js +2 -2
  86. package/dist/utils/logs.d.ts +1 -3
  87. package/dist/utils/logs.js +1 -23
  88. package/dist/utils/logs.js.map +1 -1
  89. package/dist/utils/monitoring.d.ts +0 -5
  90. package/package.json +1 -1
  91. package/dist/utils/__test__/logs.test.d.ts +0 -1
  92. package/dist/utils/__test__/logs.test.js +0 -36
  93. package/dist/utils/__test__/logs.test.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NotFoundContainer.js","sourceRoot":"","sources":["../../../../../../src/containers/Tenant/Diagnostics/TopQueries/QueryDetails/NotFoundContainer.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAC,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAE3D,OAAO,EAAC,EAAE,EAAC,MAAM,yBAAyB,CAAC;AAC3C,OAAO,IAAI,MAAM,SAAS,CAAC;AAE3B,OAAO,UAAU,MAAM,yCAAyC,CAAC;AAEjE,MAAM,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,CAAC;AAM/B,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,EAAC,OAAO,EAAyB,EAAE,EAAE;IACnE,OAAO,CACH,MAAC,IAAI,IACD,cAAc,EAAC,QAAQ,EACvB,UAAU,EAAC,QAAQ,EACnB,SAAS,EAAC,QAAQ,EAClB,SAAS,EAAE,CAAC,CAAC,qBAAqB,CAAC,aAEnC,KAAC,IAAI,IAAC,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,GAAI,EACrC,KAAC,IAAI,IAAC,OAAO,EAAC,aAAa,EAAC,SAAS,EAAE,CAAC,CAAC,iBAAiB,CAAC,YACtD,IAAI,CAAC,+BAA+B,CAAC,GACnC,EACP,KAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,eAAe,EAAC,SAAS,EAAE,CAAC,CAAC,uBAAuB,CAAC,YAC7E,IAAI,CAAC,qCAAqC,CAAC,GACzC,EACP,KAAC,MAAM,IAAC,IAAI,EAAC,GAAG,EAAC,IAAI,EAAC,QAAQ,EAAC,SAAS,EAAE,CAAC,CAAC,iBAAiB,CAAC,EAAE,OAAO,EAAE,OAAO,YAC3E,IAAI,CAAC,qBAAqB,CAAC,GACvB,IACN,CACV,CAAC;AACN,CAAC,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type { InfoViewerItem } from '../../../../../components/InfoViewer';
2
+ import './QueryDetails.scss';
3
+ interface QueryDetailsProps {
4
+ queryText: string;
5
+ infoItems: InfoViewerItem[];
6
+ onOpenInEditor: () => void;
7
+ }
8
+ export declare const QueryDetails: ({ queryText, infoItems, onOpenInEditor }: QueryDetailsProps) => import("react/jsx-runtime").JSX.Element;
9
+ export {};
@@ -0,0 +1,13 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Code } from '@gravity-ui/icons';
3
+ import { Button, Flex, Icon } from '@gravity-ui/uikit';
4
+ import { InfoViewer } from '../../../../../components/InfoViewer';
5
+ import { YDBSyntaxHighlighter } from '../../../../../components/SyntaxHighlighter/YDBSyntaxHighlighter';
6
+ import { cn } from '../../../../../utils/cn';
7
+ import i18n from '../i18n';
8
+ import './QueryDetails.scss';
9
+ const b = cn('ydb-query-details');
10
+ export const QueryDetails = ({ queryText, infoItems, onOpenInEditor }) => {
11
+ return (_jsx(Flex, { direction: "column", className: b(), children: _jsxs(Flex, { direction: "column", className: b('content'), children: [_jsx(InfoViewer, { info: infoItems }), _jsxs("div", { className: b('query-content'), children: [_jsxs("div", { className: b('query-header'), children: [_jsx("div", { className: b('query-title'), children: i18n('query-details.query.title') }), _jsxs(Button, { view: "flat-secondary", size: "m", onClick: onOpenInEditor, className: b('editor-button'), children: [_jsx(Icon, { data: Code, size: 16 }), i18n('query-details.open-in-editor')] })] }), _jsx(YDBSyntaxHighlighter, { language: "yql", text: queryText, withClipboardButton: { alwaysVisible: true, withLabel: false } })] })] }) }));
12
+ };
13
+ //# sourceMappingURL=QueryDetails.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QueryDetails.js","sourceRoot":"","sources":["../../../../../../src/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetails.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAC,IAAI,EAAC,MAAM,mBAAmB,CAAC;AACvC,OAAO,EAAC,MAAM,EAAE,IAAI,EAAE,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAGrD,OAAO,EAAC,UAAU,EAAC,MAAM,sCAAsC,CAAC;AAChE,OAAO,EAAC,oBAAoB,EAAC,MAAM,kEAAkE,CAAC;AACtG,OAAO,EAAC,EAAE,EAAC,MAAM,yBAAyB,CAAC;AAC3C,OAAO,IAAI,MAAM,SAAS,CAAC;AAE3B,OAAO,qBAAqB,CAAC;AAE7B,MAAM,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC,CAAC;AAQlC,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAAC,SAAS,EAAE,SAAS,EAAE,cAAc,EAAoB,EAAE,EAAE;IACtF,OAAO,CACH,KAAC,IAAI,IAAC,SAAS,EAAC,QAAQ,EAAC,SAAS,EAAE,CAAC,EAAE,YACnC,MAAC,IAAI,IAAC,SAAS,EAAC,QAAQ,EAAC,SAAS,EAAE,CAAC,CAAC,SAAS,CAAC,aAC5C,KAAC,UAAU,IAAC,IAAI,EAAE,SAAS,GAAI,EAE/B,eAAK,SAAS,EAAE,CAAC,CAAC,eAAe,CAAC,aAC9B,eAAK,SAAS,EAAE,CAAC,CAAC,cAAc,CAAC,aAC7B,cAAK,SAAS,EAAE,CAAC,CAAC,aAAa,CAAC,YAAG,IAAI,CAAC,2BAA2B,CAAC,GAAO,EAC3E,MAAC,MAAM,IACH,IAAI,EAAC,gBAAgB,EACrB,IAAI,EAAC,GAAG,EACR,OAAO,EAAE,cAAc,EACvB,SAAS,EAAE,CAAC,CAAC,eAAe,CAAC,aAE7B,KAAC,IAAI,IAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,GAAI,EAC7B,IAAI,CAAC,8BAA8B,CAAC,IAChC,IACP,EACN,KAAC,oBAAoB,IACjB,QAAQ,EAAC,KAAK,EACd,IAAI,EAAE,SAAS,EACf,mBAAmB,EAAE,EAAC,aAAa,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAC,GAC9D,IACA,IACH,GACJ,CACV,CAAC;AACN,CAAC,CAAC"}
@@ -0,0 +1,43 @@
1
+ @import '../../../../../styles/mixins.scss';
2
+
3
+ .ydb-query-details {
4
+ flex: 1;
5
+
6
+ color: var(--g-color-text-primary);
7
+ background-color: var(--g-color-base-background-dark);
8
+
9
+ &__content {
10
+ overflow: auto;
11
+ flex: 1;
12
+
13
+ padding: var(--g-spacing-5) var(--g-spacing-4) var(--g-spacing-5) var(--g-spacing-4);
14
+ }
15
+
16
+ &__query-header {
17
+ display: flex;
18
+ justify-content: space-between;
19
+ align-items: center;
20
+
21
+ padding: var(--g-spacing-2) var(--g-spacing-3);
22
+
23
+ border-bottom: 1px solid var(--g-color-line-generic);
24
+ }
25
+
26
+ &__query-title {
27
+ font-size: 14px;
28
+ font-weight: 500;
29
+ }
30
+
31
+ &__query-content {
32
+ position: relative;
33
+
34
+ display: flex;
35
+ flex: 1;
36
+ flex-direction: column;
37
+
38
+ margin-top: var(--g-spacing-5);
39
+
40
+ border-radius: 4px;
41
+ background-color: var(--code-background-color);
42
+ }
43
+ }
@@ -0,0 +1,7 @@
1
+ import type { KeyValueRow } from '../../../../../types/api/query';
2
+ interface QueryDetailsDrawerContentProps {
3
+ row?: KeyValueRow | null;
4
+ onClose: () => void;
5
+ }
6
+ export declare const QueryDetailsDrawerContent: ({ row, onClose }: QueryDetailsDrawerContentProps) => import("react/jsx-runtime").JSX.Element;
7
+ export {};
@@ -0,0 +1,35 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import { useHistory, useLocation } from 'react-router-dom';
4
+ import { parseQuery } from '../../../../../routes';
5
+ import { changeUserInput, setIsDirty } from '../../../../../store/reducers/query/query';
6
+ import { TENANT_PAGE, TENANT_PAGES_IDS, TENANT_QUERY_TABS_ID, } from '../../../../../store/reducers/tenant/constants';
7
+ import { useTypedDispatch } from '../../../../../utils/hooks';
8
+ import { TenantTabsGroups, getTenantPath } from '../../../TenantPages';
9
+ import { createQueryInfoItems } from '../utils';
10
+ import { NotFoundContainer } from './NotFoundContainer';
11
+ import { QueryDetails } from './QueryDetails';
12
+ export const QueryDetailsDrawerContent = ({ row, onClose }) => {
13
+ const dispatch = useTypedDispatch();
14
+ const location = useLocation();
15
+ const history = useHistory();
16
+ const handleOpenInEditor = React.useCallback(() => {
17
+ if (row) {
18
+ const input = row.QueryText;
19
+ dispatch(changeUserInput({ input }));
20
+ dispatch(setIsDirty(false));
21
+ const queryParams = parseQuery(location);
22
+ const queryPath = getTenantPath({
23
+ ...queryParams,
24
+ [TENANT_PAGE]: TENANT_PAGES_IDS.query,
25
+ [TenantTabsGroups.queryTab]: TENANT_QUERY_TABS_ID.newQuery,
26
+ });
27
+ history.push(queryPath);
28
+ }
29
+ }, [dispatch, history, location, row]);
30
+ if (row) {
31
+ return (_jsx(QueryDetails, { queryText: row.QueryText, infoItems: createQueryInfoItems(row), onOpenInEditor: handleOpenInEditor }));
32
+ }
33
+ return _jsx(NotFoundContainer, { onClose: onClose });
34
+ };
35
+ //# sourceMappingURL=QueryDetailsDrawerContent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QueryDetailsDrawerContent.js","sourceRoot":"","sources":["../../../../../../src/containers/Tenant/Diagnostics/TopQueries/QueryDetails/QueryDetailsDrawerContent.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAC,UAAU,EAAE,WAAW,EAAC,MAAM,kBAAkB,CAAC;AAEzD,OAAO,EAAC,UAAU,EAAC,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAC,eAAe,EAAE,UAAU,EAAC,MAAM,2CAA2C,CAAC;AACtF,OAAO,EACH,WAAW,EACX,gBAAgB,EAChB,oBAAoB,GACvB,MAAM,gDAAgD,CAAC;AAExD,OAAO,EAAC,gBAAgB,EAAC,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAC,gBAAgB,EAAE,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACrE,OAAO,EAAC,oBAAoB,EAAC,MAAM,UAAU,CAAC;AAE9C,OAAO,EAAC,iBAAiB,EAAC,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AAW5C,MAAM,CAAC,MAAM,yBAAyB,GAAG,CAAC,EAAC,GAAG,EAAE,OAAO,EAAiC,EAAE,EAAE;IACxF,MAAM,QAAQ,GAAG,gBAAgB,EAAE,CAAC;IACpC,MAAM,QAAQ,GAAG,WAAW,EAAE,CAAC;IAC/B,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;IAE7B,MAAM,kBAAkB,GAAG,KAAK,CAAC,WAAW,CAAC,GAAG,EAAE;QAC9C,IAAI,GAAG,EAAE,CAAC;YACN,MAAM,KAAK,GAAG,GAAG,CAAC,SAAmB,CAAC;YACtC,QAAQ,CAAC,eAAe,CAAC,EAAC,KAAK,EAAC,CAAC,CAAC,CAAC;YACnC,QAAQ,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;YAE5B,MAAM,WAAW,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAC;YAEzC,MAAM,SAAS,GAAG,aAAa,CAAC;gBAC5B,GAAG,WAAW;gBACd,CAAC,WAAW,CAAC,EAAE,gBAAgB,CAAC,KAAK;gBACrC,CAAC,gBAAgB,CAAC,QAAQ,CAAC,EAAE,oBAAoB,CAAC,QAAQ;aAC7D,CAAC,CAAC;YAEH,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC5B,CAAC;IACL,CAAC,EAAE,CAAC,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC;IAEvC,IAAI,GAAG,EAAE,CAAC;QACN,OAAO,CACH,KAAC,YAAY,IACT,SAAS,EAAE,GAAG,CAAC,SAAmB,EAClC,SAAS,EAAE,oBAAoB,CAAC,GAAG,CAAC,EACpC,cAAc,EAAE,kBAAkB,GACpC,CACL,CAAC;IACN,CAAC;IAED,OAAO,KAAC,iBAAiB,IAAC,OAAO,EAAE,OAAO,GAAI,CAAC;AACnD,CAAC,CAAC"}
@@ -2,8 +2,7 @@ import React from 'react';
2
2
  interface RunningQueriesDataProps {
3
3
  tenantName: string;
4
4
  renderQueryModeControl: () => React.ReactNode;
5
- onRowClick: (query: string) => void;
6
5
  handleTextSearchUpdate: (text: string) => void;
7
6
  }
8
- export declare const RunningQueriesData: ({ tenantName, renderQueryModeControl, onRowClick, handleTextSearchUpdate, }: RunningQueriesDataProps) => import("react/jsx-runtime").JSX.Element;
7
+ export declare const RunningQueriesData: ({ tenantName, renderQueryModeControl, handleTextSearchUpdate, }: RunningQueriesDataProps) => import("react/jsx-runtime").JSX.Element;
9
8
  export {};
@@ -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":"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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 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[];