@cloud-ru/uikit-product-calculator 0.33.6 → 0.35.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/CHANGELOG.md +24 -0
- package/dist/cjs/components/Catalog/Catalog.js +2 -0
- package/dist/cjs/components/Controls/SelectControl/SelectControl.d.ts +1 -0
- package/dist/cjs/components/Controls/SelectControl/SelectControl.js +1 -0
- package/dist/cjs/config/platforms/advanced/product-config/AdvancedMySqlDataBase.js +1 -1
- package/dist/cjs/config/platforms/advanced/product-config/AdvancedPostgreSqlDatabase.js +1 -1
- package/dist/cjs/config/platforms/evolution/catalog.js +7 -1
- package/dist/cjs/config/platforms/evolution/constants.d.ts +3 -0
- package/dist/cjs/config/platforms/evolution/constants.js +3 -0
- package/dist/cjs/config/platforms/evolution/product-config/EvolutionDNS.d.ts +2 -0
- package/dist/cjs/config/platforms/evolution/product-config/EvolutionDNS.js +99 -0
- package/dist/cjs/config/platforms/evolution/product-config/EvolutionLoadBalancer.d.ts +2 -0
- package/dist/cjs/config/platforms/evolution/product-config/EvolutionLoadBalancer.js +62 -0
- package/dist/cjs/config/platforms/evolution/product-config/EvolutionManagedBI.d.ts +2 -0
- package/dist/cjs/config/platforms/evolution/product-config/EvolutionManagedBI.js +35 -0
- package/dist/cjs/config/platforms/evolution/products.js +35 -0
- package/dist/cjs/config/utils/{diskPostgreSqlMySQL.d.ts → diskPostgreSqlMySQL/diskPostgreSqlMySQL.d.ts} +3 -1
- package/dist/cjs/config/utils/{diskPostgreSqlMySQL.js → diskPostgreSqlMySQL/diskPostgreSqlMySQL.js} +10 -1
- package/dist/cjs/config/utils/diskPostgreSqlMySQL/index.d.ts +1 -0
- package/dist/cjs/config/utils/diskPostgreSqlMySQL/index.js +5 -0
- package/dist/cjs/config/utils/diskPostgreSqlMySQL/styles.module.css +6 -0
- package/dist/cjs/hooks/index.d.ts +1 -0
- package/dist/cjs/hooks/index.js +1 -0
- package/dist/cjs/hooks/useCatalogLockBodyScroll.d.ts +5 -0
- package/dist/cjs/hooks/useCatalogLockBodyScroll.js +19 -0
- package/dist/esm/components/Catalog/Catalog.js +3 -1
- package/dist/esm/components/Controls/SelectControl/SelectControl.d.ts +1 -0
- package/dist/esm/components/Controls/SelectControl/SelectControl.js +1 -0
- package/dist/esm/config/platforms/advanced/product-config/AdvancedMySqlDataBase.js +1 -1
- package/dist/esm/config/platforms/advanced/product-config/AdvancedPostgreSqlDatabase.js +1 -1
- package/dist/esm/config/platforms/evolution/catalog.js +7 -1
- package/dist/esm/config/platforms/evolution/constants.d.ts +3 -0
- package/dist/esm/config/platforms/evolution/constants.js +3 -0
- package/dist/esm/config/platforms/evolution/product-config/EvolutionDNS.d.ts +2 -0
- package/dist/esm/config/platforms/evolution/product-config/EvolutionDNS.js +96 -0
- package/dist/esm/config/platforms/evolution/product-config/EvolutionLoadBalancer.d.ts +2 -0
- package/dist/esm/config/platforms/evolution/product-config/EvolutionLoadBalancer.js +59 -0
- package/dist/esm/config/platforms/evolution/product-config/EvolutionManagedBI.d.ts +2 -0
- package/dist/esm/config/platforms/evolution/product-config/EvolutionManagedBI.js +32 -0
- package/dist/esm/config/platforms/evolution/products.js +36 -1
- package/dist/esm/config/utils/{diskPostgreSqlMySQL.d.ts → diskPostgreSqlMySQL/diskPostgreSqlMySQL.d.ts} +3 -1
- package/dist/esm/config/utils/{diskPostgreSqlMySQL.js → diskPostgreSqlMySQL/diskPostgreSqlMySQL.js} +7 -1
- package/dist/esm/config/utils/diskPostgreSqlMySQL/index.d.ts +1 -0
- package/dist/esm/config/utils/diskPostgreSqlMySQL/index.js +1 -0
- package/dist/esm/config/utils/diskPostgreSqlMySQL/styles.module.css +6 -0
- package/dist/esm/hooks/index.d.ts +1 -0
- package/dist/esm/hooks/index.js +1 -0
- package/dist/esm/hooks/useCatalogLockBodyScroll.d.ts +5 -0
- package/dist/esm/hooks/useCatalogLockBodyScroll.js +15 -0
- package/package.json +2 -2
- package/src/components/Catalog/Catalog.tsx +4 -1
- package/src/components/Controls/SelectControl/SelectControl.tsx +2 -0
- package/src/config/platforms/advanced/product-config/AdvancedMySqlDataBase.ts +1 -1
- package/src/config/platforms/advanced/product-config/AdvancedPostgreSqlDatabase.ts +1 -1
- package/src/config/platforms/evolution/catalog.tsx +7 -1
- package/src/config/platforms/evolution/constants.ts +3 -0
- package/src/config/platforms/evolution/product-config/EvolutionDNS.ts +103 -0
- package/src/config/platforms/evolution/product-config/EvolutionLoadBalancer.tsx +60 -0
- package/src/config/platforms/evolution/product-config/EvolutionManagedBI.ts +34 -0
- package/src/config/platforms/evolution/products.ts +38 -0
- package/src/config/utils/{diskPostgreSqlMySQL.ts → diskPostgreSqlMySQL/diskPostgreSqlMySQL.tsx} +14 -1
- package/src/config/utils/diskPostgreSqlMySQL/index.ts +1 -0
- package/src/config/utils/diskPostgreSqlMySQL/styles.module.scss +8 -0
- package/src/hooks/index.ts +1 -0
- package/src/hooks/useCatalogLockBodyScroll.ts +19 -0
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { CONTROL } from '../../../../components';
|
|
2
|
+
const domainZoneCards = [
|
|
3
|
+
{
|
|
4
|
+
value: 'Private',
|
|
5
|
+
label: 'Приватная доменная зона',
|
|
6
|
+
},
|
|
7
|
+
{
|
|
8
|
+
value: 'Public',
|
|
9
|
+
label: 'Публичная доменная зона',
|
|
10
|
+
},
|
|
11
|
+
{
|
|
12
|
+
value: 'null',
|
|
13
|
+
label: 'DNS-сервер',
|
|
14
|
+
},
|
|
15
|
+
];
|
|
16
|
+
const requestTypesCards = [
|
|
17
|
+
{
|
|
18
|
+
value: '0',
|
|
19
|
+
label: 'Запросы к приватным доменным зонам',
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
value: '1',
|
|
23
|
+
label: 'Запросы к публичным доменным зонам',
|
|
24
|
+
disabled: true,
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
value: '2',
|
|
28
|
+
label: 'Запросы к внешним доменным зонам',
|
|
29
|
+
disabled: true,
|
|
30
|
+
},
|
|
31
|
+
];
|
|
32
|
+
export const EVOLUTION_DNS_CONFIG = {
|
|
33
|
+
ui: ['domainZone', 'requestTypes', ['requestCount']],
|
|
34
|
+
controls: {
|
|
35
|
+
domainZone: {
|
|
36
|
+
decoratorProps: {
|
|
37
|
+
label: 'Тип услуги',
|
|
38
|
+
},
|
|
39
|
+
type: CONTROL.Segmented,
|
|
40
|
+
accessorKey: 'domainZone',
|
|
41
|
+
defaultValue: domainZoneCards[0].value,
|
|
42
|
+
items: domainZoneCards,
|
|
43
|
+
onChangeFn: (value, setValue) => {
|
|
44
|
+
const itemIndex = domainZoneCards.findIndex(domain => value === domain.value);
|
|
45
|
+
const arr = [
|
|
46
|
+
['domainZone', value],
|
|
47
|
+
['requestTypes', String(itemIndex)],
|
|
48
|
+
];
|
|
49
|
+
setValue(arr);
|
|
50
|
+
},
|
|
51
|
+
},
|
|
52
|
+
requestTypes: {
|
|
53
|
+
decoratorProps: {
|
|
54
|
+
label: 'Тип запросов',
|
|
55
|
+
},
|
|
56
|
+
type: CONTROL.Segmented,
|
|
57
|
+
accessorKey: 'requestTypes',
|
|
58
|
+
defaultValue: requestTypesCards[0].value,
|
|
59
|
+
items: requestTypesCards,
|
|
60
|
+
watchedControls: { domainZone: 'domainZone' },
|
|
61
|
+
relateFn: ({ domainZone }) => {
|
|
62
|
+
const itemIndex = domainZoneCards.findIndex(domain => domainZone === domain.value);
|
|
63
|
+
if (itemIndex >= 0) {
|
|
64
|
+
return {
|
|
65
|
+
items: requestTypesCards.map((type, index) => ({
|
|
66
|
+
value: type.value,
|
|
67
|
+
label: type.label,
|
|
68
|
+
disabled: itemIndex !== index,
|
|
69
|
+
})),
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
},
|
|
73
|
+
},
|
|
74
|
+
requestCount: {
|
|
75
|
+
type: CONTROL.Stepper,
|
|
76
|
+
accessorKey: 'requestCount',
|
|
77
|
+
defaultValue: 100,
|
|
78
|
+
decoratorProps: {
|
|
79
|
+
label: 'Количество запросов',
|
|
80
|
+
labelTooltip: 'Бесплатно',
|
|
81
|
+
},
|
|
82
|
+
uiProps: {
|
|
83
|
+
min: 100,
|
|
84
|
+
max: 9999900,
|
|
85
|
+
step: 100,
|
|
86
|
+
postfix: 'тыс',
|
|
87
|
+
},
|
|
88
|
+
watchedControls: { requestTypes: 'requestTypes' },
|
|
89
|
+
relateFn: ({ requestTypes }) => ({
|
|
90
|
+
decoratorProps: {
|
|
91
|
+
labelTooltip: requestTypes === '0' ? 'Бесплатно' : 'Бесплатно до 1 млн запросов',
|
|
92
|
+
},
|
|
93
|
+
}),
|
|
94
|
+
},
|
|
95
|
+
},
|
|
96
|
+
};
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { CONTROL } from '../../../../components';
|
|
2
|
+
export const EVOLUTION_LOAD_BALANCER_CONFIG = {
|
|
3
|
+
ui: [['availabilityZone'], ['outcomingTraffic'], ['incomingTraffic'], 'hasPublicIP'],
|
|
4
|
+
controls: {
|
|
5
|
+
availabilityZone: {
|
|
6
|
+
type: CONTROL.Stepper,
|
|
7
|
+
defaultValue: 1,
|
|
8
|
+
accessorKey: 'availabilityZone',
|
|
9
|
+
decoratorProps: {
|
|
10
|
+
label: 'Зоны доступности',
|
|
11
|
+
labelTooltip: 'В каждой зоне доступности по две ресурсные единицы',
|
|
12
|
+
},
|
|
13
|
+
uiProps: {
|
|
14
|
+
min: 1,
|
|
15
|
+
max: 3,
|
|
16
|
+
showHint: false,
|
|
17
|
+
postfix: 'Шт',
|
|
18
|
+
},
|
|
19
|
+
},
|
|
20
|
+
outcomingTraffic: {
|
|
21
|
+
type: CONTROL.Stepper,
|
|
22
|
+
defaultValue: 1,
|
|
23
|
+
accessorKey: 'outcomingTraffic',
|
|
24
|
+
decoratorProps: {
|
|
25
|
+
label: 'Исходящий трафик',
|
|
26
|
+
labelTooltip: 'Обработка балансировщиком L4 исходящего трафика',
|
|
27
|
+
},
|
|
28
|
+
uiProps: {
|
|
29
|
+
min: 0,
|
|
30
|
+
max: 9999999999,
|
|
31
|
+
showHint: false,
|
|
32
|
+
postfix: 'Гб',
|
|
33
|
+
},
|
|
34
|
+
},
|
|
35
|
+
incomingTraffic: {
|
|
36
|
+
type: CONTROL.Stepper,
|
|
37
|
+
defaultValue: 1,
|
|
38
|
+
accessorKey: 'incomingTraffic',
|
|
39
|
+
decoratorProps: {
|
|
40
|
+
label: 'Входящий трафик',
|
|
41
|
+
labelTooltip: 'Обработка балансировщиком L4 входящего трафика',
|
|
42
|
+
},
|
|
43
|
+
uiProps: {
|
|
44
|
+
min: 0,
|
|
45
|
+
max: 9999999999,
|
|
46
|
+
showHint: false,
|
|
47
|
+
postfix: 'Гб',
|
|
48
|
+
},
|
|
49
|
+
},
|
|
50
|
+
hasPublicIP: {
|
|
51
|
+
type: CONTROL.Toggle,
|
|
52
|
+
accessorKey: 'hasPublicIP',
|
|
53
|
+
defaultValue: false,
|
|
54
|
+
decoratorProps: {
|
|
55
|
+
label: 'Аренда публичного IP',
|
|
56
|
+
},
|
|
57
|
+
},
|
|
58
|
+
},
|
|
59
|
+
};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { CONTROL } from '../../../../components';
|
|
2
|
+
const configItems = [
|
|
3
|
+
{
|
|
4
|
+
value: '2, 4 (Freetier)',
|
|
5
|
+
label: '2 vCPU / 4 RAM (Freetier)',
|
|
6
|
+
},
|
|
7
|
+
{
|
|
8
|
+
value: '2, 4',
|
|
9
|
+
label: '2 vCPU / 4 RAM',
|
|
10
|
+
},
|
|
11
|
+
];
|
|
12
|
+
export const EVOLUTION_MANAGED_BI = {
|
|
13
|
+
ui: ['serviceAlert', ['name']],
|
|
14
|
+
controls: {
|
|
15
|
+
serviceAlert: {
|
|
16
|
+
type: CONTROL.Alert,
|
|
17
|
+
uiProps: {
|
|
18
|
+
description: 'Бесплатно предоставляем первый инстанс в заданной конфигурации',
|
|
19
|
+
},
|
|
20
|
+
accessorKey: 'tarification',
|
|
21
|
+
},
|
|
22
|
+
name: {
|
|
23
|
+
type: CONTROL.SelectSingle,
|
|
24
|
+
accessorKey: 'name',
|
|
25
|
+
items: configItems,
|
|
26
|
+
defaultValue: '2, 4 (freetier)',
|
|
27
|
+
decoratorProps: {
|
|
28
|
+
label: 'Конфигурация',
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
},
|
|
32
|
+
};
|
|
@@ -1,7 +1,10 @@
|
|
|
1
|
-
import { ArenadataDbSVG, ArtifactRegistrySVG, BareMetalSVG, ContainerAppsSVG, ElasticCloudServerWithGpuSVG, EvolutionComputeSVG, ManagedKubernetesSVG, ManagedPostgreSqlSVG, MetastoreSVG, MlInferenceSVG, PublicIpSVG, RedisSVG, S3StorageSVG, SnatSVG, SparkSVG, TrinoSVG, } from '@cloud-ru/uikit-product-icons';
|
|
1
|
+
import { ArenadataDbSVG, ArtifactRegistrySVG, BareMetalSVG, ContainerAppsSVG, ElasticCloudServerWithGpuSVG, EvoDnsSVG, EvolutionBiSVG, EvolutionComputeSVG, LoadBalancerSVG, ManagedKubernetesSVG, ManagedPostgreSqlSVG, MetastoreSVG, MlInferenceSVG, PublicIpSVG, RedisSVG, S3StorageSVG, SnatSVG, SparkSVG, TrinoSVG, } from '@cloud-ru/uikit-product-icons';
|
|
2
2
|
import { PLATFORM } from '../../../constants';
|
|
3
3
|
import { EVOLUTION_PRODUCT } from './constants';
|
|
4
4
|
import { EVOLUTION_ARENADATA_DB_FORM_CONFIG, EVOLUTION_ARTIFACT_REGISTRY, EVOLUTION_BARE_METAL_FORM_CONFIG, EVOLUTION_CLOUD_SERVER_FORM_CONFIG, EVOLUTION_CLOUD_SERVER_FREE_TIER_FORM_CONFIG, EVOLUTION_CLOUD_SERVER_GPU_FORM_CONFIG, EVOLUTION_CONTAINER_APPS_CONFIG, EVOLUTION_CONTAINER_APPS_FREE_TIER_CONFIG, EVOLUTION_KUBERNETES_FORM_CONFIG, EVOLUTION_MANAGED_METASTORE_CONFIG, EVOLUTION_MANAGED_TRINO_CONFIG, EVOLUTION_ML_INFERENCE_FORM_CONFIG, EVOLUTION_POSTGRE_SQL_FORM_CONFIG, EVOLUTION_PUBLIC_IP_FORM_CONFIG, EVOLUTION_SNAT_GATEWAY_FORM_CONFIG, EVOLUTION_STORAGE_S3_FORM_CONFIG, EVOLUTION_STORAGE_S3_FREE_TIER_FORM_CONFIG, } from './product-config';
|
|
5
|
+
import { EVOLUTION_DNS_CONFIG } from './product-config/EvolutionDNS';
|
|
6
|
+
import { EVOLUTION_LOAD_BALANCER_CONFIG } from './product-config/EvolutionLoadBalancer';
|
|
7
|
+
import { EVOLUTION_MANAGED_BI } from './product-config/EvolutionManagedBI';
|
|
5
8
|
import { EVOLUTION_MANAGED_REDIS_CONFIG } from './product-config/EvolutionManagedRedis';
|
|
6
9
|
import { EVOLUTION_MANAGED_SPARK_CONFIG } from './product-config/EvolutionManagedSpark';
|
|
7
10
|
export const EVOLUTION_PRODUCTS = {
|
|
@@ -89,6 +92,16 @@ export const EVOLUTION_PRODUCTS = {
|
|
|
89
92
|
dataTestId: 'EvolutionManagedRedis',
|
|
90
93
|
enableConnectToConsole: true,
|
|
91
94
|
},
|
|
95
|
+
[EVOLUTION_PRODUCT.EvolutionLoadBalancer]: {
|
|
96
|
+
id: EVOLUTION_PRODUCT.EvolutionLoadBalancer,
|
|
97
|
+
platform: PLATFORM.Evolution,
|
|
98
|
+
label: 'Evolution Load Balancer',
|
|
99
|
+
caption: 'Сервис для балансировки сетевого трафика',
|
|
100
|
+
formConfig: EVOLUTION_LOAD_BALANCER_CONFIG,
|
|
101
|
+
icon: LoadBalancerSVG,
|
|
102
|
+
dataTestId: 'EvolutionLoadBalancer',
|
|
103
|
+
enableConnectToConsole: true,
|
|
104
|
+
},
|
|
92
105
|
[EVOLUTION_PRODUCT.EvolutionStorageS3]: {
|
|
93
106
|
id: EVOLUTION_PRODUCT.EvolutionStorageS3,
|
|
94
107
|
platform: PLATFORM.Evolution,
|
|
@@ -196,6 +209,17 @@ export const EVOLUTION_PRODUCTS = {
|
|
|
196
209
|
enableChangeProductQuantity: true,
|
|
197
210
|
enableConnectToConsole: true,
|
|
198
211
|
},
|
|
212
|
+
[EVOLUTION_PRODUCT.EvolutionDNS]: {
|
|
213
|
+
id: EVOLUTION_PRODUCT.EvolutionDNS,
|
|
214
|
+
platform: PLATFORM.Evolution,
|
|
215
|
+
label: 'Evolution DNS',
|
|
216
|
+
caption: 'Сервис для управления публичными и приватными доменными зонами на облачной платформе Cloud.ru Evolution',
|
|
217
|
+
icon: EvoDnsSVG,
|
|
218
|
+
formConfig: EVOLUTION_DNS_CONFIG,
|
|
219
|
+
dataTestId: EVOLUTION_PRODUCT.EvolutionDNS,
|
|
220
|
+
enableChangeProductQuantity: true,
|
|
221
|
+
enableConnectToConsole: true,
|
|
222
|
+
},
|
|
199
223
|
[EVOLUTION_PRODUCT.EvolutionPublicIp]: {
|
|
200
224
|
id: EVOLUTION_PRODUCT.EvolutionPublicIp,
|
|
201
225
|
platform: PLATFORM.Evolution,
|
|
@@ -218,4 +242,15 @@ export const EVOLUTION_PRODUCTS = {
|
|
|
218
242
|
enableChangeProductQuantity: false,
|
|
219
243
|
enableConnectToConsole: true,
|
|
220
244
|
},
|
|
245
|
+
[EVOLUTION_PRODUCT.EvolutionManagedBI]: {
|
|
246
|
+
id: EVOLUTION_PRODUCT.EvolutionManagedBI,
|
|
247
|
+
platform: PLATFORM.Evolution,
|
|
248
|
+
label: 'Evolution Managed BI',
|
|
249
|
+
caption: 'Управляемые инстансы Business Intelligence',
|
|
250
|
+
icon: EvolutionBiSVG,
|
|
251
|
+
formConfig: EVOLUTION_MANAGED_BI,
|
|
252
|
+
dataTestId: EVOLUTION_PRODUCT.EvolutionManagedBI,
|
|
253
|
+
enableChangeProductQuantity: false,
|
|
254
|
+
enableConnectToConsole: true,
|
|
255
|
+
},
|
|
221
256
|
};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ValueOf } from '@snack-uikit/utils';
|
|
2
|
-
import { ObjectControl, SelectSingleControl, StepperControl } from '
|
|
2
|
+
import { ObjectControl, SelectSingleControl, StepperControl } from '../../../components';
|
|
3
3
|
export declare const SpecificationItem: {
|
|
4
4
|
readonly Extreme_SSD: "Extreme SSD";
|
|
5
5
|
readonly Cloud_SSD: "Cloud SSD";
|
|
@@ -8,9 +8,11 @@ export declare const SpecificationItem: {
|
|
|
8
8
|
export declare const specificationItems: ({
|
|
9
9
|
value: "Extreme SSD";
|
|
10
10
|
label: string;
|
|
11
|
+
afterContent: import("react/jsx-runtime").JSX.Element;
|
|
11
12
|
} | {
|
|
12
13
|
value: "Cloud SSD";
|
|
13
14
|
label: string;
|
|
15
|
+
afterContent: import("react/jsx-runtime").JSX.Element;
|
|
14
16
|
})[];
|
|
15
17
|
type DiskSpecification = ValueOf<typeof SpecificationItem>;
|
|
16
18
|
type GetDiskProps = {
|
package/dist/esm/config/utils/{diskPostgreSqlMySQL.js → diskPostgreSqlMySQL/diskPostgreSqlMySQL.js}
RENAMED
|
@@ -9,7 +9,11 @@ var __rest = (this && this.__rest) || function (s, e) {
|
|
|
9
9
|
}
|
|
10
10
|
return t;
|
|
11
11
|
};
|
|
12
|
-
import {
|
|
12
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
13
|
+
import { QuestionRoundSVG } from '@cloud-ru/uikit-product-icons';
|
|
14
|
+
import { Tooltip } from '@snack-uikit/tooltip';
|
|
15
|
+
import { CONTROL } from '../../../components';
|
|
16
|
+
import styles from './styles.module.css';
|
|
13
17
|
export const SpecificationItem = {
|
|
14
18
|
Extreme_SSD: 'Extreme SSD',
|
|
15
19
|
Cloud_SSD: 'Cloud SSD',
|
|
@@ -19,10 +23,12 @@ export const specificationItems = [
|
|
|
19
23
|
{
|
|
20
24
|
value: SpecificationItem.Extreme_SSD,
|
|
21
25
|
label: 'Extreme SSD',
|
|
26
|
+
afterContent: (_jsx(Tooltip, { tip: '\u0414\u0438\u0441\u043A\u0438 Ultra-high I/O \u0441 \u0443\u0432\u0435\u043B\u0438\u0447\u0435\u043D\u043D\u043E\u0439 \u043F\u0440\u043E\u043F\u0443\u0441\u043A\u043D\u043E\u0439 \u0441\u043F\u043E\u0441\u043E\u0431\u043D\u043E\u0441\u0442\u044C\u044E', children: _jsx(QuestionRoundSVG, { size: 20, className: styles.icon, "data-test-id": 'field-decorator__label-tooltip-trigger' }) })),
|
|
22
27
|
},
|
|
23
28
|
{
|
|
24
29
|
value: SpecificationItem.Cloud_SSD,
|
|
25
30
|
label: 'Cloud SSD',
|
|
31
|
+
afterContent: (_jsx(Tooltip, { tip: '\u0414\u0438\u0441\u043A\u0438 Ultra-high I/O', children: _jsx(QuestionRoundSVG, { size: 20, className: styles.icon, "data-test-id": 'field-decorator__label-tooltip-trigger' }) })),
|
|
26
32
|
},
|
|
27
33
|
];
|
|
28
34
|
export function getDisk({ space, specification }) {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { getDisk } from './diskPostgreSqlMySQL';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { getDisk } from './diskPostgreSqlMySQL';
|
package/dist/esm/hooks/index.js
CHANGED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { useEffect } from 'react';
|
|
2
|
+
// FIXME: убрать после задачи PDS-3175
|
|
3
|
+
export const useCatalogLockBodyScroll = ({ catalogOpen }) => {
|
|
4
|
+
useEffect(() => {
|
|
5
|
+
if (catalogOpen) {
|
|
6
|
+
document.body.style.overflow = 'hidden';
|
|
7
|
+
}
|
|
8
|
+
else {
|
|
9
|
+
document.body.style.overflow = 'auto';
|
|
10
|
+
}
|
|
11
|
+
return () => {
|
|
12
|
+
document.body.style.overflow = 'auto';
|
|
13
|
+
};
|
|
14
|
+
}, [catalogOpen]);
|
|
15
|
+
};
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cloud-ru/uikit-product-calculator",
|
|
3
3
|
"title": "Calculator",
|
|
4
|
-
"version": "0.
|
|
4
|
+
"version": "0.35.0",
|
|
5
5
|
"sideEffects": [
|
|
6
6
|
"*.css",
|
|
7
7
|
"*.woff",
|
|
@@ -71,5 +71,5 @@
|
|
|
71
71
|
"devDependencies": {
|
|
72
72
|
"@types/lodash": "4.17.13"
|
|
73
73
|
},
|
|
74
|
-
"gitHead": "
|
|
74
|
+
"gitHead": "021abe9a1bb7c6d6bc751ee4e4b6f4bcd3e7b4e7"
|
|
75
75
|
}
|
|
@@ -15,7 +15,7 @@ import { Tag } from '@snack-uikit/tag';
|
|
|
15
15
|
import { Tooltip } from '@snack-uikit/tooltip';
|
|
16
16
|
|
|
17
17
|
import { useCalculatorContext } from '../../contexts';
|
|
18
|
-
import { useCatalogCardClick } from '../../hooks';
|
|
18
|
+
import { useCatalogCardClick, useCatalogLockBodyScroll } from '../../hooks';
|
|
19
19
|
import { CatalogConfig, PlatformType } from '../../types';
|
|
20
20
|
import { parseKeyToDataTest } from '../../utils';
|
|
21
21
|
import { PrivateCardHeader } from './components';
|
|
@@ -67,6 +67,9 @@ export function Catalog() {
|
|
|
67
67
|
'data-test-id': dataTestId,
|
|
68
68
|
}));
|
|
69
69
|
|
|
70
|
+
// FIXME: убрать после задачи PDS-3175
|
|
71
|
+
useCatalogLockBodyScroll({ catalogOpen: catalogOpen });
|
|
72
|
+
|
|
70
73
|
const [openMobileCategory, setOpenMobileCategory] = useState<boolean>(false);
|
|
71
74
|
|
|
72
75
|
const isMobile = layoutType !== LAYOUT_TYPE.Desktop && layoutType !== LAYOUT_TYPE.DesktopSmall;
|
|
@@ -17,6 +17,7 @@ export type SelectControlItem = {
|
|
|
17
17
|
icon?: ReactNode;
|
|
18
18
|
disabled?: boolean;
|
|
19
19
|
disabledReason?: ReactNode;
|
|
20
|
+
afterContent?: ReactNode;
|
|
20
21
|
dataTestId?: string;
|
|
21
22
|
onChangePeriod?: (value: PRICE_PERIOD) => void;
|
|
22
23
|
canChangeWholePricePeriod?: boolean;
|
|
@@ -65,6 +66,7 @@ function convertItemsToOptions(items: SelectControlItem[]): BaseOptionProps[] {
|
|
|
65
66
|
disabled: item.disabled,
|
|
66
67
|
option: item.label ?? item.value,
|
|
67
68
|
beforeContent: item.icon,
|
|
69
|
+
afterContent: item.afterContent,
|
|
68
70
|
}));
|
|
69
71
|
}
|
|
70
72
|
|
|
@@ -15,7 +15,7 @@ const bdEngineVersionItems = [
|
|
|
15
15
|
},
|
|
16
16
|
{
|
|
17
17
|
value: BdEngineVersionItem.General_Purpose,
|
|
18
|
-
label: 'General
|
|
18
|
+
label: 'General-Purpose',
|
|
19
19
|
description: `Инстансы используют ресурсы процессора совместно с другими инстансами того же класса, размещенными на одном физическом сервере`,
|
|
20
20
|
},
|
|
21
21
|
];
|
|
@@ -34,7 +34,7 @@ const bdEngineVersionItems = [
|
|
|
34
34
|
},
|
|
35
35
|
{
|
|
36
36
|
value: BdEngineVersionItem.General_Purpose,
|
|
37
|
-
label: 'General
|
|
37
|
+
label: 'General-Purpose',
|
|
38
38
|
description: `Инстансы используют ресурсы процессора совместно с другими инстансами того же класса, размещенными на одном физическом сервере`,
|
|
39
39
|
},
|
|
40
40
|
];
|
|
@@ -65,7 +65,12 @@ export const EVOLUTION_CATALOG: CatalogConfig['catalog'] = {
|
|
|
65
65
|
id: CATEGORY.Network,
|
|
66
66
|
label: 'Сети',
|
|
67
67
|
dataTestId: 'network',
|
|
68
|
-
visibleProducts: [
|
|
68
|
+
visibleProducts: [
|
|
69
|
+
EVOLUTION_PRODUCT.EvolutionSnatGateway,
|
|
70
|
+
EVOLUTION_PRODUCT.EvolutionPublicIp,
|
|
71
|
+
EVOLUTION_PRODUCT.EvolutionLoadBalancer,
|
|
72
|
+
EVOLUTION_PRODUCT.EvolutionDNS,
|
|
73
|
+
],
|
|
69
74
|
},
|
|
70
75
|
{
|
|
71
76
|
id: CATEGORY.Storage,
|
|
@@ -95,6 +100,7 @@ export const EVOLUTION_CATALOG: CatalogConfig['catalog'] = {
|
|
|
95
100
|
EVOLUTION_PRODUCT.EvolutionManagedMetastore,
|
|
96
101
|
EVOLUTION_PRODUCT.EvolutionManagedRedis,
|
|
97
102
|
EVOLUTION_PRODUCT.EvolutionManagedSpark,
|
|
103
|
+
EVOLUTION_PRODUCT.EvolutionManagedBI,
|
|
98
104
|
],
|
|
99
105
|
},
|
|
100
106
|
{
|
|
@@ -14,10 +14,13 @@ export const EVOLUTION_PRODUCT = {
|
|
|
14
14
|
EvolutionSnatGateway: 'evolutionSnatGateway',
|
|
15
15
|
EvolutionManagedMetastore: 'evolutionManagedMetastore',
|
|
16
16
|
EvolutionPublicIp: 'evolutionPublicIp',
|
|
17
|
+
EvolutionDNS: 'evolutionDNS',
|
|
17
18
|
EvolutionArtifactRegistry: 'evolutionArtifactRegistry',
|
|
18
19
|
EvolutionManagedTrino: 'evolutionManagedTrino',
|
|
20
|
+
EvolutionManagedBI: 'evolutionManagedBI',
|
|
19
21
|
EvolutionManagedRedis: 'evolutionManagedRedis',
|
|
20
22
|
EvolutionManagedSpark: 'evolutionManagedSpark',
|
|
23
|
+
EvolutionLoadBalancer: 'evolutionLoadBalancer',
|
|
21
24
|
} as const;
|
|
22
25
|
|
|
23
26
|
const GuaranteedPartItem = {
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { CONTROL, FormConfig } from '../../../../components';
|
|
2
|
+
import { AnyType } from '../../../../types';
|
|
3
|
+
|
|
4
|
+
const domainZoneCards = [
|
|
5
|
+
{
|
|
6
|
+
value: 'Private',
|
|
7
|
+
label: 'Приватная доменная зона',
|
|
8
|
+
},
|
|
9
|
+
{
|
|
10
|
+
value: 'Public',
|
|
11
|
+
label: 'Публичная доменная зона',
|
|
12
|
+
},
|
|
13
|
+
{
|
|
14
|
+
value: 'null',
|
|
15
|
+
label: 'DNS-сервер',
|
|
16
|
+
},
|
|
17
|
+
];
|
|
18
|
+
|
|
19
|
+
const requestTypesCards = [
|
|
20
|
+
{
|
|
21
|
+
value: '0',
|
|
22
|
+
label: 'Запросы к приватным доменным зонам',
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
value: '1',
|
|
26
|
+
label: 'Запросы к публичным доменным зонам',
|
|
27
|
+
disabled: true,
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
value: '2',
|
|
31
|
+
label: 'Запросы к внешним доменным зонам',
|
|
32
|
+
disabled: true,
|
|
33
|
+
},
|
|
34
|
+
];
|
|
35
|
+
|
|
36
|
+
export const EVOLUTION_DNS_CONFIG: FormConfig = {
|
|
37
|
+
ui: ['domainZone', 'requestTypes', ['requestCount']],
|
|
38
|
+
controls: {
|
|
39
|
+
domainZone: {
|
|
40
|
+
decoratorProps: {
|
|
41
|
+
label: 'Тип услуги',
|
|
42
|
+
},
|
|
43
|
+
type: CONTROL.Segmented,
|
|
44
|
+
accessorKey: 'domainZone',
|
|
45
|
+
defaultValue: domainZoneCards[0].value,
|
|
46
|
+
items: domainZoneCards,
|
|
47
|
+
onChangeFn: (value, setValue) => {
|
|
48
|
+
const itemIndex = domainZoneCards.findIndex(domain => value === domain.value);
|
|
49
|
+
|
|
50
|
+
const arr: [string, AnyType][] = [
|
|
51
|
+
['domainZone', value],
|
|
52
|
+
['requestTypes', String(itemIndex)],
|
|
53
|
+
];
|
|
54
|
+
|
|
55
|
+
setValue(arr);
|
|
56
|
+
},
|
|
57
|
+
},
|
|
58
|
+
requestTypes: {
|
|
59
|
+
decoratorProps: {
|
|
60
|
+
label: 'Тип запросов',
|
|
61
|
+
},
|
|
62
|
+
type: CONTROL.Segmented,
|
|
63
|
+
accessorKey: 'requestTypes',
|
|
64
|
+
defaultValue: requestTypesCards[0].value,
|
|
65
|
+
items: requestTypesCards,
|
|
66
|
+
watchedControls: { domainZone: 'domainZone' },
|
|
67
|
+
relateFn: ({ domainZone }) => {
|
|
68
|
+
const itemIndex = domainZoneCards.findIndex(domain => domainZone === domain.value);
|
|
69
|
+
|
|
70
|
+
if (itemIndex >= 0) {
|
|
71
|
+
return {
|
|
72
|
+
items: requestTypesCards.map((type, index) => ({
|
|
73
|
+
value: type.value,
|
|
74
|
+
label: type.label,
|
|
75
|
+
disabled: itemIndex !== index,
|
|
76
|
+
})),
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
},
|
|
80
|
+
},
|
|
81
|
+
requestCount: {
|
|
82
|
+
type: CONTROL.Stepper,
|
|
83
|
+
accessorKey: 'requestCount',
|
|
84
|
+
defaultValue: 100,
|
|
85
|
+
decoratorProps: {
|
|
86
|
+
label: 'Количество запросов',
|
|
87
|
+
labelTooltip: 'Бесплатно',
|
|
88
|
+
},
|
|
89
|
+
uiProps: {
|
|
90
|
+
min: 100,
|
|
91
|
+
max: 9_999_900,
|
|
92
|
+
step: 100,
|
|
93
|
+
postfix: 'тыс',
|
|
94
|
+
},
|
|
95
|
+
watchedControls: { requestTypes: 'requestTypes' },
|
|
96
|
+
relateFn: ({ requestTypes }) => ({
|
|
97
|
+
decoratorProps: {
|
|
98
|
+
labelTooltip: requestTypes === '0' ? 'Бесплатно' : 'Бесплатно до 1 млн запросов',
|
|
99
|
+
},
|
|
100
|
+
}),
|
|
101
|
+
},
|
|
102
|
+
},
|
|
103
|
+
};
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { CONTROL, FormConfig } from '../../../../components';
|
|
2
|
+
|
|
3
|
+
export const EVOLUTION_LOAD_BALANCER_CONFIG: FormConfig = {
|
|
4
|
+
ui: [['availabilityZone'], ['outcomingTraffic'], ['incomingTraffic'], 'hasPublicIP'],
|
|
5
|
+
controls: {
|
|
6
|
+
availabilityZone: {
|
|
7
|
+
type: CONTROL.Stepper,
|
|
8
|
+
defaultValue: 1,
|
|
9
|
+
accessorKey: 'availabilityZone',
|
|
10
|
+
decoratorProps: {
|
|
11
|
+
label: 'Зоны доступности',
|
|
12
|
+
labelTooltip: 'В каждой зоне доступности по две ресурсные единицы',
|
|
13
|
+
},
|
|
14
|
+
uiProps: {
|
|
15
|
+
min: 1,
|
|
16
|
+
max: 3,
|
|
17
|
+
showHint: false,
|
|
18
|
+
postfix: 'Шт',
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
outcomingTraffic: {
|
|
22
|
+
type: CONTROL.Stepper,
|
|
23
|
+
defaultValue: 1,
|
|
24
|
+
accessorKey: 'outcomingTraffic',
|
|
25
|
+
decoratorProps: {
|
|
26
|
+
label: 'Исходящий трафик',
|
|
27
|
+
labelTooltip: 'Обработка балансировщиком L4 исходящего трафика',
|
|
28
|
+
},
|
|
29
|
+
uiProps: {
|
|
30
|
+
min: 0,
|
|
31
|
+
max: 9_999_999_999,
|
|
32
|
+
showHint: false,
|
|
33
|
+
postfix: 'Гб',
|
|
34
|
+
},
|
|
35
|
+
},
|
|
36
|
+
incomingTraffic: {
|
|
37
|
+
type: CONTROL.Stepper,
|
|
38
|
+
defaultValue: 1,
|
|
39
|
+
accessorKey: 'incomingTraffic',
|
|
40
|
+
decoratorProps: {
|
|
41
|
+
label: 'Входящий трафик',
|
|
42
|
+
labelTooltip: 'Обработка балансировщиком L4 входящего трафика',
|
|
43
|
+
},
|
|
44
|
+
uiProps: {
|
|
45
|
+
min: 0,
|
|
46
|
+
max: 9_999_999_999,
|
|
47
|
+
showHint: false,
|
|
48
|
+
postfix: 'Гб',
|
|
49
|
+
},
|
|
50
|
+
},
|
|
51
|
+
hasPublicIP: {
|
|
52
|
+
type: CONTROL.Toggle,
|
|
53
|
+
accessorKey: 'hasPublicIP',
|
|
54
|
+
defaultValue: false,
|
|
55
|
+
decoratorProps: {
|
|
56
|
+
label: 'Аренда публичного IP',
|
|
57
|
+
},
|
|
58
|
+
},
|
|
59
|
+
},
|
|
60
|
+
};
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { CONTROL, FormConfig } from '../../../../components';
|
|
2
|
+
|
|
3
|
+
const configItems = [
|
|
4
|
+
{
|
|
5
|
+
value: '2, 4 (Freetier)',
|
|
6
|
+
label: '2 vCPU / 4 RAM (Freetier)',
|
|
7
|
+
},
|
|
8
|
+
{
|
|
9
|
+
value: '2, 4',
|
|
10
|
+
label: '2 vCPU / 4 RAM',
|
|
11
|
+
},
|
|
12
|
+
];
|
|
13
|
+
|
|
14
|
+
export const EVOLUTION_MANAGED_BI: FormConfig = {
|
|
15
|
+
ui: ['serviceAlert', ['name']],
|
|
16
|
+
controls: {
|
|
17
|
+
serviceAlert: {
|
|
18
|
+
type: CONTROL.Alert,
|
|
19
|
+
uiProps: {
|
|
20
|
+
description: 'Бесплатно предоставляем первый инстанс в заданной конфигурации',
|
|
21
|
+
},
|
|
22
|
+
accessorKey: 'tarification',
|
|
23
|
+
},
|
|
24
|
+
name: {
|
|
25
|
+
type: CONTROL.SelectSingle,
|
|
26
|
+
accessorKey: 'name',
|
|
27
|
+
items: configItems,
|
|
28
|
+
defaultValue: '2, 4 (freetier)',
|
|
29
|
+
decoratorProps: {
|
|
30
|
+
label: 'Конфигурация',
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
},
|
|
34
|
+
};
|