ydb-embedded-ui 6.11.0 → 6.12.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (243) hide show
  1. package/dist/components/DateRange/DateRange.d.ts +4 -4
  2. package/dist/components/DateRange/DateRange.js +23 -26
  3. package/dist/components/DateRange/DateRange.scss +14 -13
  4. package/dist/components/DateRange/__test__/fromDateRangeValues.test.d.ts +1 -0
  5. package/dist/components/DateRange/__test__/fromDateRangeValues.test.js +80 -0
  6. package/dist/components/DateRange/__test__/getdatePickerSize.test.d.ts +1 -0
  7. package/dist/components/DateRange/__test__/getdatePickerSize.test.js +56 -0
  8. package/dist/components/DateRange/__test__/toDateRangeValues.test.d.ts +1 -0
  9. package/dist/components/DateRange/__test__/toDateRangeValues.test.js +80 -0
  10. package/dist/components/DateRange/i18n/en.json +4 -0
  11. package/dist/components/DateRange/i18n/index.d.ts +2 -0
  12. package/dist/components/DateRange/i18n/index.js +5 -0
  13. package/dist/components/DateRange/i18n/ru.json +4 -0
  14. package/dist/components/DateRange/utils.d.ts +5 -0
  15. package/dist/components/DateRange/utils.js +41 -0
  16. package/dist/components/DeveloperUILinkButton/DeveloperUILinkButton.d.ts +8 -0
  17. package/dist/components/{DeveloperUiLink/DeveloperUiLink.js → DeveloperUILinkButton/DeveloperUILinkButton.js} +3 -3
  18. package/dist/components/{DeveloperUiLink/DeveloperUiLink.scss → DeveloperUILinkButton/DeveloperUILinkButton.scss} +3 -2
  19. package/dist/components/DiskStateProgressBar/DiskStateProgressBar.d.ts +6 -1
  20. package/dist/components/DiskStateProgressBar/DiskStateProgressBar.js +22 -12
  21. package/dist/components/DiskStateProgressBar/DiskStateProgressBar.scss +45 -45
  22. package/dist/components/EntityStatus/EntityStatus.js +1 -1
  23. package/dist/components/EntityStatus/EntityStatus.scss +6 -2
  24. package/dist/components/MetricChart/reducer.d.ts +2 -2
  25. package/dist/components/MonacoEditor/MonacoEditor.js +0 -2
  26. package/dist/components/NodeHostWrapper/NodeHostWrapper.d.ts +0 -1
  27. package/dist/components/NodeHostWrapper/NodeHostWrapper.js +3 -6
  28. package/dist/components/PDiskInfo/PDiskInfo.d.ts +7 -4
  29. package/dist/components/PDiskInfo/PDiskInfo.js +73 -26
  30. package/dist/components/PDiskInfo/PDiskInfo.scss +15 -1
  31. package/dist/components/PDiskInfo/i18n/en.json +11 -5
  32. package/dist/components/PDiskInfo/i18n/index.d.ts +1 -1
  33. package/dist/components/PDiskPopup/PDiskPopup.js +8 -2
  34. package/dist/components/VDiskInfo/VDiskInfo.d.ts +3 -2
  35. package/dist/components/VDiskInfo/VDiskInfo.js +9 -4
  36. package/dist/components/VDiskInfo/VDiskInfo.scss +7 -1
  37. package/dist/components/VDiskInfo/i18n/en.json +2 -1
  38. package/dist/components/VDiskInfo/i18n/index.d.ts +1 -1
  39. package/dist/containers/Cluster/Cluster.scss +1 -4
  40. package/dist/containers/Cluster/ClusterInfo/ClusterInfo.scss +1 -1
  41. package/dist/containers/Heatmap/Heatmap.d.ts +2 -1
  42. package/dist/containers/Heatmap/Heatmap.js +2 -2
  43. package/dist/containers/Node/Node.scss +1 -4
  44. package/dist/containers/Node/NodeStructure/NodeStructure.scss +0 -20
  45. package/dist/containers/Node/NodeStructure/Pdisk.js +2 -2
  46. package/dist/containers/PDiskPage/PDiskGroups/PDiskGroups.d.ts +6 -0
  47. package/dist/containers/PDiskPage/PDiskGroups/PDiskGroups.js +24 -0
  48. package/dist/containers/PDiskPage/PDiskPage.js +62 -24
  49. package/dist/containers/PDiskPage/PDiskPage.scss +8 -5
  50. package/dist/containers/PDiskPage/PDiskSpaceDistribution/PDiskSpaceDistribution.d.ts +7 -0
  51. package/dist/containers/PDiskPage/PDiskSpaceDistribution/PDiskSpaceDistribution.js +93 -0
  52. package/dist/containers/PDiskPage/PDiskSpaceDistribution/PDiskSpaceDistribution.scss +52 -0
  53. package/dist/containers/PDiskPage/PDiskSpaceDistribution/utils.d.ts +4 -0
  54. package/dist/containers/PDiskPage/PDiskSpaceDistribution/utils.js +9 -0
  55. package/dist/containers/PDiskPage/i18n/en.json +8 -1
  56. package/dist/containers/PDiskPage/i18n/index.d.ts +1 -1
  57. package/dist/containers/Storage/StorageGroups/getStorageGroupsColumns.js +16 -6
  58. package/dist/containers/Tablets/Tablets.js +11 -8
  59. package/dist/containers/Tenant/Acl/Acl.d.ts +2 -1
  60. package/dist/containers/Tenant/Acl/Acl.js +10 -8
  61. package/dist/containers/Tenant/Acl/Acl.scss +8 -8
  62. package/dist/containers/Tenant/Acl/i18n/en.json +6 -0
  63. package/dist/containers/Tenant/Acl/i18n/index.d.ts +2 -0
  64. package/dist/containers/Tenant/Acl/i18n/index.js +4 -0
  65. package/dist/containers/Tenant/Diagnostics/Describe/Describe.d.ts +2 -1
  66. package/dist/containers/Tenant/Diagnostics/Describe/Describe.js +4 -4
  67. package/dist/containers/Tenant/Diagnostics/DetailedOverview/DetailedOverview.js +1 -1
  68. package/dist/containers/Tenant/Diagnostics/Diagnostics.js +3 -3
  69. package/dist/containers/Tenant/Diagnostics/Diagnostics.scss +3 -1
  70. package/dist/containers/Tenant/Diagnostics/HotKeys/HotKeys.d.ts +2 -1
  71. package/dist/containers/Tenant/Diagnostics/HotKeys/HotKeys.js +3 -3
  72. package/dist/containers/Tenant/Diagnostics/Overview/Overview.d.ts +2 -1
  73. package/dist/containers/Tenant/Diagnostics/Overview/Overview.js +5 -5
  74. package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/i18n/en.json +14 -1
  75. package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/i18n/index.d.ts +1 -1
  76. package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/i18n/index.js +1 -2
  77. package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/prepareTableInfo.js +36 -17
  78. package/dist/containers/Tenant/Diagnostics/TenantOverview/TenantCpu/TopQueries.js +8 -5
  79. package/dist/containers/Tenant/Diagnostics/TenantOverview/TenantOverview.js +1 -1
  80. package/dist/containers/Tenant/Diagnostics/TenantOverview/getSectionTitle.d.ts +2 -1
  81. package/dist/containers/Tenant/Diagnostics/TenantOverview/getSectionTitle.js +2 -2
  82. package/dist/containers/Tenant/Diagnostics/TenantOverview/i18n/en.json +3 -2
  83. package/dist/containers/Tenant/Diagnostics/TenantOverview/i18n/index.d.ts +1 -1
  84. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueries.js +2 -2
  85. package/dist/containers/Tenant/Diagnostics/TopQueries/getTopQueriesColumns.d.ts +2 -2
  86. package/dist/containers/Tenant/Diagnostics/TopQueries/getTopQueriesColumns.js +14 -14
  87. package/dist/containers/Tenant/Diagnostics/TopShards/TopShards.js +3 -3
  88. package/dist/containers/Tenant/Diagnostics/TopShards/getTopShardsColumns.js +4 -4
  89. package/dist/containers/Tenant/ObjectSummary/ObjectSummary.js +31 -18
  90. package/dist/containers/Tenant/Query/ExplainResult/ExplainResult.js +2 -2
  91. package/dist/containers/Tenant/Query/QueryEditor/QueryEditor.js +8 -3
  92. package/dist/containers/Tenant/Query/QueryEditorControls/QueryEditorControls.d.ts +2 -1
  93. package/dist/containers/Tenant/Query/QueryEditorControls/QueryEditorControls.js +9 -7
  94. package/dist/containers/Tenant/Query/QuerySettingsDialog/QuerySettingsDialog.d.ts +2 -0
  95. package/dist/containers/Tenant/Query/QuerySettingsDialog/QuerySettingsDialog.js +38 -0
  96. package/dist/containers/Tenant/Query/QuerySettingsDialog/QuerySettingsDialog.scss +63 -0
  97. package/dist/containers/Tenant/Query/QuerySettingsDialog/QuerySettingsSelect.d.ts +15 -0
  98. package/dist/containers/Tenant/Query/QuerySettingsDialog/QuerySettingsSelect.js +14 -0
  99. package/dist/containers/Tenant/Query/QuerySettingsDialog/QuerySettingsSelect.scss +19 -0
  100. package/dist/containers/Tenant/Query/QuerySettingsDialog/constants.d.ts +99 -0
  101. package/dist/containers/Tenant/Query/QuerySettingsDialog/constants.js +109 -0
  102. package/dist/containers/Tenant/Query/QuerySettingsDialog/i18n/en.json +13 -0
  103. package/dist/containers/Tenant/Query/QuerySettingsDialog/i18n/index.d.ts +2 -0
  104. package/dist/containers/Tenant/Query/QuerySettingsDialog/i18n/index.js +5 -0
  105. package/dist/containers/Tenant/Query/QuerySettingsDialog/i18n/ru.json +13 -0
  106. package/dist/containers/Tenant/Query/i18n/en.json +14 -0
  107. package/dist/containers/Tenant/Query/i18n/index.d.ts +1 -1
  108. package/dist/containers/Tenant/Schema/CreateDirectoryDialog/CreateDirectoryDialog.d.ts +3 -2
  109. package/dist/containers/Tenant/Schema/CreateDirectoryDialog/CreateDirectoryDialog.js +2 -2
  110. package/dist/containers/Tenant/Schema/SchemaTree/SchemaTree.js +2 -2
  111. package/dist/containers/Tenant/Schema/SchemaViewer/SchemaViewer.js +1 -1
  112. package/dist/containers/Tenant/Tenant.js +1 -1
  113. package/dist/containers/Tenant/TenantPages.d.ts +12 -1
  114. package/dist/containers/Tenant/TenantPages.js +1 -1
  115. package/dist/containers/Tenant/i18n/en.json +2 -2
  116. package/dist/containers/Tenant/i18n/index.d.ts +1 -1
  117. package/dist/containers/Tenant/utils/schema.js +1 -1
  118. package/dist/containers/Tenants/Tenants.js +1 -1
  119. package/dist/containers/Tenants/Tenants.scss +0 -4
  120. package/dist/containers/UserSettings/i18n/en.json +2 -0
  121. package/dist/containers/UserSettings/i18n/index.d.ts +1 -1
  122. package/dist/containers/UserSettings/settings.d.ts +1 -0
  123. package/dist/containers/UserSettings/settings.js +6 -1
  124. package/dist/routes.js +2 -2
  125. package/dist/services/api.d.ts +39 -21
  126. package/dist/services/api.js +45 -56
  127. package/dist/services/settings.d.ts +1 -0
  128. package/dist/services/settings.js +2 -1
  129. package/dist/store/configureStore.d.ts +4 -4
  130. package/dist/store/defaultStore.d.ts +2 -2
  131. package/dist/store/reducers/api.d.ts +1 -1
  132. package/dist/store/reducers/api.js +1 -1
  133. package/dist/store/reducers/cluster/cluster.d.ts +2 -2
  134. package/dist/store/reducers/clusterNodes/clusterNodes.d.ts +2 -2
  135. package/dist/store/reducers/clusters/clusters.d.ts +2 -2
  136. package/dist/store/reducers/describe.d.ts +5 -2
  137. package/dist/store/reducers/describe.js +2 -2
  138. package/dist/store/reducers/executeQuery.d.ts +2 -2
  139. package/dist/store/reducers/executeTopQueries/executeTopQueries.d.ts +2 -2
  140. package/dist/store/reducers/executeTopQueries/executeTopQueries.js +19 -14
  141. package/dist/store/reducers/executeTopQueries/types.d.ts +2 -2
  142. package/dist/store/reducers/executeTopQueries/utils.js +11 -7
  143. package/dist/store/reducers/explainQuery/explainQuery.d.ts +2 -2
  144. package/dist/store/reducers/explainQuery/explainQuery.js +6 -1
  145. package/dist/store/reducers/healthcheckInfo/healthcheckInfo.d.ts +58 -58
  146. package/dist/store/reducers/heatmap.d.ts +2 -2
  147. package/dist/store/reducers/heatmap.js +3 -3
  148. package/dist/store/reducers/hotKeys/hotKeys.d.ts +3 -2
  149. package/dist/store/reducers/hotKeys/hotKeys.js +3 -3
  150. package/dist/store/reducers/index.d.ts +3 -3
  151. package/dist/store/reducers/network/network.d.ts +2 -2
  152. package/dist/store/reducers/network/network.js +1 -1
  153. package/dist/store/reducers/node/node.d.ts +3 -3
  154. package/dist/store/reducers/node/selectors.d.ts +1 -1
  155. package/dist/store/reducers/node/selectors.js +2 -2
  156. package/dist/store/reducers/nodes/nodes.d.ts +3 -3
  157. package/dist/store/reducers/nodesList.d.ts +3 -3
  158. package/dist/store/reducers/overview/overview.d.ts +5 -2
  159. package/dist/store/reducers/overview/overview.js +2 -2
  160. package/dist/store/reducers/partitions/partitions.d.ts +2 -2
  161. package/dist/store/reducers/pdisk/pdisk.d.ts +3 -3
  162. package/dist/store/reducers/pdisk/pdisk.js +15 -2
  163. package/dist/store/reducers/pdisk/types.d.ts +17 -1
  164. package/dist/store/reducers/pdisk/utils.d.ts +2 -2
  165. package/dist/store/reducers/pdisk/utils.js +68 -8
  166. package/dist/store/reducers/preview.d.ts +2 -2
  167. package/dist/store/reducers/preview.js +1 -1
  168. package/dist/store/reducers/queryActions/types.d.ts +1 -1
  169. package/dist/store/reducers/schema/schema.d.ts +28 -10
  170. package/dist/store/reducers/schema/schema.js +11 -12
  171. package/dist/store/reducers/schemaAcl/schemaAcl.d.ts +4 -2
  172. package/dist/store/reducers/schemaAcl/schemaAcl.js +9 -3
  173. package/dist/store/reducers/shardsWorkload/shardsWorkload.d.ts +2 -2
  174. package/dist/store/reducers/shardsWorkload/shardsWorkload.js +22 -6
  175. package/dist/store/reducers/shardsWorkload/types.d.ts +2 -2
  176. package/dist/store/reducers/storage/storage.d.ts +3 -3
  177. package/dist/store/reducers/tablet.d.ts +3 -3
  178. package/dist/store/reducers/tablets.d.ts +13 -13
  179. package/dist/store/reducers/tabletsFilters.d.ts +1 -1
  180. package/dist/store/reducers/tenant/tenant.d.ts +2 -2
  181. package/dist/store/reducers/tenantOverview/executeTopTables/executeTopTables.d.ts +2 -2
  182. package/dist/store/reducers/tenantOverview/executeTopTables/executeTopTables.js +1 -1
  183. package/dist/store/reducers/tenantOverview/topNodes/topNodes.d.ts +2 -2
  184. package/dist/store/reducers/tenantOverview/topShards/tenantOverviewTopShards.d.ts +2 -2
  185. package/dist/store/reducers/tenantOverview/topShards/tenantOverviewTopShards.js +1 -1
  186. package/dist/store/reducers/tenantOverview/topStorageGroups/topStorageGroups.d.ts +2 -2
  187. package/dist/store/reducers/tenants/selectors.d.ts +27 -27
  188. package/dist/store/reducers/tenants/tenants.d.ts +2 -2
  189. package/dist/store/reducers/topic.d.ts +44 -44
  190. package/dist/store/reducers/vdisk/vdisk.d.ts +2 -2
  191. package/dist/store/reducers/vdisk/vdisk.js +1 -1
  192. package/dist/store/reducers/viewSchema/viewSchema.d.ts +2 -2
  193. package/dist/store/reducers/viewSchema/viewSchema.js +1 -1
  194. package/dist/store/state-url-mapping.d.ts +70 -0
  195. package/dist/store/state-url-mapping.js +1 -5
  196. package/dist/styles/mixins.scss +11 -0
  197. package/dist/types/api/acl.d.ts +1 -0
  198. package/dist/types/api/pdisk.d.ts +65 -2
  199. package/dist/types/api/vdisk.d.ts +33 -2
  200. package/dist/types/common.d.ts +3 -0
  201. package/dist/types/store/heatmap.d.ts +1 -0
  202. package/dist/types/store/query.d.ts +4 -1
  203. package/dist/utils/constants.d.ts +1 -0
  204. package/dist/utils/constants.js +1 -0
  205. package/dist/utils/dataFormatters/dataFormatters.d.ts +0 -4
  206. package/dist/utils/dataFormatters/dataFormatters.js +2 -8
  207. package/dist/utils/developerUI/developerUI.d.ts +1 -0
  208. package/dist/utils/developerUI/developerUI.js +3 -0
  209. package/dist/utils/disks/getPDiskType.d.ts +3 -3
  210. package/dist/utils/disks/helpers.d.ts +1 -0
  211. package/dist/utils/disks/helpers.js +3 -0
  212. package/dist/utils/disks/prepareDisks.d.ts +2 -2
  213. package/dist/utils/disks/prepareDisks.js +17 -22
  214. package/dist/utils/disks/types.d.ts +7 -5
  215. package/dist/utils/monaco/constats.d.ts +2 -0
  216. package/dist/utils/monaco/constats.js +2 -0
  217. package/dist/utils/monaco/yql/constants.d.ts +0 -1
  218. package/dist/utils/monaco/yql/constants.js +0 -1
  219. package/dist/utils/monaco/yql/yql.completionItemProvider.js +2 -2
  220. package/dist/utils/query.d.ts +24 -1
  221. package/dist/utils/query.js +40 -0
  222. package/package.json +5 -1
  223. package/dist/components/DeveloperUiLink/DeveloperUiLink.d.ts +0 -8
  224. package/dist/components/NodeHostWrapper/NodeHostWrapper.scss +0 -15
  225. package/dist/containers/Node/NodeStructure/Vdisk.d.ts +0 -6
  226. package/dist/containers/Node/NodeStructure/Vdisk.js +0 -13
  227. package/dist/containers/PDiskPage/PDiskGroups.d.ts +0 -9
  228. package/dist/containers/PDiskPage/PDiskGroups.js +0 -20
  229. package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/i18n/ru.json +0 -5
  230. package/dist/store/reducers/tenantOverview/topQueries/tenantOverviewTopQueries.d.ts +0 -5
  231. package/dist/store/reducers/tenantOverview/topQueries/tenantOverviewTopQueries.js +0 -38
  232. package/dist/utils/monaco/index.d.ts +0 -1
  233. package/dist/utils/monaco/index.js +0 -6
  234. package/dist/utils/monaco/s-expression/constants.d.ts +0 -1
  235. package/dist/utils/monaco/s-expression/constants.js +0 -1
  236. package/dist/utils/monaco/s-expression/registerLanguage.d.ts +0 -1
  237. package/dist/utils/monaco/s-expression/registerLanguage.js +0 -59
  238. package/dist/utils/monaco/yql/registerLanguage.d.ts +0 -1
  239. package/dist/utils/monaco/yql/registerLanguage.js +0 -8
  240. package/dist/utils/monaco/yql/yql.d.ts +0 -7
  241. package/dist/utils/monaco/yql/yql.js +0 -180
  242. package/dist/utils/monaco/yql/yql.keywords.d.ts +0 -3
  243. package/dist/utils/monaco/yql/yql.keywords.js +0 -3
@@ -78,13 +78,13 @@ function Diagnostics(props) {
78
78
  return _jsx(Network, { tenantName: tenantName });
79
79
  }
80
80
  case TENANT_DIAGNOSTICS_TABS_IDS.describe: {
81
- return _jsx(Describe, { path: path, type: type });
81
+ return _jsx(Describe, { path: path, database: tenantName, type: type });
82
82
  }
83
83
  case TENANT_DIAGNOSTICS_TABS_IDS.hotKeys: {
84
- return _jsx(HotKeys, { path: path });
84
+ return _jsx(HotKeys, { path: path, database: tenantName });
85
85
  }
86
86
  case TENANT_DIAGNOSTICS_TABS_IDS.graph: {
87
- return _jsx(Heatmap, { path: path });
87
+ return _jsx(Heatmap, { path: path, database: tenantName });
88
88
  }
89
89
  case TENANT_DIAGNOSTICS_TABS_IDS.consumers: {
90
90
  return _jsx(Consumers, { path: path, type: type });
@@ -1,3 +1,5 @@
1
+ @import '../../../styles/mixins.scss';
2
+
1
3
  .kv-tenant-diagnostics {
2
4
  display: flex;
3
5
  overflow: hidden;
@@ -16,7 +18,7 @@
16
18
  justify-content: space-between;
17
19
  align-items: center;
18
20
 
19
- box-shadow: inset 0 -1px 0 0 var(--g-color-line-generic);
21
+ @include tabs-wrapper-styles();
20
22
  & .g-tabs_direction_horizontal {
21
23
  box-shadow: unset;
22
24
  }
@@ -1,6 +1,7 @@
1
1
  import './HotKeys.scss';
2
2
  interface HotKeysProps {
3
+ database: string;
3
4
  path: string;
4
5
  }
5
- export declare function HotKeys({ path }: HotKeysProps): import("react/jsx-runtime").JSX.Element;
6
+ export declare function HotKeys({ path, database }: HotKeysProps): import("react/jsx-runtime").JSX.Element;
6
7
  export {};
@@ -37,11 +37,11 @@ const getHotKeysColumns = (keyColumnsIds = []) => {
37
37
  },
38
38
  ];
39
39
  };
40
- export function HotKeys({ path }) {
40
+ export function HotKeys({ path, database }) {
41
41
  var _a, _b;
42
- const { currentData: data, isFetching, error } = hotKeysApi.useGetHotKeysQuery({ path });
42
+ const { currentData: data, isFetching, error } = hotKeysApi.useGetHotKeysQuery({ path, database });
43
43
  const loading = isFetching && data === undefined;
44
- const { data: schemaData, isLoading: schemaLoading } = useGetSchemaQuery({ path });
44
+ const { data: schemaData, isLoading: schemaLoading } = useGetSchemaQuery({ path, database });
45
45
  const keyColumnsIds = (_b = (_a = schemaData === null || schemaData === void 0 ? void 0 : schemaData.PathDescription) === null || _a === void 0 ? void 0 : _a.Table) === null || _b === void 0 ? void 0 : _b.KeyColumnNames;
46
46
  const tableColumns = React.useMemo(() => {
47
47
  return getHotKeysColumns(keyColumnsIds);
@@ -3,6 +3,7 @@ import { EPathType } from '../../../../types/api/schema';
3
3
  interface OverviewProps {
4
4
  type?: EPathType;
5
5
  path: string;
6
+ database: string;
6
7
  }
7
- declare function Overview({ type, path }: OverviewProps): string | number | true | Iterable<React.ReactNode> | import("react/jsx-runtime").JSX.Element;
8
+ declare function Overview({ type, path, database }: OverviewProps): string | number | true | Iterable<React.ReactNode> | import("react/jsx-runtime").JSX.Element;
8
9
  export default Overview;
@@ -16,24 +16,24 @@ import { AsyncReplicationInfo } from './AsyncReplicationInfo';
16
16
  import { ChangefeedInfo } from './ChangefeedInfo';
17
17
  import { TableInfo } from './TableInfo';
18
18
  import { TopicInfo } from './TopicInfo';
19
- function Overview({ type, path }) {
19
+ function Overview({ type, path, database }) {
20
20
  const [autoRefreshInterval] = useAutoRefreshInterval();
21
21
  const isEntityWithMergedImpl = isEntityWithMergedImplementation(type);
22
22
  // shallowEqual prevents rerenders when new schema data is loaded
23
- const mergedChildrenPaths = useTypedSelector((state) => selectSchemaMergedChildrenPaths(state, path, type), shallowEqual);
24
- let paths = skipToken;
23
+ const mergedChildrenPaths = useTypedSelector((state) => selectSchemaMergedChildrenPaths(state, path, type, database), shallowEqual);
24
+ let paths = [];
25
25
  if (!isEntityWithMergedImpl) {
26
26
  paths = [path];
27
27
  }
28
28
  else if (mergedChildrenPaths) {
29
29
  paths = [path, ...mergedChildrenPaths];
30
30
  }
31
- const { currentData, isFetching, error: overviewError, } = overviewApi.useGetOverviewQuery(paths, {
31
+ const { currentData, isFetching, error: overviewError, } = overviewApi.useGetOverviewQuery(paths.length ? { paths, database } : skipToken, {
32
32
  pollingInterval: autoRefreshInterval,
33
33
  });
34
34
  const overviewLoading = isFetching && currentData === undefined;
35
35
  const { data: rawData, additionalData } = currentData || {};
36
- const { error: schemaError } = useGetSchemaQuery({ path });
36
+ const { error: schemaError } = useGetSchemaQuery({ path, database });
37
37
  const entityLoading = overviewLoading;
38
38
  const entityNotReady = isEntityWithMergedImpl && !mergedChildrenPaths;
39
39
  const renderContent = () => {
@@ -1,5 +1,18 @@
1
1
  {
2
2
  "tableStats": "Table Stats",
3
3
  "tabletMetrics": "Tablet Metrics",
4
- "partitionConfig": "Partition Config"
4
+ "partitionConfig": "Partition Config",
5
+ "label.ttl": "TTL for rows",
6
+ "value.ttl": "column: '{{columnName}}', expire after: {{expireTime}}",
7
+ "label.standalone": "Standalone",
8
+ "label.partitioning": "Partitioning",
9
+ "label.partitioning-by-size": "Partitioning by size",
10
+ "value.partitioning-by-size.enabled": "Enabled, split size: {{size}}",
11
+ "label.partitioning-by-load": "Partitioning by load",
12
+ "label.partitions-min": "Min number of partitions",
13
+ "label.partitions-max": "Max number of partitions",
14
+ "label.read-replicas": "Read replicas (followers)",
15
+ "label.bloom-filter": "Bloom filter",
16
+ "enabled": "Enabled",
17
+ "disabled": "Disabled"
5
18
  }
@@ -1,2 +1,2 @@
1
- declare const _default: (key: "tableStats" | "tabletMetrics" | "partitionConfig", params?: import("@gravity-ui/i18n").Params) => string;
1
+ declare const _default: (key: "disabled" | "tableStats" | "tabletMetrics" | "partitionConfig" | "label.ttl" | "value.ttl" | "label.standalone" | "label.partitioning" | "label.partitioning-by-size" | "value.partitioning-by-size.enabled" | "label.partitioning-by-load" | "label.partitions-min" | "label.partitions-max" | "label.read-replicas" | "label.bloom-filter" | "enabled", params?: import("@gravity-ui/i18n").Params) => string;
2
2
  export default _default;
@@ -1,5 +1,4 @@
1
1
  import { registerKeysets } from '../../../../../../utils/i18n';
2
2
  import en from './en.json';
3
- import ru from './ru.json';
4
3
  const COMPONENT = 'ydb-diagnostics-overview-table-info';
5
- export default registerKeysets(COMPONENT, { ru, en });
4
+ export default registerKeysets(COMPONENT, { en });
@@ -1,8 +1,12 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Text } from '@gravity-ui/uikit';
3
+ import omit from 'lodash/omit';
1
4
  import { formatObject } from '../../../../../components/InfoViewer';
2
5
  import { formatFollowerGroupItem, formatPartitionConfigItem, formatTableStatsItem, formatTabletMetricsItem, } from '../../../../../components/InfoViewer/formatters';
3
6
  import { EPathType } from '../../../../../types/api/schema';
4
7
  import { formatBytes, formatNumber } from '../../../../../utils/dataFormatters/dataFormatters';
5
8
  import { formatDurationToShortTimeFormat } from '../../../../../utils/timeParsers';
9
+ import i18n from './i18n';
6
10
  const isInStoreColumnTable = (table) => {
7
11
  // SchemaPresetId could be 0
8
12
  return table.SchemaPresetName && table.SchemaPresetId !== undefined;
@@ -10,19 +14,28 @@ const isInStoreColumnTable = (table) => {
10
14
  const prepareTTL = (ttl) => {
11
15
  // ExpireAfterSeconds could be 0
12
16
  if (ttl.Enabled && ttl.Enabled.ColumnName && ttl.Enabled.ExpireAfterSeconds !== undefined) {
13
- const value = `column: '${ttl.Enabled.ColumnName}', expire after: ${formatDurationToShortTimeFormat(ttl.Enabled.ExpireAfterSeconds * 1000, 1)}`;
14
- return { label: 'TTL for rows', value };
17
+ const value = i18n('value.ttl', {
18
+ columnName: ttl.Enabled.ColumnName,
19
+ expireTime: formatDurationToShortTimeFormat(ttl.Enabled.ExpireAfterSeconds * 1000, 1),
20
+ });
21
+ return { label: i18n('label.ttl'), value };
15
22
  }
16
23
  return undefined;
17
24
  };
18
25
  function prepareColumnTableGeneralInfo(columnTable) {
26
+ var _a, _b;
19
27
  const columnTableGeneralInfo = [];
20
28
  columnTableGeneralInfo.push({
21
- label: 'Standalone',
29
+ label: i18n('label.standalone'),
22
30
  value: String(!isInStoreColumnTable(columnTable)),
23
31
  });
24
- if (columnTable.Sharding && columnTable.Sharding.HashSharding) {
25
- columnTableGeneralInfo.push({ label: 'Sharding', value: 'hash' });
32
+ if ((_b = (_a = columnTable.Sharding) === null || _a === void 0 ? void 0 : _a.HashSharding) === null || _b === void 0 ? void 0 : _b.Columns) {
33
+ const columns = columnTable.Sharding.HashSharding.Columns.join(', ');
34
+ const content = `PARTITION BY HASH(${columns})`;
35
+ columnTableGeneralInfo.push({
36
+ label: i18n('label.partitioning'),
37
+ value: (_jsx(Text, { variant: "code-2", wordBreak: "break-word", children: content })),
38
+ });
26
39
  }
27
40
  if (columnTable.TtlSettings) {
28
41
  const ttlInfo = prepareTTL(columnTable === null || columnTable === void 0 ? void 0 : columnTable.TtlSettings);
@@ -37,18 +50,20 @@ const prepareTableGeneralInfo = (PartitionConfig, TTLSettings) => {
37
50
  const { PartitioningPolicy = {}, FollowerGroups, EnableFilterByKey } = PartitionConfig;
38
51
  const generalTableInfo = [];
39
52
  const partitioningBySize = PartitioningPolicy.SizeToSplit && Number(PartitioningPolicy.SizeToSplit) > 0
40
- ? `Enabled, split size: ${formatBytes(PartitioningPolicy.SizeToSplit)}`
41
- : 'Disabled';
53
+ ? i18n('value.partitioning-by-size.enabled', {
54
+ size: formatBytes(PartitioningPolicy.SizeToSplit),
55
+ })
56
+ : i18n('disabled');
42
57
  const partitioningByLoad = ((_a = PartitioningPolicy.SplitByLoadSettings) === null || _a === void 0 ? void 0 : _a.Enabled)
43
- ? 'Enabled'
44
- : 'Disabled';
45
- generalTableInfo.push({ label: 'Partitioning by size', value: partitioningBySize }, { label: 'Partitioning by load', value: partitioningByLoad }, {
46
- label: 'Min number of partitions',
58
+ ? i18n('enabled')
59
+ : i18n('disabled');
60
+ generalTableInfo.push({ label: i18n('label.partitioning-by-size'), value: partitioningBySize }, { label: i18n('label.partitioning-by-load'), value: partitioningByLoad }, {
61
+ label: i18n('label.partitions-min'),
47
62
  value: formatNumber(PartitioningPolicy.MinPartitionsCount || 0),
48
63
  });
49
64
  if (PartitioningPolicy.MaxPartitionsCount) {
50
65
  generalTableInfo.push({
51
- label: 'Max number of partitions',
66
+ label: i18n('label.partitions-max'),
52
67
  value: formatNumber(PartitioningPolicy.MaxPartitionsCount),
53
68
  });
54
69
  }
@@ -61,7 +76,7 @@ const prepareTableGeneralInfo = (PartitionConfig, TTLSettings) => {
61
76
  else {
62
77
  readReplicasConfig = `ANY_AZ: ${FollowerCount}`;
63
78
  }
64
- generalTableInfo.push({ label: 'Read replicas (followers)', value: readReplicasConfig });
79
+ generalTableInfo.push({ label: i18n('label.read-replicas'), value: readReplicasConfig });
65
80
  }
66
81
  if (TTLSettings) {
67
82
  const ttlInfo = prepareTTL(TTLSettings);
@@ -70,8 +85,8 @@ const prepareTableGeneralInfo = (PartitionConfig, TTLSettings) => {
70
85
  }
71
86
  }
72
87
  generalTableInfo.push({
73
- label: 'Bloom filter',
74
- value: EnableFilterByKey ? 'Enabled' : 'Disabled',
88
+ label: i18n('label.bloom-filter'),
89
+ value: EnableFilterByKey ? i18n('enabled') : i18n('disabled'),
75
90
  });
76
91
  return generalTableInfo;
77
92
  };
@@ -122,8 +137,12 @@ export const prepareTableInfo = (data, type) => {
122
137
  RangeReadRows,
123
138
  }),
124
139
  ];
125
- //@ts-expect-error
126
- const tabletMetricsInfo = formatObject(formatTabletMetricsItem, TabletMetrics);
140
+ const tabletMetricsInfo = formatObject(formatTabletMetricsItem, omit(TabletMetrics, [
141
+ 'GroupReadIops',
142
+ 'GroupReadThroughput',
143
+ 'GroupWriteIops',
144
+ 'GroupWriteThroughput',
145
+ ]));
127
146
  let partitionConfigInfo = [];
128
147
  if (Array.isArray(FollowerGroups) && FollowerGroups.length > 0) {
129
148
  partitionConfigInfo = formatObject(formatFollowerGroupItem, FollowerGroups[0]);
@@ -3,12 +3,12 @@ import React from 'react';
3
3
  import { useHistory, useLocation } from 'react-router-dom';
4
4
  import { parseQuery } from '../../../../../routes';
5
5
  import { changeUserInput } from '../../../../../store/reducers/executeQuery';
6
+ import { setTopQueriesFilters, topQueriesApi, } from '../../../../../store/reducers/executeTopQueries/executeTopQueries';
6
7
  import { TENANT_DIAGNOSTICS_TABS_IDS, TENANT_PAGE, TENANT_PAGES_IDS, TENANT_QUERY_TABS_ID, } from '../../../../../store/reducers/tenant/constants';
7
- import { topQueriesApi } from '../../../../../store/reducers/tenantOverview/topQueries/tenantOverviewTopQueries';
8
8
  import { useAutoRefreshInterval, useTypedDispatch } from '../../../../../utils/hooks';
9
9
  import { parseQueryErrorToString } from '../../../../../utils/query';
10
10
  import { TenantTabsGroups, getTenantPath } from '../../../TenantPages';
11
- import { TOP_QUERIES_COLUMNS_WIDTH_LS_KEY, getTenantOverviewTopQueriesColumns, } from '../../TopQueries/getTopQueriesColumns';
11
+ import { TENANT_OVERVIEW_TOP_QUERUES_COLUMNS, TOP_QUERIES_COLUMNS_WIDTH_LS_KEY, } from '../../TopQueries/getTopQueriesColumns';
12
12
  import { TenantOverviewTableLayout } from '../TenantOverviewTableLayout';
13
13
  import { getSectionTitle } from '../getSectionTitle';
14
14
  import i18n from '../i18n';
@@ -19,8 +19,8 @@ export function TopQueries({ tenantName }) {
19
19
  const history = useHistory();
20
20
  const query = parseQuery(location);
21
21
  const [autoRefreshInterval] = useAutoRefreshInterval();
22
- const columns = getTenantOverviewTopQueriesColumns();
23
- const { currentData, isFetching, error } = topQueriesApi.useGetOverviewTopQueriesQuery({ database: tenantName }, { pollingInterval: autoRefreshInterval });
22
+ const columns = TENANT_OVERVIEW_TOP_QUERUES_COLUMNS;
23
+ const { currentData, isFetching, error } = topQueriesApi.useGetTopQueriesQuery({ database: tenantName }, { pollingInterval: autoRefreshInterval });
24
24
  const loading = isFetching && currentData === undefined;
25
25
  const { result: data } = currentData || {};
26
26
  const handleRowClick = React.useCallback((row) => {
@@ -36,7 +36,10 @@ export function TopQueries({ tenantName }) {
36
36
  }, [dispatch, history, location]);
37
37
  const title = getSectionTitle({
38
38
  entity: i18n('queries'),
39
- postfix: i18n('by-cpu-time'),
39
+ postfix: i18n('by-cpu-time', { executionPeriod: i18n('executed-last-hour') }),
40
+ onClick: () => {
41
+ dispatch(setTopQueriesFilters({ from: undefined, to: undefined }));
42
+ },
40
43
  link: getTenantPath({
41
44
  ...query,
42
45
  [TenantTabsGroups.diagnosticsTab]: TENANT_DIAGNOSTICS_TABS_IDS.topQueries,
@@ -27,7 +27,7 @@ export function TenantOverview({ tenantName, additionalTenantProps, additionalNo
27
27
  const { Name, Type, Overall } = tenant || {};
28
28
  const tenantType = mapDatabaseTypeToDBName(Type);
29
29
  // FIXME: remove after correct data is added to tenantInfo
30
- const { data: tenantSchemaData } = useGetSchemaQuery({ path: tenantName });
30
+ const { data: tenantSchemaData } = useGetSchemaQuery({ path: tenantName, database: tenantName });
31
31
  const { Tables, Topics } = ((_b = (_a = tenantSchemaData === null || tenantSchemaData === void 0 ? void 0 : tenantSchemaData.PathDescription) === null || _a === void 0 ? void 0 : _a.DomainDescription) === null || _b === void 0 ? void 0 : _b.DiskSpaceUsage) || {};
32
32
  const usedTabletStorage = [
33
33
  Tables === null || Tables === void 0 ? void 0 : Tables.TotalSize,
@@ -3,6 +3,7 @@ interface GetSectionTitleParams {
3
3
  postfix: string;
4
4
  prefix?: string;
5
5
  link?: string;
6
+ onClick?: () => void;
6
7
  }
7
- export declare const getSectionTitle: ({ prefix, entity, postfix, link, }: GetSectionTitleParams) => string | import("react/jsx-runtime").JSX.Element;
8
+ export declare const getSectionTitle: ({ prefix, entity, postfix, link, onClick, }: GetSectionTitleParams) => string | import("react/jsx-runtime").JSX.Element;
8
9
  export {};
@@ -3,9 +3,9 @@ import React from 'react';
3
3
  import { InternalLink } from '../../../../components/InternalLink/InternalLink';
4
4
  import i18n from './i18n';
5
5
  // Titles are formed by the principle "Top entities by parameter"
6
- export const getSectionTitle = ({ prefix = i18n('top'), entity, postfix, link, }) => {
6
+ export const getSectionTitle = ({ prefix = i18n('top'), entity, postfix, link, onClick, }) => {
7
7
  if (link) {
8
- return (_jsxs(React.Fragment, { children: [prefix, " ", _jsx(InternalLink, { to: link, children: entity }), " ", postfix] }));
8
+ return (_jsxs(React.Fragment, { children: [prefix, ' ', _jsx(InternalLink, { to: link, onClick: onClick, children: entity }), ' ', postfix] }));
9
9
  }
10
10
  return `${prefix} ${entity} ${postfix}`;
11
11
  };
@@ -10,7 +10,7 @@
10
10
  "queries": "queries",
11
11
  "tables": "tables",
12
12
  "by-pools-usage": "by pools usage",
13
- "by-cpu-time": "by cpu time",
13
+ "by-cpu-time": "by cpu time, {{executionPeriod}}",
14
14
  "by-cpu-usage": "by cpu usage",
15
15
  "by-load": "by load",
16
16
  "by-memory": "by memory",
@@ -27,5 +27,6 @@
27
27
  "storage.tablet-storage-title": "Tablet storage",
28
28
  "storage.tablet-storage-description": "Size of user data and indexes stored in schema objects (tables, topics, etc.)",
29
29
  "storage.db-storage-title": "Database storage",
30
- "storage.db-storage-description": "Size of data stored in distributed storage with all overheads for redundancy"
30
+ "storage.db-storage-description": "Size of data stored in distributed storage with all overheads for redundancy",
31
+ "executed-last-hour": "executed in the last hour"
31
32
  }
@@ -1,2 +1,2 @@
1
- declare const _default: (key: "nodes" | "queries" | "groups" | "no-data" | "top" | "shards" | "tables" | "no-pools-data" | "top-nodes.empty-data" | "top-groups.empty-data" | "by-pools-usage" | "by-cpu-time" | "by-cpu-usage" | "by-load" | "by-memory" | "by-usage" | "by-size" | "cards.cpu-label" | "cards.storage-label" | "cards.memory-label" | "charts.queries-per-second" | "charts.transaction-latency" | "charts.cpu-usage" | "charts.storage-usage" | "charts.memory-usage" | "storage.tablet-storage-title" | "storage.tablet-storage-description" | "storage.db-storage-title" | "storage.db-storage-description", params?: import("@gravity-ui/i18n").Params) => string;
1
+ declare const _default: (key: "nodes" | "queries" | "groups" | "no-data" | "top" | "shards" | "tables" | "no-pools-data" | "top-nodes.empty-data" | "top-groups.empty-data" | "by-pools-usage" | "by-cpu-time" | "by-cpu-usage" | "by-load" | "by-memory" | "by-usage" | "by-size" | "cards.cpu-label" | "cards.storage-label" | "cards.memory-label" | "charts.queries-per-second" | "charts.transaction-latency" | "charts.cpu-usage" | "charts.storage-usage" | "charts.memory-usage" | "storage.tablet-storage-title" | "storage.tablet-storage-description" | "storage.db-storage-title" | "storage.db-storage-description" | "executed-last-hour", params?: import("@gravity-ui/i18n").Params) => string;
2
2
  export default _default;
@@ -16,7 +16,7 @@ import { parseQueryErrorToString } from '../../../../utils/query';
16
16
  import { TenantTabsGroups, getTenantPath } from '../../TenantPages';
17
17
  import { QUERY_TABLE_SETTINGS } from '../../utils/constants';
18
18
  import { isColumnEntityType } from '../../utils/schema';
19
- import { TOP_QUERIES_COLUMNS_WIDTH_LS_KEY, getTopQueriesColumns } from './getTopQueriesColumns';
19
+ import { TOP_QUERIES_COLUMNS, TOP_QUERIES_COLUMNS_WIDTH_LS_KEY } from './getTopQueriesColumns';
20
20
  import i18n from './i18n';
21
21
  import './TopQueries.scss';
22
22
  const b = cn('kv-top-queries');
@@ -32,7 +32,7 @@ export const TopQueries = ({ tenantName, type }) => {
32
32
  }, { pollingInterval: autoRefreshInterval });
33
33
  const loading = isFetching && currentData === undefined;
34
34
  const { result: data } = currentData || {};
35
- const rawColumns = getTopQueriesColumns();
35
+ const rawColumns = TOP_QUERIES_COLUMNS;
36
36
  const columns = rawColumns.map((column) => ({
37
37
  ...column,
38
38
  sortable: isSortableTopQueriesProperty(column.name),
@@ -2,5 +2,5 @@ import type { Column } from '@gravity-ui/react-data-table';
2
2
  import type { KeyValueRow } from '../../../../types/api/query';
3
3
  import './TopQueries.scss';
4
4
  export declare const TOP_QUERIES_COLUMNS_WIDTH_LS_KEY = "topQueriesColumnsWidth";
5
- export declare const getTopQueriesColumns: () => Column<KeyValueRow>[];
6
- export declare const getTenantOverviewTopQueriesColumns: () => Column<KeyValueRow>[];
5
+ export declare const TOP_QUERIES_COLUMNS: Column<KeyValueRow>[];
6
+ export declare const TENANT_OVERVIEW_TOP_QUERUES_COLUMNS: Column<KeyValueRow>[];
@@ -75,17 +75,17 @@ const durationColumn = {
75
75
  align: DataTable.RIGHT,
76
76
  width: 150,
77
77
  };
78
- export const getTopQueriesColumns = () => {
79
- return [
80
- cpuTimeUsColumn,
81
- queryTextColumn,
82
- endTimeColumn,
83
- durationColumn,
84
- readRowsColumn,
85
- readBytesColumn,
86
- userSIDColumn,
87
- ];
88
- };
89
- export const getTenantOverviewTopQueriesColumns = () => {
90
- return [queryHashColumn, oneLineQueryTextColumn, cpuTimeUsColumn];
91
- };
78
+ export const TOP_QUERIES_COLUMNS = [
79
+ cpuTimeUsColumn,
80
+ queryTextColumn,
81
+ endTimeColumn,
82
+ durationColumn,
83
+ readRowsColumn,
84
+ readBytesColumn,
85
+ userSIDColumn,
86
+ ];
87
+ export const TENANT_OVERVIEW_TOP_QUERUES_COLUMNS = [
88
+ queryHashColumn,
89
+ oneLineQueryTextColumn,
90
+ cpuTimeUsColumn,
91
+ ];
@@ -7,7 +7,7 @@ import { TableWithControlsLayout } from '../../../../components/TableWithControl
7
7
  import { setShardsQueryFilters, shardApi, } from '../../../../store/reducers/shardsWorkload/shardsWorkload';
8
8
  import { EShardsWorkloadMode } from '../../../../store/reducers/shardsWorkload/types';
9
9
  import { cn } from '../../../../utils/cn';
10
- import { DEFAULT_TABLE_SETTINGS, HOUR_IN_SECONDS } from '../../../../utils/constants';
10
+ import { DEFAULT_TABLE_SETTINGS } from '../../../../utils/constants';
11
11
  import { formatDateTime } from '../../../../utils/dataFormatters/dataFormatters';
12
12
  import { TOP_SHARD_COLUMNS_IDS, isSortableTopShardsProperty } from '../../../../utils/diagnostics';
13
13
  import { useAutoRefreshInterval, useTypedDispatch, useTypedSelector } from '../../../../utils/hooks';
@@ -52,8 +52,8 @@ function dataTableToStringSortOrder(value = []) {
52
52
  return sortOrders.map(({ columnId }) => columnId).join(',');
53
53
  }
54
54
  function fillDateRangeFor(value) {
55
- value.to = Date.now();
56
- value.from = value.to - HOUR_IN_SECONDS * 1000;
55
+ value.to = 'now';
56
+ value.from = 'now-1h';
57
57
  return value;
58
58
  }
59
59
  export const TopShards = ({ tenantName, path, type }) => {
@@ -1,14 +1,14 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
2
  import DataTable from '@gravity-ui/react-data-table';
3
- import { DeveloperUiLink } from '../../../../components/DeveloperUiLink/DeveloperUiLink';
3
+ import { DeveloperUILinkButton } from '../../../../components/DeveloperUILinkButton/DeveloperUILinkButton';
4
4
  import { EntityStatus } from '../../../../components/EntityStatus/EntityStatus';
5
5
  import { InternalLink } from '../../../../components/InternalLink';
6
6
  import { LinkToSchemaObject } from '../../../../components/LinkToSchemaObject/LinkToSchemaObject';
7
7
  import { UsageLabel } from '../../../../components/UsageLabel/UsageLabel';
8
8
  import routes, { createHref } from '../../../../routes';
9
- import { backend } from '../../../../store';
10
9
  import { getLoadSeverityForShard } from '../../../../store/reducers/tenantOverview/topShards/utils';
11
10
  import { formatNumber, roundToPrecision } from '../../../../utils/dataFormatters/dataFormatters';
11
+ import { createTabletDeveloperUIHref } from '../../../../utils/developerUI/developerUI';
12
12
  import { getDefaultNodePath } from '../../../Node/NodePages';
13
13
  export const TOP_SHARDS_COLUMNS_WIDTH_LS_KEY = 'topShardsColumnsWidth';
14
14
  const TOP_SHARDS_COLUMNS_IDS = {
@@ -68,10 +68,10 @@ const tabletIdColumn = {
68
68
  if (!row.TabletId) {
69
69
  return '–';
70
70
  }
71
- return (_jsx(EntityStatus, { name: (_a = row.TabletId) === null || _a === void 0 ? void 0 : _a.toString(), path: createHref(routes.tablet, { id: row.TabletId }), hasClipboardButton: true, showStatus: false, additionalControls: _jsx(DeveloperUiLink, { href: `${backend}/tablets?TabletID=${row.TabletId}` }) }));
71
+ return (_jsx(EntityStatus, { name: (_a = row.TabletId) === null || _a === void 0 ? void 0 : _a.toString(), path: createHref(routes.tablet, { id: row.TabletId }), hasClipboardButton: true, showStatus: false, additionalControls: _jsx(DeveloperUILinkButton, { href: createTabletDeveloperUIHref(row.TabletId) }) }));
72
72
  },
73
73
  sortable: false,
74
- width: 190,
74
+ width: 220,
75
75
  };
76
76
  const nodeIdColumn = {
77
77
  name: TOP_SHARDS_COLUMNS_IDS.NodeId,
@@ -8,6 +8,7 @@ import { Link, useLocation } from 'react-router-dom';
8
8
  import { StringParam, useQueryParam } from 'use-query-params';
9
9
  import { AsyncReplicationState } from '../../../components/AsyncReplicationState';
10
10
  import { ClipboardButton } from '../../../components/ClipboardButton';
11
+ import { toFormattedSize } from '../../../components/FormattedBytes/utils';
11
12
  import InfoViewer from '../../../components/InfoViewer/InfoViewer';
12
13
  import { LinkWithIcon } from '../../../components/LinkWithIcon/LinkWithIcon';
13
14
  import { Loader } from '../../../components/Loader';
@@ -19,7 +20,7 @@ import { setQueryTab, setSummaryTab, setTenantPage } from '../../../store/reduce
19
20
  import { EPathSubType, EPathType } from '../../../types/api/schema';
20
21
  import { cn } from '../../../utils/cn';
21
22
  import { DEFAULT_IS_TENANT_COMMON_INFO_COLLAPSED, DEFAULT_SIZE_TENANT_SUMMARY_KEY, } from '../../../utils/constants';
22
- import { formatDateTime, formatSecondsToHours } from '../../../utils/dataFormatters/dataFormatters';
23
+ import { formatDateTime, formatNumber, formatSecondsToHours, } from '../../../utils/dataFormatters/dataFormatters';
23
24
  import { useTypedDispatch, useTypedSelector } from '../../../utils/hooks';
24
25
  import { Acl } from '../Acl/Acl';
25
26
  import { EntityTitle } from '../EntityTitle/EntityTitle';
@@ -48,7 +49,7 @@ export function ObjectSummary({ type, subType, tenantName, path, onCollapseSumma
48
49
  const queryParams = qs.parse(location.search, {
49
50
  ignoreQueryPrefix: true,
50
51
  });
51
- const { data: currentObjectData } = useGetSchemaQuery({ path });
52
+ const { data: currentObjectData } = useGetSchemaQuery({ path, database: tenantName });
52
53
  const currentSchemaData = (_a = currentObjectData === null || currentObjectData === void 0 ? void 0 : currentObjectData.PathDescription) === null || _a === void 0 ? void 0 : _a.Self;
53
54
  React.useEffect(() => {
54
55
  const isTable = isTableType(type);
@@ -86,10 +87,33 @@ export function ObjectSummary({ type, subType, tenantName, path, onCollapseSumma
86
87
  overview.push({ label: i18n('summary.version'), value: PathVersion });
87
88
  overview.push({
88
89
  label: i18n('summary.created'),
89
- value: formatDateTime(CreateStep, ''),
90
+ value: formatDateTime(CreateStep),
90
91
  });
91
92
  const { PathDescription } = currentObjectData;
93
+ if (PathDescription === null || PathDescription === void 0 ? void 0 : PathDescription.TableStats) {
94
+ const { DataSize, RowCount } = PathDescription.TableStats;
95
+ overview.push({
96
+ label: i18n('summary.data-size'),
97
+ value: toFormattedSize(DataSize),
98
+ }, {
99
+ label: i18n('summary.row-count'),
100
+ value: formatNumber(RowCount),
101
+ });
102
+ }
92
103
  const title = _jsx(EntityTitle, { data: PathDescription });
104
+ const getDatabaseOverview = () => {
105
+ var _a, _b;
106
+ return [
107
+ {
108
+ label: i18n('summary.paths'),
109
+ value: (_a = PathDescription === null || PathDescription === void 0 ? void 0 : PathDescription.DomainDescription) === null || _a === void 0 ? void 0 : _a.PathsInside,
110
+ },
111
+ {
112
+ label: i18n('summary.shards'),
113
+ value: (_b = PathDescription === null || PathDescription === void 0 ? void 0 : PathDescription.DomainDescription) === null || _b === void 0 ? void 0 : _b.ShardsInside,
114
+ },
115
+ ];
116
+ };
93
117
  const getPathTypeOverview = {
94
118
  [EPathType.EPathTypeInvalid]: undefined,
95
119
  [EPathType.EPathTypeDir]: undefined,
@@ -102,21 +126,9 @@ export function ObjectSummary({ type, subType, tenantName, path, onCollapseSumma
102
126
  },
103
127
  ];
104
128
  },
105
- [EPathType.EPathTypeSubDomain]: undefined,
129
+ [EPathType.EPathTypeSubDomain]: getDatabaseOverview,
106
130
  [EPathType.EPathTypeTableIndex]: undefined,
107
- [EPathType.EPathTypeExtSubDomain]: () => {
108
- var _a, _b;
109
- return [
110
- {
111
- label: i18n('summary.paths'),
112
- value: (_a = PathDescription === null || PathDescription === void 0 ? void 0 : PathDescription.DomainDescription) === null || _a === void 0 ? void 0 : _a.PathsInside,
113
- },
114
- {
115
- label: i18n('summary.shards'),
116
- value: (_b = PathDescription === null || PathDescription === void 0 ? void 0 : PathDescription.DomainDescription) === null || _b === void 0 ? void 0 : _b.ShardsInside,
117
- },
118
- ];
119
- },
131
+ [EPathType.EPathTypeExtSubDomain]: getDatabaseOverview,
120
132
  [EPathType.EPathTypeColumnStore]: () => {
121
133
  var _a, _b;
122
134
  return [
@@ -212,7 +224,7 @@ export function ObjectSummary({ type, subType, tenantName, path, onCollapseSumma
212
224
  const renderTabContent = () => {
213
225
  switch (summaryTab) {
214
226
  case TENANT_SUMMARY_TABS_IDS.acl: {
215
- return _jsx(Acl, { path: path });
227
+ return _jsx(Acl, { path: path, database: tenantName });
216
228
  }
217
229
  case TENANT_SUMMARY_TABS_IDS.schema: {
218
230
  return _jsx(SchemaViewer, { type: type, path: path, tenantName: tenantName });
@@ -257,6 +269,7 @@ function ObjectTree({ tenantName, path }) {
257
269
  var _a;
258
270
  const { data: tenantData = {}, isLoading } = useGetSchemaQuery({
259
271
  path: tenantName,
272
+ database: tenantName,
260
273
  });
261
274
  const pathData = (_a = tenantData === null || tenantData === void 0 ? void 0 : tenantData.PathDescription) === null || _a === void 0 ? void 0 : _a.Self;
262
275
  const [, setCurrentPath] = useQueryParam('schema', StringParam);
@@ -12,7 +12,7 @@ import { explainVersions } from '../../../../store/reducers/explainQuery/utils';
12
12
  import { disableFullscreen } from '../../../../store/reducers/fullscreen';
13
13
  import { cn } from '../../../../utils/cn';
14
14
  import { useTypedDispatch, useTypedSelector } from '../../../../utils/hooks';
15
- import { LANGUAGE_S_EXPRESSION_ID } from '../../../../utils/monaco/s-expression/constants';
15
+ import { S_EXPRESSION_LANGUAGE_ID } from '../../../../utils/monaco/constats';
16
16
  import { parseQueryErrorToString } from '../../../../utils/query';
17
17
  import { PaneVisibilityToggleButtons } from '../../utils/paneVisibilityToggleHelpers';
18
18
  import { renderExplainNode } from './utils';
@@ -98,7 +98,7 @@ export function ExplainResult(props) {
98
98
  return (_jsxs(React.Fragment, { children: [content, isFullscreen && _jsx(Fullscreen, { children: content })] }));
99
99
  };
100
100
  const renderAstExplain = () => {
101
- const content = (_jsx("div", { className: b('ast'), children: _jsx(MonacoEditor, { language: LANGUAGE_S_EXPRESSION_ID, value: props.ast, options: EDITOR_OPTIONS, wrappingIndent: "indent", theme: `vs-${props.theme}` }) }));
101
+ const content = (_jsx("div", { className: b('ast'), children: _jsx(MonacoEditor, { language: S_EXPRESSION_LANGUAGE_ID, value: props.ast, options: EDITOR_OPTIONS, wrappingIndent: "indent", theme: `vs-${props.theme}` }) }));
102
102
  return (_jsxs(React.Fragment, { children: [content, isFullscreen && _jsx(Fullscreen, { children: content })] }));
103
103
  };
104
104
  const renderGraph = () => {
@@ -11,13 +11,14 @@ import { setShowPreview } from '../../../../store/reducers/schema/schema';
11
11
  import { cn } from '../../../../utils/cn';
12
12
  import { DEFAULT_IS_QUERY_RESULT_COLLAPSED, DEFAULT_SIZE_RESULT_PANE_KEY, LAST_USED_QUERY_ACTION_KEY, QUERY_USE_MULTI_SCHEMA_KEY, } from '../../../../utils/constants';
13
13
  import { useQueryModes, useSetting } from '../../../../utils/hooks';
14
- import { LANGUAGE_YQL_ID } from '../../../../utils/monaco/yql/constants';
14
+ import { YQL_LANGUAGE_ID } from '../../../../utils/monaco/constats';
15
15
  import { QUERY_ACTIONS } from '../../../../utils/query';
16
16
  import { PaneVisibilityActionTypes, paneVisibilityToggleReducerCreator, } from '../../utils/paneVisibilityToggleHelpers';
17
17
  import { ExecuteResult } from '../ExecuteResult/ExecuteResult';
18
18
  import { ExplainResult } from '../ExplainResult/ExplainResult';
19
19
  import { Preview } from '../Preview/Preview';
20
20
  import { QueryEditorControls } from '../QueryEditorControls/QueryEditorControls';
21
+ import { QuerySettingsDialog } from '../QuerySettingsDialog/QuerySettingsDialog';
21
22
  import { SaveQueryDialog } from '../SaveQuery/SaveQuery';
22
23
  import i18n from '../i18n';
23
24
  import { useEditorOptions } from './helpers';
@@ -133,6 +134,10 @@ function QueryEditor(props) {
133
134
  }
134
135
  dispatchResultVisibilityState(PaneVisibilityActionTypes.triggerExpand);
135
136
  };
137
+ const handleSettingsClick = () => {
138
+ setQueryAction('settings');
139
+ props.setShowPreview(false);
140
+ };
136
141
  const handleGetExplainQueryClick = (mode) => {
137
142
  const { input } = executeQuery;
138
143
  setLastUsedQueryAction(QUERY_ACTIONS.explain);
@@ -255,11 +260,11 @@ function QueryEditor(props) {
255
260
  dispatchResultVisibilityState(PaneVisibilityActionTypes.clear);
256
261
  };
257
262
  const renderControls = () => {
258
- return (_jsx(QueryEditorControls, { onRunButtonClick: handleSendExecuteClick, runIsLoading: executeQueryResult.isLoading, onExplainButtonClick: handleGetExplainQueryClick, explainIsLoading: explainQueryResult.isLoading, disabled: !executeQuery.input, onUpdateQueryMode: setQueryMode, queryMode: queryMode, highlightedAction: lastUsedQueryAction }));
263
+ return (_jsx(QueryEditorControls, { onRunButtonClick: handleSendExecuteClick, onSettingsButtonClick: handleSettingsClick, runIsLoading: executeQueryResult.isLoading, onExplainButtonClick: handleGetExplainQueryClick, explainIsLoading: explainQueryResult.isLoading, disabled: !executeQuery.input, onUpdateQueryMode: setQueryMode, queryMode: queryMode, highlightedAction: lastUsedQueryAction }));
259
264
  };
260
265
  return (_jsxs("div", { className: b(), children: [_jsxs(SplitPane, { direction: "vertical", defaultSizePaneKey: DEFAULT_SIZE_RESULT_PANE_KEY, triggerCollapse: resultVisibilityState.triggerCollapse, triggerExpand: resultVisibilityState.triggerExpand, minSize: [0, 52], collapsedSizes: [100, 0], onSplitStartDragAdditional: onSplitStartDragAdditional, children: [_jsxs("div", { className: b('pane-wrapper', {
261
266
  top: true,
262
- }), children: [_jsx("div", { className: b('monaco-wrapper'), children: _jsx("div", { className: b('monaco'), children: _jsx(MonacoEditor, { language: LANGUAGE_YQL_ID, value: executeQuery.input, options: editorOptions, onChange: onChange, editorDidMount: editorDidMount, theme: `vs-${theme}` }) }) }), renderControls()] }), _jsx("div", { className: b('pane-wrapper'), children: _jsx(Result, { executeQueryData: executeQueryResult.data, executeQueryError: executeQueryResult.error, explainQueryData: explainQueryResult.data, explainQueryError: explainQueryResult.error, explainQueryLoading: explainQueryResult.isLoading, resultVisibilityState: resultVisibilityState, onExpandResultHandler: onExpandResultHandler, onCollapseResultHandler: onCollapseResultHandler, type: type, theme: theme, resultType: resultType, tenantName: tenantName, path: path, showPreview: showPreview }) })] }), _jsx(SaveQueryDialog, {})] }));
267
+ }), children: [_jsx("div", { className: b('monaco-wrapper'), children: _jsx("div", { className: b('monaco'), children: _jsx(MonacoEditor, { language: YQL_LANGUAGE_ID, value: executeQuery.input, options: editorOptions, onChange: onChange, editorDidMount: editorDidMount, theme: `vs-${theme}` }) }) }), renderControls()] }), _jsx("div", { className: b('pane-wrapper'), children: _jsx(Result, { executeQueryData: executeQueryResult.data, executeQueryError: executeQueryResult.error, explainQueryData: explainQueryResult.data, explainQueryError: explainQueryResult.error, explainQueryLoading: explainQueryResult.isLoading, resultVisibilityState: resultVisibilityState, onExpandResultHandler: onExpandResultHandler, onCollapseResultHandler: onCollapseResultHandler, type: type, theme: theme, resultType: resultType, tenantName: tenantName, path: path, showPreview: showPreview }) })] }), _jsx(SaveQueryDialog, {}), _jsx(QuerySettingsDialog, {})] }));
263
268
  }
264
269
  const mapStateToProps = (state) => {
265
270
  return {