@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.
Files changed (65) hide show
  1. package/CHANGELOG.md +24 -0
  2. package/dist/cjs/components/Catalog/Catalog.js +2 -0
  3. package/dist/cjs/components/Controls/SelectControl/SelectControl.d.ts +1 -0
  4. package/dist/cjs/components/Controls/SelectControl/SelectControl.js +1 -0
  5. package/dist/cjs/config/platforms/advanced/product-config/AdvancedMySqlDataBase.js +1 -1
  6. package/dist/cjs/config/platforms/advanced/product-config/AdvancedPostgreSqlDatabase.js +1 -1
  7. package/dist/cjs/config/platforms/evolution/catalog.js +7 -1
  8. package/dist/cjs/config/platforms/evolution/constants.d.ts +3 -0
  9. package/dist/cjs/config/platforms/evolution/constants.js +3 -0
  10. package/dist/cjs/config/platforms/evolution/product-config/EvolutionDNS.d.ts +2 -0
  11. package/dist/cjs/config/platforms/evolution/product-config/EvolutionDNS.js +99 -0
  12. package/dist/cjs/config/platforms/evolution/product-config/EvolutionLoadBalancer.d.ts +2 -0
  13. package/dist/cjs/config/platforms/evolution/product-config/EvolutionLoadBalancer.js +62 -0
  14. package/dist/cjs/config/platforms/evolution/product-config/EvolutionManagedBI.d.ts +2 -0
  15. package/dist/cjs/config/platforms/evolution/product-config/EvolutionManagedBI.js +35 -0
  16. package/dist/cjs/config/platforms/evolution/products.js +35 -0
  17. package/dist/cjs/config/utils/{diskPostgreSqlMySQL.d.ts → diskPostgreSqlMySQL/diskPostgreSqlMySQL.d.ts} +3 -1
  18. package/dist/cjs/config/utils/{diskPostgreSqlMySQL.js → diskPostgreSqlMySQL/diskPostgreSqlMySQL.js} +10 -1
  19. package/dist/cjs/config/utils/diskPostgreSqlMySQL/index.d.ts +1 -0
  20. package/dist/cjs/config/utils/diskPostgreSqlMySQL/index.js +5 -0
  21. package/dist/cjs/config/utils/diskPostgreSqlMySQL/styles.module.css +6 -0
  22. package/dist/cjs/hooks/index.d.ts +1 -0
  23. package/dist/cjs/hooks/index.js +1 -0
  24. package/dist/cjs/hooks/useCatalogLockBodyScroll.d.ts +5 -0
  25. package/dist/cjs/hooks/useCatalogLockBodyScroll.js +19 -0
  26. package/dist/esm/components/Catalog/Catalog.js +3 -1
  27. package/dist/esm/components/Controls/SelectControl/SelectControl.d.ts +1 -0
  28. package/dist/esm/components/Controls/SelectControl/SelectControl.js +1 -0
  29. package/dist/esm/config/platforms/advanced/product-config/AdvancedMySqlDataBase.js +1 -1
  30. package/dist/esm/config/platforms/advanced/product-config/AdvancedPostgreSqlDatabase.js +1 -1
  31. package/dist/esm/config/platforms/evolution/catalog.js +7 -1
  32. package/dist/esm/config/platforms/evolution/constants.d.ts +3 -0
  33. package/dist/esm/config/platforms/evolution/constants.js +3 -0
  34. package/dist/esm/config/platforms/evolution/product-config/EvolutionDNS.d.ts +2 -0
  35. package/dist/esm/config/platforms/evolution/product-config/EvolutionDNS.js +96 -0
  36. package/dist/esm/config/platforms/evolution/product-config/EvolutionLoadBalancer.d.ts +2 -0
  37. package/dist/esm/config/platforms/evolution/product-config/EvolutionLoadBalancer.js +59 -0
  38. package/dist/esm/config/platforms/evolution/product-config/EvolutionManagedBI.d.ts +2 -0
  39. package/dist/esm/config/platforms/evolution/product-config/EvolutionManagedBI.js +32 -0
  40. package/dist/esm/config/platforms/evolution/products.js +36 -1
  41. package/dist/esm/config/utils/{diskPostgreSqlMySQL.d.ts → diskPostgreSqlMySQL/diskPostgreSqlMySQL.d.ts} +3 -1
  42. package/dist/esm/config/utils/{diskPostgreSqlMySQL.js → diskPostgreSqlMySQL/diskPostgreSqlMySQL.js} +7 -1
  43. package/dist/esm/config/utils/diskPostgreSqlMySQL/index.d.ts +1 -0
  44. package/dist/esm/config/utils/diskPostgreSqlMySQL/index.js +1 -0
  45. package/dist/esm/config/utils/diskPostgreSqlMySQL/styles.module.css +6 -0
  46. package/dist/esm/hooks/index.d.ts +1 -0
  47. package/dist/esm/hooks/index.js +1 -0
  48. package/dist/esm/hooks/useCatalogLockBodyScroll.d.ts +5 -0
  49. package/dist/esm/hooks/useCatalogLockBodyScroll.js +15 -0
  50. package/package.json +2 -2
  51. package/src/components/Catalog/Catalog.tsx +4 -1
  52. package/src/components/Controls/SelectControl/SelectControl.tsx +2 -0
  53. package/src/config/platforms/advanced/product-config/AdvancedMySqlDataBase.ts +1 -1
  54. package/src/config/platforms/advanced/product-config/AdvancedPostgreSqlDatabase.ts +1 -1
  55. package/src/config/platforms/evolution/catalog.tsx +7 -1
  56. package/src/config/platforms/evolution/constants.ts +3 -0
  57. package/src/config/platforms/evolution/product-config/EvolutionDNS.ts +103 -0
  58. package/src/config/platforms/evolution/product-config/EvolutionLoadBalancer.tsx +60 -0
  59. package/src/config/platforms/evolution/product-config/EvolutionManagedBI.ts +34 -0
  60. package/src/config/platforms/evolution/products.ts +38 -0
  61. package/src/config/utils/{diskPostgreSqlMySQL.ts → diskPostgreSqlMySQL/diskPostgreSqlMySQL.tsx} +14 -1
  62. package/src/config/utils/diskPostgreSqlMySQL/index.ts +1 -0
  63. package/src/config/utils/diskPostgreSqlMySQL/styles.module.scss +8 -0
  64. package/src/hooks/index.ts +1 -0
  65. 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,2 @@
1
+ import { FormConfig } from '../../../../components';
2
+ export declare const EVOLUTION_LOAD_BALANCER_CONFIG: FormConfig;
@@ -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,2 @@
1
+ import { FormConfig } from '../../../../components';
2
+ export declare const EVOLUTION_MANAGED_BI: FormConfig;
@@ -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 '../../components';
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 = {
@@ -9,7 +9,11 @@ var __rest = (this && this.__rest) || function (s, e) {
9
9
  }
10
10
  return t;
11
11
  };
12
- import { CONTROL } from '../../components';
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';
@@ -0,0 +1,6 @@
1
+ .icon{
2
+ flex-shrink:0;
3
+ box-sizing:content-box;
4
+ color:var(--sys-neutral-text-light, #8b8e9b);
5
+ margin:auto 0;
6
+ }
@@ -1,4 +1,5 @@
1
1
  export * from './useAdaptive';
2
2
  export * from './useCatalogCardClick';
3
+ export * from './useCatalogLockBodyScroll';
3
4
  export * from './useProductClick';
4
5
  export * from './useProductDelete';
@@ -1,4 +1,5 @@
1
1
  export * from './useAdaptive';
2
2
  export * from './useCatalogCardClick';
3
+ export * from './useCatalogLockBodyScroll';
3
4
  export * from './useProductClick';
4
5
  export * from './useProductDelete';
@@ -0,0 +1,5 @@
1
+ type UseLockBodyScrollProps = {
2
+ catalogOpen: boolean;
3
+ };
4
+ export declare const useCatalogLockBodyScroll: ({ catalogOpen }: UseLockBodyScrollProps) => void;
5
+ export {};
@@ -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.33.6",
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": "ce69097516055b330a0b05da5e29ac5b66e56284"
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 Purpose',
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 Purpose',
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: [EVOLUTION_PRODUCT.EvolutionSnatGateway, EVOLUTION_PRODUCT.EvolutionPublicIp],
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
+ };