ydb-embedded-ui 12.5.0 → 12.6.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 (64) hide show
  1. package/dist/assets/illustrations/dark/403.svg +18 -1
  2. package/dist/assets/illustrations/dark/error.svg +1 -1
  3. package/dist/assets/illustrations/dark/thumbsUp.svg +2 -1
  4. package/dist/assets/illustrations/light/403.svg +16 -1
  5. package/dist/assets/illustrations/light/error.svg +1 -1
  6. package/dist/assets/illustrations/light/thumbsUp.svg +2 -1
  7. package/dist/components/EmptyFilter/EmptyFilter.js +1 -1
  8. package/dist/components/EmptyFilter/EmptyFilter.js.map +1 -1
  9. package/dist/components/HoverPopup/HoverPopup.js +1 -1
  10. package/dist/components/HoverPopup/HoverPopup.js.map +1 -1
  11. package/dist/components/Illustration/Illustration.d.ts +5 -3
  12. package/dist/components/Illustration/Illustration.js +30 -15
  13. package/dist/components/Illustration/Illustration.js.map +1 -1
  14. package/dist/components/Illustration/Illustration.scss +9 -0
  15. package/dist/components/PaginatedTable/TableChunk.js +2 -1
  16. package/dist/components/PaginatedTable/TableChunk.js.map +1 -1
  17. package/dist/components/VDisk/VDisk.js +1 -1
  18. package/dist/containers/Clusters/Clusters.js +1 -1
  19. package/dist/containers/Clusters/Clusters.js.map +1 -1
  20. package/dist/containers/Nodes/NodesTable.js +1 -1
  21. package/dist/containers/Nodes/NodesTable.js.map +1 -1
  22. package/dist/containers/Nodes/PaginatedNodes/GroupedNodesComponent.js +1 -1
  23. package/dist/containers/Nodes/PaginatedNodes/GroupedNodesComponent.js.map +1 -1
  24. package/dist/containers/Nodes/PaginatedNodes/NodesComponent.js +1 -1
  25. package/dist/containers/Nodes/PaginatedNodes/NodesComponent.js.map +1 -1
  26. package/dist/containers/Storage/PDisk/PDisk.js +1 -1
  27. package/dist/containers/Storage/PaginatedStorageGroups/GroupedStorageGroupsComponent.js +1 -1
  28. package/dist/containers/Storage/PaginatedStorageGroups/GroupedStorageGroupsComponent.js.map +1 -1
  29. package/dist/containers/Storage/PaginatedStorageGroups/StorageGroupsComponent.js +1 -1
  30. package/dist/containers/Storage/PaginatedStorageGroups/StorageGroupsComponent.js.map +1 -1
  31. package/dist/containers/Storage/PaginatedStorageGroupsTable/columns/hooks.d.ts +3 -1
  32. package/dist/containers/Storage/PaginatedStorageNodes/GroupedStorageNodesComponent.js +1 -1
  33. package/dist/containers/Storage/PaginatedStorageNodes/GroupedStorageNodesComponent.js.map +1 -1
  34. package/dist/containers/Storage/PaginatedStorageNodes/StorageNodesComponent.js +1 -1
  35. package/dist/containers/Storage/PaginatedStorageNodes/StorageNodesComponent.js.map +1 -1
  36. package/dist/containers/Storage/PaginatedStorageNodes/useStorageNodesColumnsToSelect.d.ts +3 -1
  37. package/dist/containers/Storage/PaginatedStorageNodesTable/columns/hooks.d.ts +3 -1
  38. package/dist/containers/Tenant/Diagnostics/Network/Network.js +1 -1
  39. package/dist/containers/Tenant/Diagnostics/Network/Network.js.map +1 -1
  40. package/dist/containers/Tenant/Diagnostics/Partitions/Partitions.js +6 -12
  41. package/dist/containers/Tenant/Diagnostics/Partitions/Partitions.js.map +1 -1
  42. package/dist/containers/Tenant/Diagnostics/Partitions/PartitionsControls/PartitionsControls.d.ts +0 -6
  43. package/dist/containers/Tenant/Diagnostics/Partitions/PartitionsControls/PartitionsControls.js +0 -40
  44. package/dist/containers/Tenant/Diagnostics/Partitions/PartitionsControls/PartitionsControls.js.map +1 -1
  45. package/dist/containers/Tenant/Diagnostics/Partitions/utils/constants.d.ts +2 -2
  46. package/dist/containers/Tenant/Diagnostics/Partitions/utils/useGetPartitionsColumns.d.ts +7 -3
  47. package/dist/containers/Tenant/Diagnostics/Partitions/utils/useGetPartitionsColumns.js +25 -12
  48. package/dist/containers/Tenant/Diagnostics/Partitions/utils/useGetPartitionsColumns.js.map +1 -1
  49. package/dist/containers/Tenant/Diagnostics/TenantOverview/TenantOverview.js +1 -1
  50. package/dist/containers/Tenant/Diagnostics/TenantOverview/TenantOverview.js.map +1 -1
  51. package/dist/containers/Tenant/Diagnostics/TopQueries/RunningQueriesData.js +1 -1
  52. package/dist/containers/Tenant/Diagnostics/TopQueries/RunningQueriesData.js.map +1 -1
  53. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.js +1 -1
  54. package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.js.map +1 -1
  55. package/dist/containers/Tenant/Diagnostics/TopicData/TopicData.js +1 -1
  56. package/dist/containers/Tenant/Diagnostics/TopicData/TopicData.js.map +1 -1
  57. package/dist/containers/Tenant/Healthcheck/Healthcheck.js +1 -1
  58. package/dist/containers/Tenant/Healthcheck/Healthcheck.js.map +1 -1
  59. package/dist/containers/Tenants/Tenants.js +1 -1
  60. package/dist/containers/Tenants/Tenants.js.map +1 -1
  61. package/dist/utils/hooks/useSelectedColumns.d.ts +3 -1
  62. package/dist/utils/hooks/useSelectedColumns.js +46 -25
  63. package/dist/utils/hooks/useSelectedColumns.js.map +1 -1
  64. package/package.json +1 -1
@@ -1,35 +1,56 @@
1
1
  import React from 'react';
2
2
  import { settingsManager } from '../../services/settings';
3
+ function parseSavedColumn(saved) {
4
+ if (typeof saved === 'string') {
5
+ return { id: saved, selected: true };
6
+ }
7
+ if (saved && typeof saved === 'object' && 'id' in saved && typeof saved.id === 'string') {
8
+ const selected = 'selected' in saved ? Boolean(saved.selected) : false;
9
+ return { id: saved.id, selected };
10
+ }
11
+ return undefined;
12
+ }
3
13
  export const useSelectedColumns = (columns, storageKey, columnsTitles, defaultColumnsIds, requiredColumnsIds) => {
4
- const [selectedColumnsIds, setSelectedColumnsIds] = React.useState(() => {
5
- return settingsManager.readUserSettingsValue(storageKey, defaultColumnsIds);
14
+ const [orderedColumns, setOrderedColumns] = React.useState(() => {
15
+ const savedColumns = settingsManager.readUserSettingsValue(storageKey, defaultColumnsIds);
16
+ const normalizedSavedColumns = savedColumns.map(parseSavedColumn);
17
+ return columns.reduce((acc, column) => {
18
+ const savedColumn = normalizedSavedColumns.find((c) => c && c.id === column.name);
19
+ if (savedColumn) {
20
+ acc.push(savedColumn);
21
+ }
22
+ else {
23
+ acc.push({ id: column.name, selected: false });
24
+ }
25
+ return acc;
26
+ }, []);
6
27
  });
7
- const columnsToShow = React.useMemo(() => {
8
- return columns.filter((column) => {
9
- const columnId = column.name;
10
- const isSelected = selectedColumnsIds.includes(columnId);
11
- const isRequired = requiredColumnsIds === null || requiredColumnsIds === void 0 ? void 0 : requiredColumnsIds.includes(columnId);
12
- return isSelected || isRequired;
13
- });
14
- }, [columns, requiredColumnsIds, selectedColumnsIds]);
15
28
  const columnsToSelect = React.useMemo(() => {
16
- const columnsIds = columns.map((column) => column.name);
17
- return columnsIds.map((id) => {
29
+ const preparedColumns = orderedColumns.reduce((acc, { id, selected }) => {
18
30
  const isRequired = requiredColumnsIds === null || requiredColumnsIds === void 0 ? void 0 : requiredColumnsIds.includes(id);
19
- const isSelected = selectedColumnsIds.includes(id);
20
- return {
21
- id,
22
- title: columnsTitles[id],
23
- selected: isRequired || isSelected,
24
- required: isRequired,
25
- sticky: isRequired ? 'start' : undefined,
26
- };
27
- });
28
- }, [columns, columnsTitles, requiredColumnsIds, selectedColumnsIds]);
31
+ const column = columns.find((c) => c.name === id);
32
+ if (column) {
33
+ acc.push({
34
+ id,
35
+ title: columnsTitles[id],
36
+ selected: selected || isRequired,
37
+ required: isRequired,
38
+ sticky: isRequired ? 'start' : undefined,
39
+ column,
40
+ });
41
+ }
42
+ return acc;
43
+ }, []);
44
+ //required columns should be first to properly render columns settings
45
+ return preparedColumns.toSorted((a, b) => Number(Boolean(b.required)) - Number(Boolean(a.required)));
46
+ }, [columns, columnsTitles, requiredColumnsIds, orderedColumns]);
47
+ const columnsToShow = React.useMemo(() => {
48
+ return columnsToSelect.filter((c) => c.selected).map((c) => c.column);
49
+ }, [columnsToSelect]);
29
50
  const setColumns = React.useCallback((value) => {
30
- const selectedColumns = value.filter((el) => el.selected).map((el) => el.id);
31
- settingsManager.setUserSettingsValue(storageKey, selectedColumns);
32
- setSelectedColumnsIds(selectedColumns);
51
+ const preparedColumns = value.map(({ id, selected }) => ({ id, selected }));
52
+ settingsManager.setUserSettingsValue(storageKey, preparedColumns);
53
+ setOrderedColumns(preparedColumns);
33
54
  }, [storageKey]);
34
55
  return {
35
56
  columnsToShow,
@@ -1 +1 @@
1
- {"version":3,"file":"useSelectedColumns.js","sourceRoot":"","sources":["../../../src/utils/hooks/useSelectedColumns.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,OAAO,EAAC,eAAe,EAAC,MAAM,yBAAyB,CAAC;AAExD,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAC9B,OAAY,EACZ,UAAkB,EAClB,aAAqC,EACrC,iBAA2B,EAC3B,kBAA6B,EAC/B,EAAE;IACA,MAAM,CAAC,kBAAkB,EAAE,qBAAqB,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAW,GAAG,EAAE;QAC9E,OAAO,eAAe,CAAC,qBAAqB,CAAC,UAAU,EAAE,iBAAiB,CAAa,CAAC;IAC5F,CAAC,CAAC,CAAC;IAEH,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACrC,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE;YAC7B,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC;YAC7B,MAAM,UAAU,GAAG,kBAAkB,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;YACzD,MAAM,UAAU,GAAG,kBAAkB,aAAlB,kBAAkB,uBAAlB,kBAAkB,CAAE,QAAQ,CAAC,QAAQ,CAAC,CAAC;YAC1D,OAAO,UAAU,IAAI,UAAU,CAAC;QACpC,CAAC,CAAC,CAAC;IACP,CAAC,EAAE,CAAC,OAAO,EAAE,kBAAkB,EAAE,kBAAkB,CAAC,CAAC,CAAC;IAEtD,MAAM,eAAe,GAA2B,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QAC/D,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAExD,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE;YACzB,MAAM,UAAU,GAAG,kBAAkB,aAAlB,kBAAkB,uBAAlB,kBAAkB,CAAE,QAAQ,CAAC,EAAE,CAAC,CAAC;YACpD,MAAM,UAAU,GAAG,kBAAkB,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YAEnD,OAAO;gBACH,EAAE;gBACF,KAAK,EAAE,aAAa,CAAC,EAAE,CAAC;gBACxB,QAAQ,EAAE,UAAU,IAAI,UAAU;gBAClC,QAAQ,EAAE,UAAU;gBACpB,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS;aAC3C,CAAC;QACN,CAAC,CAAC,CAAC;IACP,CAAC,EAAE,CAAC,OAAO,EAAE,aAAa,EAAE,kBAAkB,EAAE,kBAAkB,CAAC,CAAC,CAAC;IAErE,MAAM,UAAU,GAAsC,KAAK,CAAC,WAAW,CACnE,CAAC,KAAK,EAAE,EAAE;QACN,MAAM,eAAe,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;QAE7E,eAAe,CAAC,oBAAoB,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC;QAClE,qBAAqB,CAAC,eAAe,CAAC,CAAC;IAC3C,CAAC,EACD,CAAC,UAAU,CAAC,CACf,CAAC;IAEF,OAAO;QACH,aAAa;QACb,eAAe;QACf,UAAU;KACb,CAAC;AACN,CAAC,CAAC"}
1
+ {"version":3,"file":"useSelectedColumns.js","sourceRoot":"","sources":["../../../src/utils/hooks/useSelectedColumns.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ydb-embedded-ui",
3
- "version": "12.5.0",
3
+ "version": "12.6.0",
4
4
  "files": [
5
5
  "dist"
6
6
  ],