ydb-embedded-ui 14.1.0 → 14.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/TenantNameWrapper/TenantNameWrapper.d.ts +3 -1
- package/dist/components/TenantNameWrapper/TenantNameWrapper.js +105 -23
- package/dist/components/TenantNameWrapper/TenantNameWrapper.js.map +1 -1
- package/dist/components/TenantNameWrapper/TenantNameWrapper.scss +22 -0
- package/dist/components/TenantNameWrapper/i18n/en.json +3 -1
- package/dist/components/TenantNameWrapper/i18n/index.d.ts +1 -1
- package/dist/components/TenantNameWrapper/utils.d.ts +3 -0
- package/dist/components/TenantNameWrapper/utils.js +14 -0
- package/dist/components/TenantNameWrapper/utils.js.map +1 -0
- package/dist/components/capacityMetricsColumns/columns.d.ts +16 -0
- package/dist/components/capacityMetricsColumns/columns.js +76 -0
- package/dist/components/capacityMetricsColumns/columns.js.map +1 -0
- package/dist/components/capacityMetricsColumns/constants.d.ts +16 -0
- package/dist/components/capacityMetricsColumns/constants.js +26 -0
- package/dist/components/capacityMetricsColumns/constants.js.map +1 -0
- package/dist/components/capacityMetricsColumns/i18n/en.json +7 -0
- package/dist/components/capacityMetricsColumns/i18n/index.d.ts +2 -0
- package/dist/components/capacityMetricsColumns/i18n/index.js +5 -0
- package/dist/components/capacityMetricsColumns/i18n/index.js.map +1 -0
- package/dist/components/nodesColumns/columns.d.ts +3 -0
- package/dist/components/nodesColumns/columns.js +10 -1
- package/dist/components/nodesColumns/columns.js.map +1 -1
- package/dist/components/nodesColumns/constants.d.ts +6 -0
- package/dist/components/nodesColumns/constants.js +22 -0
- package/dist/components/nodesColumns/constants.js.map +1 -1
- package/dist/containers/App/NavigationWrapper.js +5 -1
- package/dist/containers/App/NavigationWrapper.js.map +1 -1
- package/dist/containers/Clusters/Clusters.js +6 -3
- package/dist/containers/Clusters/Clusters.js.map +1 -1
- package/dist/containers/Clusters/Clusters.scss +8 -0
- package/dist/containers/Clusters/i18n/en.json +2 -2
- package/dist/containers/HomePage/HomePage.js +8 -6
- package/dist/containers/HomePage/HomePage.js.map +1 -1
- package/dist/containers/HomePage/HomePage.scss +1 -0
- package/dist/containers/HomePage/useDatabasesPageEnvironment.js +2 -2
- package/dist/containers/HomePage/useDatabasesPageEnvironment.js.map +1 -1
- package/dist/containers/Node/Node.js +10 -5
- package/dist/containers/Node/Node.js.map +1 -1
- package/dist/containers/Nodes/columns/columns.js +2 -1
- package/dist/containers/Nodes/columns/columns.js.map +1 -1
- package/dist/containers/Operations/columns.js +51 -53
- package/dist/containers/Operations/columns.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageGroups/GroupedStorageGroupsComponent.js +3 -1
- package/dist/containers/Storage/PaginatedStorageGroups/GroupedStorageGroupsComponent.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageGroups/StorageGroupsControls.js +10 -5
- package/dist/containers/Storage/PaginatedStorageGroups/StorageGroupsControls.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageGroupsTable/columns/columns.js +10 -4
- package/dist/containers/Storage/PaginatedStorageGroupsTable/columns/columns.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageGroupsTable/columns/constants.d.ts +13 -2
- package/dist/containers/Storage/PaginatedStorageGroupsTable/columns/constants.js +40 -8
- package/dist/containers/Storage/PaginatedStorageGroupsTable/columns/constants.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageGroupsTable/columns/hooks.js +21 -14
- package/dist/containers/Storage/PaginatedStorageGroupsTable/columns/hooks.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageGroupsTable/getGroups.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageNodes/GroupedStorageNodesComponent.js +3 -1
- package/dist/containers/Storage/PaginatedStorageNodes/GroupedStorageNodesComponent.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageNodes/StorageNodesControls.js +10 -1
- package/dist/containers/Storage/PaginatedStorageNodes/StorageNodesControls.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageNodesTable/columns/columns.js +4 -0
- package/dist/containers/Storage/PaginatedStorageNodesTable/columns/columns.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageNodesTable/columns/constants.d.ts +1 -0
- package/dist/containers/Storage/PaginatedStorageNodesTable/columns/constants.js +6 -0
- package/dist/containers/Storage/PaginatedStorageNodesTable/columns/constants.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageNodesTable/columns/hooks.js +16 -9
- package/dist/containers/Storage/PaginatedStorageNodesTable/columns/hooks.js.map +1 -1
- package/dist/containers/Storage/TableGroup/TableGroup.d.ts +2 -1
- package/dist/containers/Storage/TableGroup/TableGroup.js +2 -2
- package/dist/containers/Storage/TableGroup/TableGroup.js.map +1 -1
- package/dist/containers/Storage/useStorageQueryParams.js +28 -6
- package/dist/containers/Storage/useStorageQueryParams.js.map +1 -1
- package/dist/containers/Storage/utils/useStorageColumnsSettings.js +25 -1
- package/dist/containers/Storage/utils/useStorageColumnsSettings.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/Overview/AsyncReplicationInfo/Credentials.d.ts +1 -1
- package/dist/containers/Tenant/Diagnostics/Overview/DefaultEntityInfo/DefaultEntityInfo.d.ts +8 -0
- package/dist/containers/Tenant/Diagnostics/Overview/DefaultEntityInfo/DefaultEntityInfo.js +9 -0
- package/dist/containers/Tenant/Diagnostics/Overview/DefaultEntityInfo/DefaultEntityInfo.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/Overview/DefaultEntityInfo/DefaultEntityInfo.scss +7 -0
- package/dist/containers/Tenant/Diagnostics/Overview/DefaultEntityInfo/index.d.ts +1 -0
- package/dist/containers/Tenant/Diagnostics/Overview/DefaultEntityInfo/index.js +2 -0
- package/dist/containers/Tenant/Diagnostics/Overview/DefaultEntityInfo/index.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/Overview/Overview.js +6 -4
- package/dist/containers/Tenant/Diagnostics/Overview/Overview.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/ManagePartitioningDialog.d.ts +15 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/ManagePartitioningDialog.js +85 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/ManagePartitioningDialog.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/ManagePartitioningDialog.scss +28 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/SplitUnitSelect.d.ts +12 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/SplitUnitSelect.js +26 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/SplitUnitSelect.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/SplitUnitSelect.scss +14 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/constants.d.ts +10 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/constants.js +20 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/constants.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/i18n/en.json +18 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/i18n/index.d.ts +2 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/i18n/index.js +5 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/i18n/index.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/types.d.ts +8 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/types.js +2 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/types.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/useManagePartitionForm.d.ts +5 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/useManagePartitionForm.js +15 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/useManagePartitionForm.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/utils.d.ts +40 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/utils.js +73 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/utils.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/PartitionsProgress/PartitionsProgress.js +5 -2
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/PartitionsProgress/PartitionsProgress.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/PartitionsProgress/PartitionsProgress.scss +2 -2
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/PartitionsProgress/helpers.js +9 -5
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/PartitionsProgress/helpers.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/TableInfo.d.ts +3 -1
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/TableInfo.js +36 -5
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/TableInfo.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/TableInfo.scss +12 -6
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/constants.d.ts +0 -1
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/constants.js +0 -1
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/constants.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/i18n/en.json +4 -2
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/i18n/index.d.ts +1 -1
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/prepareTableInfo.d.ts +3 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/prepareTableInfo.js +37 -12
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/prepareTableInfo.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/utils.d.ts +3 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/utils.js +15 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/utils.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/Overview/TransferInfo/Credentials.d.ts +1 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/TenantOverview.js +2 -2
- package/dist/containers/Tenant/Diagnostics/TenantOverview/TenantOverview.js.map +1 -1
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssues.js +1 -1
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssues.js.map +1 -1
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckView.js +6 -2
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckView.js.map +1 -1
- package/dist/containers/Tenant/Healthcheck/i18n/en.json +1 -0
- package/dist/containers/Tenant/Healthcheck/i18n/index.d.ts +1 -1
- package/dist/containers/Tenant/Healthcheck/shared.d.ts +2 -1
- package/dist/containers/Tenant/Healthcheck/shared.js +9 -2
- package/dist/containers/Tenant/Healthcheck/shared.js.map +1 -1
- package/dist/containers/Tenant/Query/Preview/components/TablePreview.js +5 -0
- package/dist/containers/Tenant/Query/Preview/components/TablePreview.js.map +1 -1
- package/dist/containers/Tenant/utils/schemaActions.js +2 -2
- package/dist/containers/Tenant/utils/schemaActions.js.map +1 -1
- package/dist/containers/Tenants/Tenants.scss +3 -1
- package/dist/containers/Tenants/TenantsClusterTab.js +1 -1
- package/dist/containers/Tenants/TenantsClusterTab.js.map +1 -1
- package/dist/containers/Tenants/TenantsTable.d.ts +4 -2
- package/dist/containers/Tenants/TenantsTable.js +83 -101
- package/dist/containers/Tenants/TenantsTable.js.map +1 -1
- package/dist/containers/Tenants/constants.d.ts +29 -0
- package/dist/containers/Tenants/constants.js +60 -0
- package/dist/containers/Tenants/constants.js.map +1 -0
- package/dist/containers/Tenants/i18n/en.json +10 -2
- package/dist/containers/Tenants/i18n/index.d.ts +1 -1
- package/dist/containers/UserSettings/i18n/en.json +2 -1
- package/dist/containers/UserSettings/i18n/index.d.ts +1 -1
- package/dist/containers/UserSettings/settings.d.ts +2 -0
- package/dist/containers/UserSettings/settings.js +23 -0
- package/dist/containers/UserSettings/settings.js.map +1 -1
- package/dist/store/reducers/capabilities/hooks.d.ts +2 -0
- package/dist/store/reducers/capabilities/hooks.js +13 -3
- package/dist/store/reducers/capabilities/hooks.js.map +1 -1
- package/dist/store/reducers/environments/utils.js +7 -3
- package/dist/store/reducers/environments/utils.js.map +1 -1
- package/dist/store/reducers/healthcheckInfo/types.d.ts +1 -1
- package/dist/store/reducers/healthcheckInfo/utils.js +19 -9
- package/dist/store/reducers/healthcheckInfo/utils.js.map +1 -1
- package/dist/store/reducers/preview.d.ts +1 -0
- package/dist/store/reducers/preview.js +2 -2
- package/dist/store/reducers/preview.js.map +1 -1
- package/dist/store/reducers/settings/constants.d.ts +2 -0
- package/dist/store/reducers/settings/constants.js +2 -0
- package/dist/store/reducers/settings/constants.js.map +1 -1
- package/dist/store/reducers/storage/types.d.ts +9 -1
- package/dist/store/reducers/storage/utils.js +22 -2
- package/dist/store/reducers/storage/utils.js.map +1 -1
- package/dist/store/reducers/tablePartitioning/tablePartitioning.d.ts +4 -0
- package/dist/store/reducers/tablePartitioning/tablePartitioning.js +41 -0
- package/dist/store/reducers/tablePartitioning/tablePartitioning.js.map +1 -0
- package/dist/styles/mixins.scss +0 -2
- package/dist/types/api/enums.d.ts +11 -0
- package/dist/types/api/enums.js +13 -0
- package/dist/types/api/enums.js.map +1 -1
- package/dist/types/api/nodes.d.ts +7 -4
- package/dist/types/api/nodes.js.map +1 -1
- package/dist/types/api/storage.d.ts +9 -4
- package/dist/types/store/partitioning.d.ts +11 -0
- package/dist/types/store/partitioning.js +2 -0
- package/dist/types/store/partitioning.js.map +1 -0
- package/dist/uiFactory/types.d.ts +23 -2
- package/dist/utils/additionalProps.js +8 -5
- package/dist/utils/additionalProps.js.map +1 -1
- package/dist/utils/bytesParsers/formatBytes.d.ts +2 -2
- package/dist/utils/bytesParsers/formatBytes.js +2 -1
- package/dist/utils/bytesParsers/formatBytes.js.map +1 -1
- package/dist/utils/capacityAlert/colors.d.ts +1 -0
- package/dist/utils/capacityAlert/colors.js +26 -0
- package/dist/utils/capacityAlert/colors.js.map +1 -0
- package/dist/utils/dataFormatters/dataFormatters.d.ts +3 -1
- package/dist/utils/dataFormatters/dataFormatters.js +9 -3
- package/dist/utils/dataFormatters/dataFormatters.js.map +1 -1
- package/dist/utils/query.js +7 -8
- package/dist/utils/query.js.map +1 -1
- package/dist/utils/zod/zodParsers.d.ts +3 -0
- package/dist/utils/zod/zodParsers.js +5 -0
- package/dist/utils/zod/zodParsers.js.map +1 -0
- package/package.json +1 -1
|
@@ -7,9 +7,10 @@ interface TableGroupProps {
|
|
|
7
7
|
count: string | number;
|
|
8
8
|
expanded: boolean;
|
|
9
9
|
onIsExpandedChange: (name: string, isExpanded: boolean) => void;
|
|
10
|
+
titleColor?: string;
|
|
10
11
|
}
|
|
11
12
|
export declare const TableGroup: {
|
|
12
|
-
({ children, title, entityName, count, expanded, onIsExpandedChange, }: TableGroupProps): import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
({ children, title, entityName, count, expanded, onIsExpandedChange, titleColor, }: TableGroupProps): import("react/jsx-runtime").JSX.Element;
|
|
13
14
|
displayName: string;
|
|
14
15
|
};
|
|
15
16
|
export {};
|
|
@@ -3,12 +3,12 @@ import { ArrowToggle, Label, Text } from '@gravity-ui/uikit';
|
|
|
3
3
|
import { cn } from '../../../utils/cn';
|
|
4
4
|
import './TableGroup.scss';
|
|
5
5
|
const b = cn('ydb-table-group');
|
|
6
|
-
export const TableGroup = ({ children, title, entityName, count, expanded = false, onIsExpandedChange, }) => {
|
|
6
|
+
export const TableGroup = ({ children, title, entityName, count, expanded = false, onIsExpandedChange, titleColor, }) => {
|
|
7
7
|
const toggleCollapsed = () => {
|
|
8
8
|
onIsExpandedChange(title, !expanded);
|
|
9
9
|
};
|
|
10
10
|
const renderTitle = () => {
|
|
11
|
-
return (_jsx("button", { onClick: toggleCollapsed, className: b('button'), title: title, children: _jsxs("div", { className: b('title-wrapper'), children: [_jsx(ArrowToggle, { direction: expanded ? 'top' : 'bottom' }), _jsxs("div", { className: b('title'), children: [_jsx(Text, { variant: "subheader-2", children: title }), _jsxs(Text, { variant: "body-2", color: "secondary", className: b('count'), children: [entityName, ": ", _jsx(Label, { theme: "normal", children: count })] })] })] }) }));
|
|
11
|
+
return (_jsx("button", { onClick: toggleCollapsed, className: b('button'), title: title, children: _jsxs("div", { className: b('title-wrapper'), children: [_jsx(ArrowToggle, { direction: expanded ? 'top' : 'bottom' }), _jsxs("div", { className: b('title'), children: [_jsx(Text, { variant: "subheader-2", style: titleColor ? { color: titleColor } : undefined, children: title }), _jsxs(Text, { variant: "body-2", color: "secondary", className: b('count'), children: [entityName, ": ", _jsx(Label, { theme: "normal", children: count })] })] })] }) }));
|
|
12
12
|
};
|
|
13
13
|
const renderContent = () => {
|
|
14
14
|
if (expanded) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TableGroup.js","sourceRoot":"","sources":["../../../../src/containers/Storage/TableGroup/TableGroup.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAC,WAAW,EAAE,KAAK,EAAE,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAE3D,OAAO,EAAC,EAAE,EAAC,MAAM,mBAAmB,CAAC;AAErC,OAAO,mBAAmB,CAAC;AAE3B,MAAM,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"TableGroup.js","sourceRoot":"","sources":["../../../../src/containers/Storage/TableGroup/TableGroup.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAC,WAAW,EAAE,KAAK,EAAE,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAE3D,OAAO,EAAC,EAAE,EAAC,MAAM,mBAAmB,CAAC;AAErC,OAAO,mBAAmB,CAAC;AAE3B,MAAM,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC,CAAC;AAahC,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EACvB,QAAQ,EACR,KAAK,EACL,UAAU,EACV,KAAK,EACL,QAAQ,GAAG,KAAK,EAChB,kBAAkB,EAClB,UAAU,GACI,EAAE,EAAE;IAClB,MAAM,eAAe,GAAG,GAAG,EAAE;QACzB,kBAAkB,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,CAAC;IACzC,CAAC,CAAC;IAEF,MAAM,WAAW,GAAG,GAAG,EAAE;QACrB,OAAO,CACH,iBAAQ,OAAO,EAAE,eAAe,EAAE,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,EAAE,KAAK,EAAE,KAAK,YAClE,eAAK,SAAS,EAAE,CAAC,CAAC,eAAe,CAAC,aAC9B,KAAC,WAAW,IAAC,SAAS,EAAE,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,GAAI,EACvD,eAAK,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,aACtB,KAAC,IAAI,IACD,OAAO,EAAC,aAAa,EACrB,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC,EAAC,KAAK,EAAE,UAAU,EAAC,CAAC,CAAC,CAAC,SAAS,YAElD,KAAK,GACH,EACP,MAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,WAAW,EAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,aACzD,UAAU,QAAG,KAAC,KAAK,IAAC,KAAK,EAAC,QAAQ,YAAE,KAAK,GAAS,IAChD,IACL,IACJ,GACD,CACZ,CAAC;IACN,CAAC,CAAC;IAEF,MAAM,aAAa,GAAG,GAAG,EAAE;QACvB,IAAI,QAAQ,EAAE,CAAC;YACX,OAAO,cAAK,SAAS,EAAE,CAAC,CAAC,SAAS,CAAC,YAAG,QAAQ,GAAO,CAAC;QAC1D,CAAC;QAED,OAAO,IAAI,CAAC;IAChB,CAAC,CAAC;IAEF,OAAO,CACH,eAAK,SAAS,EAAE,CAAC,CAAC,IAAI,CAAC,aAClB,WAAW,EAAE,EACb,aAAa,EAAE,IACd,CACT,CAAC;AACN,CAAC,CAAC;AAEF,UAAU,CAAC,WAAW,GAAG,YAAY,CAAC"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { StringParam, useQueryParam, useQueryParams } from 'use-query-params';
|
|
3
|
+
import { useBlobStorageCapacityMetricsEnabled } from '../../store/reducers/capabilities/hooks';
|
|
3
4
|
import { SETTING_KEYS } from '../../store/reducers/settings/constants';
|
|
4
5
|
import { STORAGE_TYPES } from '../../store/reducers/storage/constants';
|
|
5
6
|
import { storageTypeSchema, visibleEntitiesSchema } from '../../store/reducers/storage/types';
|
|
@@ -21,6 +22,7 @@ export function useStorageQueryParams() {
|
|
|
21
22
|
storageGroupsGroupBy: StringParam,
|
|
22
23
|
});
|
|
23
24
|
const [_savedStorageType, setSavedStorageType] = useSetting(SETTING_KEYS.STORAGE_TYPE, STORAGE_TYPES.groups);
|
|
25
|
+
const blobMetricsEnabled = useBlobStorageCapacityMetricsEnabled();
|
|
24
26
|
const storageType = storageTypeSchema.parse(queryParams.type);
|
|
25
27
|
const visibleEntities = visibleEntitiesSchema.parse(queryParams.visible);
|
|
26
28
|
const groupsSearchValue = (_a = queryParams.groupsSearch) !== null && _a !== void 0 ? _a : '';
|
|
@@ -51,12 +53,12 @@ export function useStorageQueryParams() {
|
|
|
51
53
|
const handleUptimeFilterChange = (value) => {
|
|
52
54
|
setQueryParams({ uptimeFilter: value }, 'replaceIn');
|
|
53
55
|
};
|
|
54
|
-
const handleStorageGroupsGroupByParamChange = (value) => {
|
|
55
|
-
setQueryParams({ storageGroupsGroupBy: value }, 'replaceIn');
|
|
56
|
-
};
|
|
57
|
-
const handleStorageNodesGroupByParamChange = (value) => {
|
|
58
|
-
setQueryParams({ storageNodesGroupBy: value }, 'replaceIn');
|
|
59
|
-
};
|
|
56
|
+
const handleStorageGroupsGroupByParamChange = React.useCallback((value) => {
|
|
57
|
+
setQueryParams({ storageGroupsGroupBy: value || undefined }, 'replaceIn');
|
|
58
|
+
}, [setQueryParams]);
|
|
59
|
+
const handleStorageNodesGroupByParamChange = React.useCallback((value) => {
|
|
60
|
+
setQueryParams({ storageNodesGroupBy: value || undefined }, 'replaceIn');
|
|
61
|
+
}, [setQueryParams]);
|
|
60
62
|
const handleShowAllGroups = () => {
|
|
61
63
|
handleVisibleEntitiesChange('all');
|
|
62
64
|
};
|
|
@@ -64,6 +66,26 @@ export function useStorageQueryParams() {
|
|
|
64
66
|
handleVisibleEntitiesChange('all');
|
|
65
67
|
handleUptimeFilterChange(NodesUptimeFilterValues.All);
|
|
66
68
|
};
|
|
69
|
+
React.useEffect(() => {
|
|
70
|
+
if (blobMetricsEnabled) {
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
const patch = {};
|
|
74
|
+
if (queryParams.storageGroupsGroupBy === 'CapacityAlert') {
|
|
75
|
+
patch.storageGroupsGroupBy = undefined;
|
|
76
|
+
}
|
|
77
|
+
if (queryParams.storageNodesGroupBy === 'CapacityAlert') {
|
|
78
|
+
patch.storageNodesGroupBy = undefined;
|
|
79
|
+
}
|
|
80
|
+
if (Object.keys(patch).length > 0) {
|
|
81
|
+
setQueryParams(patch, 'replaceIn');
|
|
82
|
+
}
|
|
83
|
+
}, [
|
|
84
|
+
blobMetricsEnabled,
|
|
85
|
+
queryParams.storageGroupsGroupBy,
|
|
86
|
+
queryParams.storageNodesGroupBy,
|
|
87
|
+
setQueryParams,
|
|
88
|
+
]);
|
|
67
89
|
return {
|
|
68
90
|
storageType,
|
|
69
91
|
visibleEntities,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useStorageQueryParams.js","sourceRoot":"","sources":["../../../src/containers/Storage/useStorageQueryParams.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"useStorageQueryParams.js","sourceRoot":"","sources":["../../../src/containers/Storage/useStorageQueryParams.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,29 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
|
|
2
|
+
/**
|
|
3
|
+
* Storage → Nodes → column "PDisks": size coupling notes (keep in sync)
|
|
4
|
+
*
|
|
5
|
+
* Data flow:
|
|
6
|
+
* - `window.api.viewer.getNodes()` returns `MaximumSlotsPerDisk` / `MaximumDisksPerNode`
|
|
7
|
+
* → `prepareStorageNodesResponse()` maps them into `columnsSettings.{maxSlotsPerDisk,maxDisksPerNode}`
|
|
8
|
+
* (`src/store/reducers/storage/utils.ts`)
|
|
9
|
+
* → `handleDataFetched()` calculates `pDiskWidth` and `pDiskContainerWidth` (this file)
|
|
10
|
+
* → `PaginatedStorageNodesTable` column width uses `pDiskContainerWidth`
|
|
11
|
+
* and each `PDisk` instance gets `width={pDiskWidth}`.
|
|
12
|
+
*
|
|
13
|
+
* Visual model:
|
|
14
|
+
* - One PDisk cell renders a horizontal row of compact VDisks above the PDisk progress bar
|
|
15
|
+
* (`src/containers/Storage/PDisk/PDisk.tsx`).
|
|
16
|
+
* - Each VDisk "slot" has a hard minimum width and a gap between slots:
|
|
17
|
+
* - slot min-width is effectively 8px:
|
|
18
|
+
* - `--pdisk-vdisk-width: 8px` (`src/containers/Storage/PDisk/PDisk.scss`)
|
|
19
|
+
* - `DiskStateProgressBar` compact min-width is 8px
|
|
20
|
+
* (`src/components/DiskStateProgressBar/DiskStateProgressBar.scss`)
|
|
21
|
+
* - gap is 2px: `--pdisk-gap-width: 2px` (`src/containers/Storage/PDisk/PDisk.scss`)
|
|
22
|
+
*
|
|
23
|
+
* Therefore, the `pDiskWidth` formula below MUST use the same slot/gap values,
|
|
24
|
+
* otherwise with large `maxSlotsPerDisk` the VDisks row will overflow the PDisk width.
|
|
25
|
+
*/
|
|
26
|
+
const PDISK_VDISK_WIDTH = 8;
|
|
3
27
|
const PDISK_GAP_WIDTH = 2;
|
|
4
28
|
const PDISK_MIN_WIDTH = 165;
|
|
5
29
|
const PDISK_MARGIN = 10;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useStorageColumnsSettings.js","sourceRoot":"","sources":["../../../../src/containers/Storage/utils/useStorageColumnsSettings.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAK1B,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAC5B,MAAM,eAAe,GAAG,CAAC,CAAC;AAC1B,MAAM,eAAe,GAAG,GAAG,CAAC;AAC5B,MAAM,YAAY,GAAG,EAAE,CAAC;AACxB,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAC5B,MAAM,sCAAsC,GAAG,EAAE,CAAC;AAElD,MAAM,UAAU,yBAAyB;IACrC,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAqB,SAAS,CAAC,CAAC;IAClF,MAAM,CAAC,mBAAmB,EAAE,sBAAsB,CAAC,GAAG,KAAK,CAAC,QAAQ,CAChE,SAAS,CACZ,CAAC;IAEF,MAAM,iBAAiB,GAAG,KAAK,CAAC,WAAW,CACvC,CAAC,IAAoC,EAAE,EAAE;QACrC,IAAI,CAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,eAAe,KAAI,CAAC,UAAU,EAAE,CAAC;YACvC,MAAM,EAAC,eAAe,EAAE,eAAe,EAAC,GAAG,IAAI,CAAC,eAAe,CAAC;YAChE,MAAM,QAAQ,GAAG,eAAe,IAAI,iBAAiB,CAAC;YACtD,MAAM,QAAQ,GAAG,eAAe,IAAI,iBAAiB,CAAC;YAEtD,MAAM,oBAAoB,GAAG,IAAI,CAAC,GAAG,CACjC,QAAQ,GAAG,iBAAiB,GAAG,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,eAAe,EAC/D,eAAe,CAClB,CAAC;YAEF,MAAM,6BAA6B,GAC/B,QAAQ,GAAG,oBAAoB;gBAC/B,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,YAAY;gBAC7B,CAAC,GAAG,sCAAsC,CAAC;YAE/C,aAAa,CAAC,oBAAoB,CAAC,CAAC;YACpC,sBAAsB,CAAC,6BAA6B,CAAC,CAAC;QAC1D,CAAC;IACL,CAAC,EACD,CAAC,UAAU,CAAC,CACf,CAAC;IAEF,MAAM,eAAe,GAAgC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACpE,OAAO;YACH,UAAU,EAAE,UAAU,IAAI,eAAe;YACzC,mBAAmB,EAAE,mBAAmB;SAC3C,CAAC;IACN,CAAC,EAAE,CAAC,mBAAmB,EAAE,UAAU,CAAC,CAAC,CAAC;IAEtC,OAAO;QACH,iBAAiB;QACjB,eAAe;KAClB,CAAC;AACN,CAAC"}
|
|
1
|
+
{"version":3,"file":"useStorageColumnsSettings.js","sourceRoot":"","sources":["../../../../src/containers/Storage/utils/useStorageColumnsSettings.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAK1B;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAC5B,MAAM,eAAe,GAAG,CAAC,CAAC;AAC1B,MAAM,eAAe,GAAG,GAAG,CAAC;AAC5B,MAAM,YAAY,GAAG,EAAE,CAAC;AACxB,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAC5B,MAAM,sCAAsC,GAAG,EAAE,CAAC;AAElD,MAAM,UAAU,yBAAyB;IACrC,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAqB,SAAS,CAAC,CAAC;IAClF,MAAM,CAAC,mBAAmB,EAAE,sBAAsB,CAAC,GAAG,KAAK,CAAC,QAAQ,CAChE,SAAS,CACZ,CAAC;IAEF,MAAM,iBAAiB,GAAG,KAAK,CAAC,WAAW,CACvC,CAAC,IAAoC,EAAE,EAAE;QACrC,IAAI,CAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,eAAe,KAAI,CAAC,UAAU,EAAE,CAAC;YACvC,MAAM,EAAC,eAAe,EAAE,eAAe,EAAC,GAAG,IAAI,CAAC,eAAe,CAAC;YAChE,MAAM,QAAQ,GAAG,eAAe,IAAI,iBAAiB,CAAC;YACtD,MAAM,QAAQ,GAAG,eAAe,IAAI,iBAAiB,CAAC;YAEtD,MAAM,oBAAoB,GAAG,IAAI,CAAC,GAAG,CACjC,QAAQ,GAAG,iBAAiB,GAAG,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,eAAe,EAC/D,eAAe,CAClB,CAAC;YAEF,MAAM,6BAA6B,GAC/B,QAAQ,GAAG,oBAAoB;gBAC/B,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,YAAY;gBAC7B,CAAC,GAAG,sCAAsC,CAAC;YAE/C,aAAa,CAAC,oBAAoB,CAAC,CAAC;YACpC,sBAAsB,CAAC,6BAA6B,CAAC,CAAC;QAC1D,CAAC;IACL,CAAC,EACD,CAAC,UAAU,CAAC,CACf,CAAC;IAEF,MAAM,eAAe,GAAgC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACpE,OAAO;YACH,UAAU,EAAE,UAAU,IAAI,eAAe;YACzC,mBAAmB,EAAE,mBAAmB;SAC3C,CAAC;IACN,CAAC,EAAE,CAAC,mBAAmB,EAAE,UAAU,CAAC,CAAC,CAAC;IAEtC,OAAO;QACH,iBAAiB;QACjB,eAAe;KAClB,CAAC;AACN,CAAC"}
|
|
@@ -2,5 +2,5 @@ import type { TConnectionParams } from '../../../../../types/api/schema/replicat
|
|
|
2
2
|
interface CredentialsProps {
|
|
3
3
|
connection?: TConnectionParams;
|
|
4
4
|
}
|
|
5
|
-
export declare function Credentials({ connection }: CredentialsProps): import("react/jsx-runtime").JSX.Element | "
|
|
5
|
+
export declare function Credentials({ connection }: CredentialsProps): "unknown" | import("react/jsx-runtime").JSX.Element | "OAuth" | null;
|
|
6
6
|
export {};
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { TEvDescribeSchemeResult } from '../../../../../types/api/schema';
|
|
2
|
+
import './DefaultEntityInfo.scss';
|
|
3
|
+
export declare const b: import("@bem-react/classname").ClassNameFormatter;
|
|
4
|
+
interface DefaultEntityInfoProps {
|
|
5
|
+
data?: TEvDescribeSchemeResult;
|
|
6
|
+
}
|
|
7
|
+
export declare function DefaultEntityInfo({ data }: DefaultEntityInfoProps): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
export {};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { cn } from '../../../../../utils/cn';
|
|
3
|
+
import { EntityTitle } from '../../../EntityTitle/EntityTitle';
|
|
4
|
+
import './DefaultEntityInfo.scss';
|
|
5
|
+
export const b = cn('default-entity-info');
|
|
6
|
+
export function DefaultEntityInfo({ data }) {
|
|
7
|
+
return (_jsx("div", { className: b('title'), children: _jsx(EntityTitle, { data: data === null || data === void 0 ? void 0 : data.PathDescription }) }));
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=DefaultEntityInfo.js.map
|
package/dist/containers/Tenant/Diagnostics/Overview/DefaultEntityInfo/DefaultEntityInfo.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DefaultEntityInfo.js","sourceRoot":"","sources":["../../../../../../src/containers/Tenant/Diagnostics/Overview/DefaultEntityInfo/DefaultEntityInfo.tsx"],"names":[],"mappings":";AACA,OAAO,EAAC,EAAE,EAAC,MAAM,yBAAyB,CAAC;AAC3C,OAAO,EAAC,WAAW,EAAC,MAAM,kCAAkC,CAAC;AAE7D,OAAO,0BAA0B,CAAC;AAElC,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC,CAAC;AAM3C,MAAM,UAAU,iBAAiB,CAAC,EAAC,IAAI,EAAyB;IAC5D,OAAO,CACH,cAAK,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,YACtB,KAAC,WAAW,IAAC,IAAI,EAAE,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,eAAe,GAAI,GAC1C,CACT,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './DefaultEntityInfo';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/containers/Tenant/Diagnostics/Overview/DefaultEntityInfo/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC"}
|
|
@@ -13,6 +13,7 @@ import { SystemViewInfo } from '../../Info/SystemView/SystemView';
|
|
|
13
13
|
import { ViewInfo } from '../../Info/View/View';
|
|
14
14
|
import { AsyncReplicationInfo } from './AsyncReplicationInfo';
|
|
15
15
|
import { ChangefeedInfo } from './ChangefeedInfo';
|
|
16
|
+
import { DefaultEntityInfo } from './DefaultEntityInfo';
|
|
16
17
|
import { StreamingQueryInfo } from './StreamingQueryInfo';
|
|
17
18
|
import { TableInfo } from './TableInfo';
|
|
18
19
|
import { TopicInfo } from './TopicInfo';
|
|
@@ -29,17 +30,18 @@ function Overview({ type, path, database, databaseFullPath }) {
|
|
|
29
30
|
const data = currentData !== null && currentData !== void 0 ? currentData : undefined;
|
|
30
31
|
// verbose mapping to guarantee a correct render for new path types
|
|
31
32
|
// TS will error when a new type is added but not mapped here
|
|
33
|
+
const renderTableInfo = () => (_jsx(TableInfo, { path: path, data: data, type: type, database: database }));
|
|
32
34
|
const pathTypeToComponent = {
|
|
33
35
|
[EPathType.EPathTypeInvalid]: undefined,
|
|
34
36
|
[EPathType.EPathTypeDir]: undefined,
|
|
35
37
|
[EPathType.EPathTypeResourcePool]: undefined,
|
|
36
|
-
[EPathType.EPathTypeTable]:
|
|
38
|
+
[EPathType.EPathTypeTable]: renderTableInfo,
|
|
37
39
|
[EPathType.EPathTypeSysView]: () => _jsx(SystemViewInfo, { data: data }),
|
|
38
40
|
[EPathType.EPathTypeSubDomain]: undefined,
|
|
39
41
|
[EPathType.EPathTypeTableIndex]: () => _jsx(TableIndexInfo, { data: data }),
|
|
40
42
|
[EPathType.EPathTypeExtSubDomain]: undefined,
|
|
41
|
-
[EPathType.EPathTypeColumnStore]:
|
|
42
|
-
[EPathType.EPathTypeColumnTable]:
|
|
43
|
+
[EPathType.EPathTypeColumnStore]: renderTableInfo,
|
|
44
|
+
[EPathType.EPathTypeColumnTable]: renderTableInfo,
|
|
43
45
|
[EPathType.EPathTypeCdcStream]: () => (_jsx(ChangefeedInfo, { path: path, database: database, databaseFullPath: databaseFullPath, data: data })),
|
|
44
46
|
[EPathType.EPathTypePersQueueGroup]: () => (_jsx(TopicInfo, { data: data, path: path, databaseFullPath: databaseFullPath, database: database })),
|
|
45
47
|
[EPathType.EPathTypeExternalTable]: () => _jsx(ExternalTableInfo, { data: data }),
|
|
@@ -49,7 +51,7 @@ function Overview({ type, path, database, databaseFullPath }) {
|
|
|
49
51
|
[EPathType.EPathTypeTransfer]: () => (_jsx(TransferInfo, { path: path, databaseFullPath: databaseFullPath, database: database, data: data })),
|
|
50
52
|
[EPathType.EPathTypeStreamingQuery]: () => (_jsx(StreamingQueryInfo, { path: path, database: database })),
|
|
51
53
|
};
|
|
52
|
-
return (type && ((_a = pathTypeToComponent[type]) === null || _a === void 0 ? void 0 : _a.call(pathTypeToComponent))) || _jsx(
|
|
54
|
+
return (type && ((_a = pathTypeToComponent[type]) === null || _a === void 0 ? void 0 : _a.call(pathTypeToComponent))) || _jsx(DefaultEntityInfo, { data: data });
|
|
53
55
|
};
|
|
54
56
|
if (loading) {
|
|
55
57
|
return _jsx(Loader, { size: "m" });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Overview.js","sourceRoot":"","sources":["../../../../../src/containers/Tenant/Diagnostics/Overview/Overview.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAC,aAAa,EAAC,MAAM,6CAA6C,CAAC;AAC1E,OAAO,EAAC,cAAc,EAAC,MAAM,8CAA8C,CAAC;AAC5E,OAAO,EAAC,MAAM,EAAC,MAAM,+BAA+B,CAAC;AACrD,OAAO,EAAC,mBAAmB,EAAC,MAAM,4CAA4C,CAAC;AAC/E,OAAO,EAAC,WAAW,EAAC,MAAM,8CAA8C,CAAC;AACzE,OAAO,EAAC,SAAS,EAAC,MAAM,8BAA8B,CAAC;AACvD,OAAO,EAAC,sBAAsB,EAAC,MAAM,yBAAyB,CAAC;AAC/D,OAAO,EAAC,sBAAsB,EAAC,MAAM,kDAAkD,CAAC;AACxF,OAAO,EAAC,iBAAiB,EAAC,MAAM,wCAAwC,CAAC;AACzE,OAAO,EAAC,cAAc,EAAC,MAAM,kCAAkC,CAAC;AAChE,OAAO,EAAC,QAAQ,EAAC,MAAM,sBAAsB,CAAC;AAE9C,OAAO,EAAC,oBAAoB,EAAC,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAC,cAAc,EAAC,MAAM,kBAAkB,CAAC;AAChD,OAAO,EAAC,kBAAkB,EAAC,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAC,SAAS,EAAC,MAAM,aAAa,CAAC;AACtC,OAAO,EAAC,SAAS,EAAC,MAAM,aAAa,CAAC;AACtC,OAAO,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AAS5C,SAAS,QAAQ,CAAC,EAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,gBAAgB,EAAgB;IACrE,MAAM,CAAC,mBAAmB,CAAC,GAAG,sBAAsB,EAAE,CAAC;IACvD,MAAM,YAAY,GAAG,mBAAmB,EAAE,CAAC;IAE3C,MAAM,EAAC,WAAW,EAAE,UAAU,EAAE,KAAK,EAAC,GAAG,WAAW,CAAC,mBAAmB,CACpE,EAAC,IAAI,EAAE,QAAQ,EAAE,gBAAgB,EAAE,YAAY,EAAC;IAChD,0FAA0F;IAC1F,EAAC,eAAe,EAAE,mBAAmB,EAAE,IAAI,EAAE,IAAI,KAAK,SAAS,CAAC,uBAAuB,EAAC,CAC3F,CAAC;IAEF,MAAM,OAAO,GAAG,UAAU,IAAI,WAAW,KAAK,SAAS,CAAC;IAExD,MAAM,aAAa,GAAG,GAAG,EAAE;;QACvB,MAAM,IAAI,GAAG,WAAW,aAAX,WAAW,cAAX,WAAW,GAAI,SAAS,CAAC;QACtC,mEAAmE;QACnE,6DAA6D;
|
|
1
|
+
{"version":3,"file":"Overview.js","sourceRoot":"","sources":["../../../../../src/containers/Tenant/Diagnostics/Overview/Overview.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import * as NiceModal from '@ebay/nice-modal-react';
|
|
3
|
+
import type { DialogFooterProps } from '@gravity-ui/uikit';
|
|
4
|
+
import type { ManagePartitioningFormState } from './types';
|
|
5
|
+
import './ManagePartitioningDialog.scss';
|
|
6
|
+
interface CommonDialogProps {
|
|
7
|
+
initialValue?: ManagePartitioningFormState;
|
|
8
|
+
onApply?: (value: ManagePartitioningFormState) => void | Promise<void>;
|
|
9
|
+
}
|
|
10
|
+
interface ManagePartitioningDialogNiceModalProps extends CommonDialogProps, DialogFooterProps {
|
|
11
|
+
onClose?: () => void;
|
|
12
|
+
}
|
|
13
|
+
export declare const ManagePartitioningDialogNiceModal: React.FC<ManagePartitioningDialogNiceModalProps & NiceModal.NiceModalHocProps>;
|
|
14
|
+
export declare function openManagePartitioningDialog(props?: Omit<ManagePartitioningDialogNiceModalProps, 'id'>): Promise<ManagePartitioningFormState | null>;
|
|
15
|
+
export {};
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import * as NiceModal from '@ebay/nice-modal-react';
|
|
4
|
+
import { Dialog, Flex, Switch, Text, TextInput } from '@gravity-ui/uikit';
|
|
5
|
+
import { Controller } from 'react-hook-form';
|
|
6
|
+
import { cn } from '../../../../../../utils/cn';
|
|
7
|
+
import { prepareErrorMessage } from '../../../../../../utils/prepareErrorMessage';
|
|
8
|
+
import { DEFAULT_PARTITION_SIZE_TO_SPLIT_BYTES } from '../constants';
|
|
9
|
+
import { SplitUnitSelect } from './SplitUnitSelect';
|
|
10
|
+
import { DEFAULT_MAX_SPLIT_SIZE_GB, MANAGE_PARTITIONING_DIALOG, UNIT_OPTIONS } from './constants';
|
|
11
|
+
import i18n from './i18n';
|
|
12
|
+
import { useManagePartitioningForm } from './useManagePartitionForm';
|
|
13
|
+
import './ManagePartitioningDialog.scss';
|
|
14
|
+
const b = cn(MANAGE_PARTITIONING_DIALOG);
|
|
15
|
+
function ManagePartitioningDialog({ onClose, open, renderButtons, initialValue, onApply, }) {
|
|
16
|
+
const [apiError, setApiError] = React.useState(null);
|
|
17
|
+
const [isSubmitting, setIsSubmitting] = React.useState(false);
|
|
18
|
+
const { control, handleSubmit, trigger, formState: { errors, isValid }, } = useManagePartitioningForm({
|
|
19
|
+
initialValue,
|
|
20
|
+
maxSplitSizeBytes: DEFAULT_PARTITION_SIZE_TO_SPLIT_BYTES,
|
|
21
|
+
});
|
|
22
|
+
const handleApply = handleSubmit(async (data) => {
|
|
23
|
+
setApiError(null);
|
|
24
|
+
setIsSubmitting(true);
|
|
25
|
+
try {
|
|
26
|
+
await (onApply === null || onApply === void 0 ? void 0 : onApply(data));
|
|
27
|
+
}
|
|
28
|
+
catch (error) {
|
|
29
|
+
setApiError(prepareErrorMessage(error));
|
|
30
|
+
}
|
|
31
|
+
finally {
|
|
32
|
+
setIsSubmitting(false);
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
return (_jsxs(Dialog, { size: "s", onClose: onClose, open: open, children: [_jsx(Dialog.Header, { caption: _jsx(Text, { variant: "subheader-3", children: i18n('title_manage-partitioning') }) }), _jsxs("form", { onSubmit: handleApply, children: [_jsx(Dialog.Body, { className: b('body'), children: _jsxs(Flex, { direction: "column", gap: "3", alignItems: "flex-start", children: [_jsx(Text, { variant: "subheader-1", children: i18n('title_partitioning') }), _jsxs(Flex, { className: b('row'), gap: "3", alignItems: "center", children: [_jsx("label", { htmlFor: "splitSize", className: b('label'), children: i18n('field_split-size') }), _jsx(Controller, { name: "splitSize", control: control, render: ({ field }) => {
|
|
36
|
+
var _a;
|
|
37
|
+
return (_jsx(TextInput, { id: "splitSize", type: "number", value: field.value, onUpdate: field.onChange, className: b('input'), errorMessage: (_a = errors.splitSize) === null || _a === void 0 ? void 0 : _a.message, validationState: errors.splitSize ? 'invalid' : undefined, endContent: _jsx(Controller, { name: "splitUnit", control: control, render: ({ field: unitField }) => (_jsx(SplitUnitSelect, { value: unitField.value, options: UNIT_OPTIONS, onChange: (nextUnit) => {
|
|
38
|
+
unitField.onChange(nextUnit);
|
|
39
|
+
trigger('splitSize');
|
|
40
|
+
} })) }) }));
|
|
41
|
+
} }), _jsx(Text, { variant: "body-1", className: b('hint'), children: i18n('context_split-size-maximum', {
|
|
42
|
+
maxGb: DEFAULT_MAX_SPLIT_SIZE_GB,
|
|
43
|
+
}) })] }), _jsxs(Flex, { className: b('row'), gap: "3", alignItems: "center", children: [_jsx("label", { htmlFor: "loadEnabled", className: b('label'), children: i18n('field_load') }), _jsx(Controller, { name: "loadEnabled", control: control, render: ({ field }) => (_jsx(Switch, { id: "loadEnabled", checked: field.value, onUpdate: field.onChange })) })] }), _jsx(Text, { variant: "subheader-1", children: i18n('title_limits') }), _jsxs(Flex, { className: b('row'), gap: "3", alignItems: "center", children: [_jsx("label", { htmlFor: "minimum", className: b('label'), children: i18n('field_minimum') }), _jsx(Controller, { name: "minimum", control: control, render: ({ field }) => {
|
|
44
|
+
var _a;
|
|
45
|
+
return (_jsx(TextInput, { id: "minimum", type: "number", value: field.value, onUpdate: (next) => {
|
|
46
|
+
field.onChange(next);
|
|
47
|
+
trigger('maximum'); // revalidate dependent field to clear stale error
|
|
48
|
+
}, className: b('input'), errorMessage: (_a = errors.minimum) === null || _a === void 0 ? void 0 : _a.message, validationState: errors.minimum ? 'invalid' : undefined }));
|
|
49
|
+
} })] }), _jsxs(Flex, { className: b('row'), gap: "3", alignItems: "center", children: [_jsx("label", { htmlFor: "maximum", className: b('label'), children: i18n('field_maximum') }), _jsx(Controller, { name: "maximum", control: control, render: ({ field }) => {
|
|
50
|
+
var _a;
|
|
51
|
+
return (_jsx(TextInput, { id: "maximum", type: "number", value: field.value, onUpdate: (next) => {
|
|
52
|
+
field.onChange(next);
|
|
53
|
+
trigger('minimum'); // revalidate dependent field to clear stale error
|
|
54
|
+
}, className: b('input'), errorMessage: (_a = errors.maximum) === null || _a === void 0 ? void 0 : _a.message, validationState: errors.maximum ? 'invalid' : undefined }));
|
|
55
|
+
} })] }), apiError && (_jsx(Text, { color: "danger", title: apiError, children: _jsx("div", { children: apiError }) }))] }) }), _jsx(Dialog.Footer, { textButtonApply: i18n('action_apply'), textButtonCancel: i18n('action_cancel'), onClickButtonCancel: onClose, loading: isSubmitting, renderButtons: renderButtons, propsButtonApply: {
|
|
56
|
+
type: 'submit',
|
|
57
|
+
disabled: isSubmitting || !isValid,
|
|
58
|
+
} })] })] }));
|
|
59
|
+
}
|
|
60
|
+
export const ManagePartitioningDialogNiceModal = NiceModal.create((props) => {
|
|
61
|
+
const modal = NiceModal.useModal();
|
|
62
|
+
const handleClose = () => {
|
|
63
|
+
modal.hide();
|
|
64
|
+
modal.remove();
|
|
65
|
+
};
|
|
66
|
+
return (_jsx(ManagePartitioningDialog, { ...props, onApply: async (value) => {
|
|
67
|
+
var _a;
|
|
68
|
+
await ((_a = props.onApply) === null || _a === void 0 ? void 0 : _a.call(props, value));
|
|
69
|
+
modal.resolve(value);
|
|
70
|
+
handleClose();
|
|
71
|
+
}, onClose: () => {
|
|
72
|
+
var _a;
|
|
73
|
+
(_a = props.onClose) === null || _a === void 0 ? void 0 : _a.call(props);
|
|
74
|
+
modal.resolve(null);
|
|
75
|
+
handleClose();
|
|
76
|
+
}, open: modal.visible }));
|
|
77
|
+
});
|
|
78
|
+
NiceModal.register(MANAGE_PARTITIONING_DIALOG, ManagePartitioningDialogNiceModal);
|
|
79
|
+
export function openManagePartitioningDialog(props) {
|
|
80
|
+
return NiceModal.show(MANAGE_PARTITIONING_DIALOG, {
|
|
81
|
+
id: MANAGE_PARTITIONING_DIALOG,
|
|
82
|
+
...props,
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
//# sourceMappingURL=ManagePartitioningDialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ManagePartitioningDialog.js","sourceRoot":"","sources":["../../../../../../../src/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/ManagePartitioningDialog.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
@use '../../../../../../styles/mixins.scss';
|
|
2
|
+
|
|
3
|
+
.manage-partitioning-dialog {
|
|
4
|
+
&__body {
|
|
5
|
+
padding-top: var(--g-spacing-3);
|
|
6
|
+
padding-bottom: 0;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
&__row {
|
|
10
|
+
width: 100%;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
&__hint,
|
|
14
|
+
&__label {
|
|
15
|
+
color: var(--g-color-text-secondary);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
&__label {
|
|
19
|
+
width: 100%;
|
|
20
|
+
max-width: 80px;
|
|
21
|
+
|
|
22
|
+
@include mixins.body-1-typography();
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
&__input {
|
|
26
|
+
max-width: 212px;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { SelectProps } from '@gravity-ui/uikit';
|
|
2
|
+
import type { UnitOptionsType } from './constants';
|
|
3
|
+
import './SplitUnitSelect.scss';
|
|
4
|
+
interface SplitUnitSelectProps {
|
|
5
|
+
value: string;
|
|
6
|
+
options: UnitOptionsType;
|
|
7
|
+
width?: number;
|
|
8
|
+
size?: SelectProps['size'];
|
|
9
|
+
onChange: (nextValue: string) => void;
|
|
10
|
+
}
|
|
11
|
+
export declare function SplitUnitSelect({ value, options, width, size, onChange, }: SplitUnitSelectProps): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export {};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { ArrowToggle, Button, Flex, Select, Text } from '@gravity-ui/uikit';
|
|
4
|
+
import { cn } from '../../../../../../utils/cn';
|
|
5
|
+
import './SplitUnitSelect.scss';
|
|
6
|
+
const b = cn('split-unit-select');
|
|
7
|
+
export function SplitUnitSelect({ value, options, width = 55, size = 's', onChange, }) {
|
|
8
|
+
var _a;
|
|
9
|
+
const [isOpen, setIsOpen] = React.useState(false);
|
|
10
|
+
const selected = React.useMemo(() => options.find((option) => option.value === value), [options, value]);
|
|
11
|
+
const selectedLabel = (_a = selected === null || selected === void 0 ? void 0 : selected.content) !== null && _a !== void 0 ? _a : value;
|
|
12
|
+
const handleOpenChange = React.useCallback((nextOpen) => {
|
|
13
|
+
setIsOpen(nextOpen);
|
|
14
|
+
}, []);
|
|
15
|
+
const handleToggleOpen = React.useCallback(() => {
|
|
16
|
+
setIsOpen((open) => !open);
|
|
17
|
+
}, []);
|
|
18
|
+
const renderControl = React.useCallback(() => (_jsx(Button, { type: "button", className: b('button'), size: size, onClick: handleToggleOpen, children: _jsxs(Flex, { justifyContent: "space-between", alignItems: "center", gap: "1", className: b('button-content'), children: [_jsx(Text, { children: selectedLabel }), _jsx(ArrowToggle, { direction: "bottom" })] }) })), [handleToggleOpen, selectedLabel, size]);
|
|
19
|
+
return (_jsx(Select, { size: size, className: b('select'), options: options, value: [value], open: isOpen, width: width, onOpenChange: handleOpenChange, renderControl: renderControl, onUpdate: (next) => {
|
|
20
|
+
var _a;
|
|
21
|
+
const nextUnit = (_a = next === null || next === void 0 ? void 0 : next[0]) !== null && _a !== void 0 ? _a : value;
|
|
22
|
+
onChange(nextUnit);
|
|
23
|
+
setIsOpen(false);
|
|
24
|
+
} }));
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=SplitUnitSelect.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SplitUnitSelect.js","sourceRoot":"","sources":["../../../../../../../src/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/SplitUnitSelect.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,EAAC,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAE1E,OAAO,EAAC,EAAE,EAAC,MAAM,4BAA4B,CAAC;AAI9C,OAAO,wBAAwB,CAAC;AAEhC,MAAM,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC,CAAC;AAUlC,MAAM,UAAU,eAAe,CAAC,EAC5B,KAAK,EACL,OAAO,EACP,KAAK,GAAG,EAAE,EACV,IAAI,GAAG,GAAG,EACV,QAAQ,GACW;;IACnB,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAElD,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAC1B,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,KAAK,KAAK,CAAC,EACtD,CAAC,OAAO,EAAE,KAAK,CAAC,CACnB,CAAC;IACF,MAAM,aAAa,GAAG,MAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,OAAO,mCAAI,KAAK,CAAC;IAEjD,MAAM,gBAAgB,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC,QAAiB,EAAE,EAAE;QAC7D,SAAS,CAAC,QAAQ,CAAC,CAAC;IACxB,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,gBAAgB,GAAG,KAAK,CAAC,WAAW,CAAC,GAAG,EAAE;QAC5C,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,aAAa,GAAiC,KAAK,CAAC,WAAW,CACjE,GAAG,EAAE,CAAC,CACF,KAAC,MAAM,IAAC,IAAI,EAAC,QAAQ,EAAC,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,gBAAgB,YAC/E,MAAC,IAAI,IACD,cAAc,EAAC,eAAe,EAC9B,UAAU,EAAC,QAAQ,EACnB,GAAG,EAAC,GAAG,EACP,SAAS,EAAE,CAAC,CAAC,gBAAgB,CAAC,aAE9B,KAAC,IAAI,cAAE,aAAa,GAAQ,EAC5B,KAAC,WAAW,IAAC,SAAS,EAAC,QAAQ,GAAG,IAC/B,GACF,CACZ,EACD,CAAC,gBAAgB,EAAE,aAAa,EAAE,IAAI,CAAC,CAC1C,CAAC;IAEF,OAAO,CACH,KAAC,MAAM,IACH,IAAI,EAAE,IAAI,EACV,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,EACtB,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,CAAC,KAAK,CAAC,EACd,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,KAAK,EACZ,YAAY,EAAE,gBAAgB,EAC9B,aAAa,EAAE,aAAa,EAC5B,QAAQ,EAAE,CAAC,IAAI,EAAE,EAAE;;YACf,MAAM,QAAQ,GAAG,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAG,CAAC,CAAC,mCAAI,KAAK,CAAC;YACpC,QAAQ,CAAC,QAAQ,CAAC,CAAC;YACnB,SAAS,CAAC,KAAK,CAAC,CAAC;QACrB,CAAC,GACH,CACL,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { BytesSizes } from '../../../../../../utils/bytesParsers';
|
|
2
|
+
import type { ManagePartitioningFormState } from './types';
|
|
3
|
+
export type UnitOptionsType = Array<{
|
|
4
|
+
value: BytesSizes;
|
|
5
|
+
content: string;
|
|
6
|
+
}>;
|
|
7
|
+
export declare const UNIT_OPTIONS: UnitOptionsType;
|
|
8
|
+
export declare const DEFAULT_MAX_SPLIT_SIZE_GB: string;
|
|
9
|
+
export declare const DEFAULT_MANAGE_PARTITIONING_VALUE: ManagePartitioningFormState;
|
|
10
|
+
export declare const MANAGE_PARTITIONING_DIALOG = "manage-partitioning-dialog";
|
package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/constants.js
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { formatBytes, sizes } from '../../../../../../utils/bytesParsers';
|
|
2
|
+
import { DEFAULT_PARTITION_SIZE_TO_SPLIT_BYTES } from '../constants';
|
|
3
|
+
export const UNIT_OPTIONS = Object.keys(sizes).map((value) => ({
|
|
4
|
+
value,
|
|
5
|
+
content: sizes[value].label,
|
|
6
|
+
}));
|
|
7
|
+
export const DEFAULT_MAX_SPLIT_SIZE_GB = formatBytes({
|
|
8
|
+
value: DEFAULT_PARTITION_SIZE_TO_SPLIT_BYTES,
|
|
9
|
+
size: 'gb',
|
|
10
|
+
withSizeLabel: false,
|
|
11
|
+
});
|
|
12
|
+
export const DEFAULT_MANAGE_PARTITIONING_VALUE = {
|
|
13
|
+
splitSize: DEFAULT_MAX_SPLIT_SIZE_GB,
|
|
14
|
+
splitUnit: 'gb',
|
|
15
|
+
loadEnabled: true,
|
|
16
|
+
minimum: '40',
|
|
17
|
+
maximum: '1000',
|
|
18
|
+
};
|
|
19
|
+
export const MANAGE_PARTITIONING_DIALOG = 'manage-partitioning-dialog';
|
|
20
|
+
//# sourceMappingURL=constants.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../../../../src/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/constants.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,WAAW,EAAE,KAAK,EAAC,MAAM,sCAAsC,CAAC;AACxE,OAAO,EAAC,qCAAqC,EAAC,MAAM,cAAc,CAAC;AAMnE,MAAM,CAAC,MAAM,YAAY,GAAqB,MAAM,CAAC,IAAI,CAAC,KAAK,CAAkB,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IAC9F,KAAK;IACL,OAAO,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,KAAK;CAC9B,CAAC,CAAC,CAAC;AAEJ,MAAM,CAAC,MAAM,yBAAyB,GAAG,WAAW,CAAC;IACjD,KAAK,EAAE,qCAAqC;IAC5C,IAAI,EAAE,IAAI;IACV,aAAa,EAAE,KAAK;CACvB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,iCAAiC,GAAgC;IAC1E,SAAS,EAAE,yBAAyB;IACpC,SAAS,EAAE,IAAI;IACf,WAAW,EAAE,IAAI;IACjB,OAAO,EAAE,IAAI;IACb,OAAO,EAAE,MAAM;CAClB,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,4BAA4B,CAAC"}
|
package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/i18n/en.json
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
{
|
|
2
|
+
"title_manage-partitioning": "Manage partitioning",
|
|
3
|
+
"title_partitioning": "Partitioning",
|
|
4
|
+
"title_limits": "Limits",
|
|
5
|
+
"field_split-size": "Split Size",
|
|
6
|
+
"context_split-size-maximum": "{{maxGb}} GB maximum",
|
|
7
|
+
"field_load": "Load",
|
|
8
|
+
"field_minimum": "Minimum",
|
|
9
|
+
"field_maximum": "Maximum",
|
|
10
|
+
"action_cancel": "Cancel",
|
|
11
|
+
"action_apply": "Apply",
|
|
12
|
+
"error_invalid-unit": "Invalid unit",
|
|
13
|
+
"error_required": "The field is required",
|
|
14
|
+
"error_value-greater-maximum": "Value must not be greater than maximum",
|
|
15
|
+
"error_minimum-greater-maximum": "Minimum must not be greater than maximum",
|
|
16
|
+
"error_maximum-less-minimum": "Maximum must not be less than minimum",
|
|
17
|
+
"error_value-too-small": "Value must be at least 1 MB"
|
|
18
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
declare const _default: (key: "action_cancel" | "action_apply" | "title_manage-partitioning" | "title_partitioning" | "title_limits" | "field_split-size" | "context_split-size-maximum" | "field_load" | "field_minimum" | "field_maximum" | "error_invalid-unit" | "error_required" | "error_value-greater-maximum" | "error_minimum-greater-maximum" | "error_maximum-less-minimum" | "error_value-too-small", params?: import("@gravity-ui/i18n").Params) => string;
|
|
2
|
+
export default _default;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../src/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/i18n/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAC,MAAM,iCAAiC,CAAC;AAEhE,OAAO,EAAE,MAAM,WAAW,CAAC;AAE3B,MAAM,SAAS,GAAG,4BAA4B,CAAC;AAE/C,eAAe,eAAe,CAAC,SAAS,EAAE,EAAC,EAAE,EAAC,CAAC,CAAC"}
|
package/dist/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/types.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../../../src/containers/Tenant/Diagnostics/Overview/TableInfo/ManagePartitioningDialog/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ManagePartitioningFormState } from './types';
|
|
2
|
+
export declare function useManagePartitioningForm(params: {
|
|
3
|
+
initialValue?: ManagePartitioningFormState;
|
|
4
|
+
maxSplitSizeBytes: number;
|
|
5
|
+
}): import("react-hook-form").UseFormReturn<ManagePartitioningFormState, any, undefined>;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { zodResolver } from '@hookform/resolvers/zod';
|
|
3
|
+
import { useForm } from 'react-hook-form';
|
|
4
|
+
import { getManagePartitioningInitialValues, managePartitioningSchema } from './utils';
|
|
5
|
+
export function useManagePartitioningForm(params) {
|
|
6
|
+
const { initialValue, maxSplitSizeBytes } = params;
|
|
7
|
+
const schema = React.useMemo(() => managePartitioningSchema(maxSplitSizeBytes), [maxSplitSizeBytes]);
|
|
8
|
+
const form = useForm({
|
|
9
|
+
defaultValues: getManagePartitioningInitialValues(initialValue),
|
|
10
|
+
resolver: zodResolver(schema),
|
|
11
|
+
mode: 'onChange',
|
|
12
|
+
});
|
|
13
|
+
return form;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=useManagePartitionForm.js.map
|