@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
@@ -4,7 +4,10 @@ import {
4
4
  BareMetalSVG,
5
5
  ContainerAppsSVG,
6
6
  ElasticCloudServerWithGpuSVG,
7
+ EvoDnsSVG,
8
+ EvolutionBiSVG,
7
9
  EvolutionComputeSVG,
10
+ LoadBalancerSVG,
8
11
  ManagedKubernetesSVG,
9
12
  ManagedPostgreSqlSVG,
10
13
  MetastoreSVG,
@@ -39,6 +42,9 @@ import {
39
42
  EVOLUTION_STORAGE_S3_FORM_CONFIG,
40
43
  EVOLUTION_STORAGE_S3_FREE_TIER_FORM_CONFIG,
41
44
  } from './product-config';
45
+ import { EVOLUTION_DNS_CONFIG } from './product-config/EvolutionDNS';
46
+ import { EVOLUTION_LOAD_BALANCER_CONFIG } from './product-config/EvolutionLoadBalancer';
47
+ import { EVOLUTION_MANAGED_BI } from './product-config/EvolutionManagedBI';
42
48
  import { EVOLUTION_MANAGED_REDIS_CONFIG } from './product-config/EvolutionManagedRedis';
43
49
  import { EVOLUTION_MANAGED_SPARK_CONFIG } from './product-config/EvolutionManagedSpark';
44
50
 
@@ -127,6 +133,16 @@ export const EVOLUTION_PRODUCTS: CatalogConfig['products'] = {
127
133
  dataTestId: 'EvolutionManagedRedis',
128
134
  enableConnectToConsole: true,
129
135
  },
136
+ [EVOLUTION_PRODUCT.EvolutionLoadBalancer]: {
137
+ id: EVOLUTION_PRODUCT.EvolutionLoadBalancer,
138
+ platform: PLATFORM.Evolution,
139
+ label: 'Evolution Load Balancer',
140
+ caption: 'Сервис для балансировки сетевого трафика',
141
+ formConfig: EVOLUTION_LOAD_BALANCER_CONFIG,
142
+ icon: LoadBalancerSVG,
143
+ dataTestId: 'EvolutionLoadBalancer',
144
+ enableConnectToConsole: true,
145
+ },
130
146
  [EVOLUTION_PRODUCT.EvolutionStorageS3]: {
131
147
  id: EVOLUTION_PRODUCT.EvolutionStorageS3,
132
148
  platform: PLATFORM.Evolution,
@@ -235,6 +251,17 @@ export const EVOLUTION_PRODUCTS: CatalogConfig['products'] = {
235
251
  enableChangeProductQuantity: true,
236
252
  enableConnectToConsole: true,
237
253
  },
254
+ [EVOLUTION_PRODUCT.EvolutionDNS]: {
255
+ id: EVOLUTION_PRODUCT.EvolutionDNS,
256
+ platform: PLATFORM.Evolution,
257
+ label: 'Evolution DNS',
258
+ caption: 'Сервис для управления публичными и приватными доменными зонами на облачной платформе Cloud.ru Evolution',
259
+ icon: EvoDnsSVG,
260
+ formConfig: EVOLUTION_DNS_CONFIG,
261
+ dataTestId: EVOLUTION_PRODUCT.EvolutionDNS,
262
+ enableChangeProductQuantity: true,
263
+ enableConnectToConsole: true,
264
+ },
238
265
  [EVOLUTION_PRODUCT.EvolutionPublicIp]: {
239
266
  id: EVOLUTION_PRODUCT.EvolutionPublicIp,
240
267
  platform: PLATFORM.Evolution,
@@ -257,4 +284,15 @@ export const EVOLUTION_PRODUCTS: CatalogConfig['products'] = {
257
284
  enableChangeProductQuantity: false,
258
285
  enableConnectToConsole: true,
259
286
  },
287
+ [EVOLUTION_PRODUCT.EvolutionManagedBI]: {
288
+ id: EVOLUTION_PRODUCT.EvolutionManagedBI,
289
+ platform: PLATFORM.Evolution,
290
+ label: 'Evolution Managed BI',
291
+ caption: 'Управляемые инстансы Business Intelligence',
292
+ icon: EvolutionBiSVG,
293
+ formConfig: EVOLUTION_MANAGED_BI,
294
+ dataTestId: EVOLUTION_PRODUCT.EvolutionManagedBI,
295
+ enableChangeProductQuantity: false,
296
+ enableConnectToConsole: true,
297
+ },
260
298
  };
@@ -1,6 +1,9 @@
1
+ import { QuestionRoundSVG } from '@cloud-ru/uikit-product-icons';
2
+ import { Tooltip } from '@snack-uikit/tooltip';
1
3
  import { ValueOf } from '@snack-uikit/utils';
2
4
 
3
- import { CONTROL, ObjectControl, SelectSingleControl, StepperControl } from '../../components';
5
+ import { CONTROL, ObjectControl, SelectSingleControl, StepperControl } from '../../../components';
6
+ import styles from './styles.module.scss';
4
7
 
5
8
  export const SpecificationItem = {
6
9
  Extreme_SSD: 'Extreme SSD',
@@ -12,10 +15,20 @@ export const specificationItems = [
12
15
  {
13
16
  value: SpecificationItem.Extreme_SSD,
14
17
  label: 'Extreme SSD',
18
+ afterContent: (
19
+ <Tooltip tip='Диски Ultra-high I/O с увеличенной пропускной способностью'>
20
+ <QuestionRoundSVG size={20} className={styles.icon} data-test-id='field-decorator__label-tooltip-trigger' />
21
+ </Tooltip>
22
+ ),
15
23
  },
16
24
  {
17
25
  value: SpecificationItem.Cloud_SSD,
18
26
  label: 'Cloud SSD',
27
+ afterContent: (
28
+ <Tooltip tip='Диски Ultra-high I/O'>
29
+ <QuestionRoundSVG size={20} className={styles.icon} data-test-id='field-decorator__label-tooltip-trigger' />
30
+ </Tooltip>
31
+ ),
19
32
  },
20
33
  ];
21
34
 
@@ -0,0 +1 @@
1
+ export { getDisk } from './diskPostgreSqlMySQL';
@@ -0,0 +1,8 @@
1
+ @use '@sbercloud/figma-tokens-cloud-platform/build/scss/components/styles-tokens-fields' as styles-tokens-fields;
2
+
3
+ .icon {
4
+ flex-shrink: 0;
5
+ box-sizing: content-box;
6
+ color: styles-tokens-fields.$sys-neutral-text-light;
7
+ margin: auto 0;
8
+ }
@@ -1,6 +1,7 @@
1
1
  export * from './useAdaptive';
2
2
 
3
3
  export * from './useCatalogCardClick';
4
+ export * from './useCatalogLockBodyScroll';
4
5
 
5
6
  export * from './useProductClick';
6
7
  export * from './useProductDelete';
@@ -0,0 +1,19 @@
1
+ import { useEffect } from 'react';
2
+
3
+ type UseLockBodyScrollProps = {
4
+ catalogOpen: boolean;
5
+ };
6
+
7
+ // FIXME: убрать после задачи PDS-3175
8
+ export const useCatalogLockBodyScroll = ({ catalogOpen }: UseLockBodyScrollProps) => {
9
+ useEffect(() => {
10
+ if (catalogOpen) {
11
+ document.body.style.overflow = 'hidden';
12
+ } else {
13
+ document.body.style.overflow = 'auto';
14
+ }
15
+ return () => {
16
+ document.body.style.overflow = 'auto';
17
+ };
18
+ }, [catalogOpen]);
19
+ };