bfg-common 1.5.161 → 1.5.162

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 (120) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/components/atoms/TheIcon3.vue +50 -50
  3. package/components/atoms/perPage/PerPage.vue +58 -58
  4. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  5. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  6. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  7. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  8. package/components/common/context/lib/models/interfaces.ts +31 -31
  9. package/components/common/context/recursion/RecursionNew.vue +238 -238
  10. package/components/common/diagramMain/DiagramMain.vue +897 -897
  11. package/components/common/diagramMain/Header.vue +214 -214
  12. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  13. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  14. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/lib/config/utils.ts +1040 -1040
  15. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  16. package/components/common/pages/home/headline/Headline.vue +45 -45
  17. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  18. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  19. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  20. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  21. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  22. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  23. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  24. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  25. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  26. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  27. package/components/common/pages/packages/Packages.vue +208 -208
  28. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  29. package/components/common/readyToComplete/New.vue +66 -66
  30. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  31. package/components/common/recursionTree/RecursionTree.vue +223 -223
  32. package/components/common/select/button/ButtonDropdown.vue +108 -108
  33. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  34. package/components/common/vm/actions/add/Add.vue +785 -785
  35. package/components/common/vm/actions/add/New.vue +556 -556
  36. package/components/common/vm/actions/add/Old.vue +371 -371
  37. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  38. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  39. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  40. package/components/common/vm/actions/add/lib/config/steps.ts +263 -263
  41. package/components/common/vm/actions/clone/Clone.vue +810 -810
  42. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  43. package/components/common/vm/actions/clone/toTemplate/ToTemplate.vue +626 -626
  44. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  45. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +319 -319
  46. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  47. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +100 -100
  48. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  49. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  50. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  51. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +70 -70
  52. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  53. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +338 -338
  54. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  55. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  56. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  57. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +375 -375
  58. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +149 -149
  59. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationNew.vue +74 -74
  60. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +83 -83
  61. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -288
  62. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
  63. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  64. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +30 -30
  75. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  76. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +102 -102
  77. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +75 -75
  78. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +26 -26
  79. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +57 -57
  80. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +171 -171
  81. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +50 -50
  82. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +140 -140
  83. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +30 -30
  84. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +30 -30
  85. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  86. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  87. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +39 -39
  88. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  89. package/components/common/vm/actions/common/lib/utils/capabilities.ts +52 -52
  90. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  91. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +134 -134
  92. package/components/common/vm/actions/common/select/computeResource/treeView/New.vue +44 -44
  93. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +118 -118
  94. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  95. package/components/common/vm/actions/common/select/createType/New.vue +84 -84
  96. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  97. package/components/common/vm/actions/common/select/name/Name.vue +167 -167
  98. package/components/common/vm/actions/common/select/os/New.vue +122 -122
  99. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  100. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  101. package/components/common/vm/actions/common/select/storage/Storage.vue +129 -129
  102. package/components/common/vm/actions/common/select/storage/new/lib/config/table.ts +326 -326
  103. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  104. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  105. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  106. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  107. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  108. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  109. package/components/common/wizards/vm/migrate/select/computeResource/tableView/TableView.vue +137 -137
  110. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  111. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  112. package/composables/productNameLocal.ts +30 -30
  113. package/composables/useAppVersion.ts +21 -21
  114. package/package.json +2 -2
  115. package/plugins/date.ts +233 -233
  116. package/public/spice-console/lib/images/bitmap.js +203 -203
  117. package/public/spice-console/network/spicechannel.js +383 -383
  118. package/store/main/mutations.ts +7 -7
  119. package/store/main/state.ts +7 -7
  120. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,21 +1,21 @@
1
- import type { UI_I_StatusData } from '~/components/common/vm/actions/common/select/storage/new/lib/models/interfaces'
2
-
3
- export const getStatus = (
4
- status: boolean,
5
- text1?: string,
6
- text2?: string
7
- ): UI_I_StatusData => {
8
- return status
9
- ? {
10
- iconClassName: 'status-check',
11
- color: 'green',
12
- isState: true,
13
- text: text1 || 'True',
14
- }
15
- : {
16
- iconClassName: 'close',
17
- color: 'red',
18
- isState: true,
19
- text: text2 || 'False',
20
- }
21
- }
1
+ import type { UI_I_StatusData } from '~/components/common/vm/actions/common/select/storage/new/lib/models/interfaces'
2
+
3
+ export const getStatus = (
4
+ status: boolean,
5
+ text1?: string,
6
+ text2?: string
7
+ ): UI_I_StatusData => {
8
+ return status
9
+ ? {
10
+ iconClassName: 'status-check',
11
+ color: 'green',
12
+ isState: true,
13
+ text: text1 || 'True',
14
+ }
15
+ : {
16
+ iconClassName: 'close',
17
+ color: 'red',
18
+ isState: true,
19
+ text: text2 || 'False',
20
+ }
21
+ }
@@ -1,88 +1,88 @@
1
- <template>
2
- <div class="skeleton-wrap">
3
- <div class="tabs">
4
- <ui-skeleton-item width="64px" height="16px" />
5
- <ui-skeleton-item width="64px" height="16px" />
6
- </div>
7
- <div class="actions">
8
- <ui-skeleton-item width="80px" height="16px" />
9
- <ui-skeleton-item width="152px" height="32px" border-radius="6px" />
10
- </div>
11
- <div class="stack-block-wrap">
12
- <div class="stack-block">
13
- <div class="stack-label flex-1">
14
- <ui-skeleton-item width="16px" height="16px" border-radius="50%" />
15
- <ui-skeleton-item height="16px" />
16
- </div>
17
- <div class="stack-value flex-1">
18
- <ui-skeleton-item width="102px" height="32px" border-radius="8px" />
19
- </div>
20
- </div>
21
-
22
- <div v-for="item in 2" :key="item" class="stack-block">
23
- <div class="stack-label flex-1">
24
- <ui-skeleton-item width="16px" height="16px" border-radius="50%" />
25
- <ui-skeleton-item height="16px" />
26
- </div>
27
- <div class="stack-value flex-1">
28
- <ui-skeleton-item width="102px" height="32px" border-radius="8px" />
29
- <ui-skeleton-item width="80px" height="32px" border-radius="8px" />
30
- </div>
31
- </div>
32
-
33
- <div v-for="item in 5" :key="item" class="stack-block">
34
- <div class="stack-label flex-1">
35
- <ui-skeleton-item width="16px" height="16px" border-radius="50%" />
36
- <ui-skeleton-item height="16px" />
37
- </div>
38
- <div class="stack-value flex-1">
39
- <ui-skeleton-item width="196px" height="32px" border-radius="8px" />
40
- </div>
41
- </div>
42
- </div>
43
- </div>
44
- </template>
45
-
46
- <script setup lang="ts"></script>
47
-
48
- <style scoped lang="scss">
49
- .skeleton-wrap {
50
- padding: 0 32px;
51
-
52
- .tabs {
53
- display: flex;
54
- align-items: center;
55
- gap: 32px;
56
- padding: 8px 0 12px;
57
- border-bottom: 1px solid var(--divider-color);
58
- }
59
-
60
- .actions {
61
- display: flex;
62
- align-items: center;
63
- justify-content: space-between;
64
- margin: 12px 0;
65
- }
66
-
67
- .stack-block-wrap {
68
- display: grid;
69
- grid-gap: 12px;
70
-
71
- .stack-block {
72
- display: flex;
73
- align-items: center;
74
- gap: 12px;
75
- padding: 8px 12px;
76
- background: var(--stack-block-bg-color);
77
- border-radius: 6px;
78
-
79
- .stack-label,
80
- .stack-value {
81
- display: flex;
82
- align-items: center;
83
- gap: 8px;
84
- }
85
- }
86
- }
87
- }
88
- </style>
1
+ <template>
2
+ <div class="skeleton-wrap">
3
+ <div class="tabs">
4
+ <ui-skeleton-item width="64px" height="16px" />
5
+ <ui-skeleton-item width="64px" height="16px" />
6
+ </div>
7
+ <div class="actions">
8
+ <ui-skeleton-item width="80px" height="16px" />
9
+ <ui-skeleton-item width="152px" height="32px" border-radius="6px" />
10
+ </div>
11
+ <div class="stack-block-wrap">
12
+ <div class="stack-block">
13
+ <div class="stack-label flex-1">
14
+ <ui-skeleton-item width="16px" height="16px" border-radius="50%" />
15
+ <ui-skeleton-item height="16px" />
16
+ </div>
17
+ <div class="stack-value flex-1">
18
+ <ui-skeleton-item width="102px" height="32px" border-radius="8px" />
19
+ </div>
20
+ </div>
21
+
22
+ <div v-for="item in 2" :key="item" class="stack-block">
23
+ <div class="stack-label flex-1">
24
+ <ui-skeleton-item width="16px" height="16px" border-radius="50%" />
25
+ <ui-skeleton-item height="16px" />
26
+ </div>
27
+ <div class="stack-value flex-1">
28
+ <ui-skeleton-item width="102px" height="32px" border-radius="8px" />
29
+ <ui-skeleton-item width="80px" height="32px" border-radius="8px" />
30
+ </div>
31
+ </div>
32
+
33
+ <div v-for="item in 5" :key="item" class="stack-block">
34
+ <div class="stack-label flex-1">
35
+ <ui-skeleton-item width="16px" height="16px" border-radius="50%" />
36
+ <ui-skeleton-item height="16px" />
37
+ </div>
38
+ <div class="stack-value flex-1">
39
+ <ui-skeleton-item width="196px" height="32px" border-radius="8px" />
40
+ </div>
41
+ </div>
42
+ </div>
43
+ </div>
44
+ </template>
45
+
46
+ <script setup lang="ts"></script>
47
+
48
+ <style scoped lang="scss">
49
+ .skeleton-wrap {
50
+ padding: 0 32px;
51
+
52
+ .tabs {
53
+ display: flex;
54
+ align-items: center;
55
+ gap: 32px;
56
+ padding: 8px 0 12px;
57
+ border-bottom: 1px solid var(--divider-color);
58
+ }
59
+
60
+ .actions {
61
+ display: flex;
62
+ align-items: center;
63
+ justify-content: space-between;
64
+ margin: 12px 0;
65
+ }
66
+
67
+ .stack-block-wrap {
68
+ display: grid;
69
+ grid-gap: 12px;
70
+
71
+ .stack-block {
72
+ display: flex;
73
+ align-items: center;
74
+ gap: 12px;
75
+ padding: 8px 12px;
76
+ background: var(--stack-block-bg-color);
77
+ border-radius: 6px;
78
+
79
+ .stack-label,
80
+ .stack-value {
81
+ display: flex;
82
+ align-items: center;
83
+ gap: 8px;
84
+ }
85
+ }
86
+ }
87
+ }
88
+ </style>
@@ -1,220 +1,220 @@
1
- import type { UI_I_Localization } from '~/lib/models/interfaces'
2
- import type { UI_I_MigrateReadyBlockData } from '~/components/common/wizards/vm/migrate/lib/models/interfaces'
3
- import type { UI_I_MigrateFormLocal } from '~/components/common/wizards/vm/migrate/lib/models/interfaces'
4
- import {
5
- UI_E_VmMigrationStrategy,
6
- UI_E_VmMigrationType,
7
- } from '~/components/common/wizards/vm/migrate/lib/models/enums'
8
- import { UI_E_SelectStorageDiskFormat } from '~/components/common/wizards/vm/migrate/select/storage/lib/models/enums'
9
- import { virtualDiskFormatOptionsFunc } from '~/components/common/wizards/vm/migrate/select/storage/configure/batch/config/virtualDiskFormat'
10
- const migrateOnlyStorageDataView = (
11
- localization: UI_I_Localization,
12
- form: UI_I_MigrateFormLocal,
13
- vmName: string
14
- ): UI_I_MigrateReadyBlockData[] => {
15
- const { disk_format, configure, storage } = form
16
-
17
- const isActivePerDiskTab: boolean = configure.type === 'configure-disk'
18
-
19
- const diskFormat = virtualDiskFormatOptionsFunc(localization).find(
20
- (file) => file.value === disk_format
21
- )!
22
-
23
- let storageResult: UI_I_MigrateReadyBlockData[] = [
24
- {
25
- label: localization.common.storage,
26
- value: storage?.name,
27
- permissions: ['batch-configure'],
28
- },
29
- {
30
- label: localization.common.diskFormat,
31
- value: diskFormat.label,
32
- permissions: ['batch-configure'],
33
- },
34
- {
35
- label: vmName,
36
- value: '',
37
- permissions: ['configure-disk'],
38
- },
39
- ]
40
-
41
- if (isActivePerDiskTab && configure.disks) {
42
- const perDiskItems: UI_I_MigrateReadyBlockData[] = configure.disks.map(
43
- (disk) => {
44
- const isConfigurationFile = disk.file === 'Configuration file'
45
- const diskFormat = UI_E_SelectStorageDiskFormat[disk.disk_format]
46
-
47
- const text = isConfigurationFile
48
- ? disk.storage
49
- : `${disk.storage} (${diskFormat})`
50
-
51
- return {
52
- label: disk.file,
53
- value: text,
54
- permissions: ['configure-disk'],
55
- isProperty: true,
56
- }
57
- }
58
- )
59
- storageResult = [...storageResult, ...perDiskItems]
60
- }
61
-
62
- return storageResult.filter(
63
- (option) =>
64
- !option.permissions.length || option.permissions.includes(configure.type)
65
- )
66
- }
67
-
68
- const setSelectNetworkDataView = (
69
- _localization: UI_I_Localization,
70
- from: UI_I_MigrateFormLocal
71
- ): string => {
72
- const result = []
73
- for (const key in from.network) {
74
- result.push(`${key}: ${from.network[key]}`)
75
- }
76
- return result.join(', ')
77
- // const {
78
- // noNetworkReassignments,
79
- // // networkAdapterReassignedNewDestination,
80
- // networkAdapterWillBeReassignedTo,
81
- // } = localization.common
82
- //
83
- // const { data } = from.network
84
- // const { sourceNetwork, value } = data
85
- //
86
- // if (sourceNetwork === value) {
87
- // return noNetworkReassignments
88
- // }
89
- //
90
- // type Replacements = {
91
- // lan: string
92
- // network: string
93
- // }
94
- //
95
- // const replacements: Replacements = {
96
- // lan: sourceNetwork,
97
- // network: value,
98
- // }
99
- // return networkAdapterWillBeReassignedTo.replace(
100
- // /{(\w+)}/g,
101
- // (_, key: keyof Replacements) => replacements[key]
102
- // )
103
-
104
- // return networkAdapterReassignedNewDestination.replace('{number}', '1')
105
- }
106
-
107
- const storageDetailsFunc = (
108
- localization: UI_I_Localization,
109
- name: string,
110
- form: UI_I_MigrateFormLocal
111
- ): UI_I_MigrateReadyBlockData[] => {
112
- const { migrate_type, vMotion_priority, resource } = form
113
-
114
- const migrationType = localization.common[UI_E_VmMigrationType[migrate_type]]
115
-
116
- let result: UI_I_MigrateReadyBlockData[] = [
117
- {
118
- label: localization.common.migrationType,
119
- value: migrationType,
120
- permissions: ['batch-configure', 'configure-disk'],
121
- },
122
- {
123
- label: localization.common.virtualMachine,
124
- value: name,
125
- permissions: ['batch-configure', 'configure-disk'],
126
- },
127
- ]
128
-
129
- if (migrate_type === 'resource') {
130
- const resourceResult = [
131
- {
132
- label: localization.common.networks,
133
- value: setSelectNetworkDataView(localization, form),
134
- permissions: [],
135
- },
136
- {
137
- label: localization.migrateVm.migrationStrategy,
138
- value:
139
- localization.migrateVm[UI_E_VmMigrationStrategy[vMotion_priority]],
140
- permissions: [],
141
- },
142
- ]
143
- Object.entries(resource).forEach(([key, value]) => {
144
- if (value !== null) {
145
- resourceResult.unshift({
146
- label: localization.common[key],
147
- value: value.name,
148
- permissions: [],
149
- })
150
- }
151
- })
152
- result = [...result, ...resourceResult]
153
- }
154
-
155
- if (migrate_type === 'storage') {
156
- const storageData = migrateOnlyStorageDataView(localization, form, name)
157
- result = [...result, ...storageData]
158
- }
159
-
160
- if (migrate_type === 'resource-storage') {
161
- const resourceStorageResult = [
162
- {
163
- label: localization.common.host,
164
- value: '', //selectedComputeResource.selectedNode.name,
165
- permissions: [],
166
- },
167
- {
168
- label: localization.migrateVm.migrationStrategy,
169
- value: localization.migrateVm[UI_E_VmMigrationStrategy[vMotion_priority]],
170
- permissions: [],
171
- },
172
- {
173
- label: localization.common.networks,
174
- value: setSelectNetworkDataView(localization, form),
175
- permissions: [],
176
- },
177
- ]
178
- const storageResult = migrateOnlyStorageDataView(localization, form, name)
179
-
180
- result = [...result, ...resourceStorageResult, ...storageResult]
181
- }
182
-
183
- if (migrate_type === 'server') {
184
- const serverResult = [
185
- {
186
- label: localization.migrateVm.migrationStrategy,
187
- value: localization.migrateVm[UI_E_VmMigrationStrategy[vMotion_priority]],
188
- permissions: [],
189
- },
190
- {
191
- label: localization.common.networks,
192
- value: setSelectNetworkDataView(localization, form),
193
- permissions: [],
194
- },
195
- ]
196
- Object.entries(resource).forEach(([key, value]) => {
197
- if (value !== null) {
198
- serverResult.unshift({
199
- label: localization.common[key],
200
- value: value.name,
201
- permissions: [],
202
- })
203
- }
204
- })
205
-
206
- const storageResult = migrateOnlyStorageDataView(localization, form, name)
207
-
208
- result = [...result, ...serverResult, ...storageResult]
209
- }
210
-
211
- return result
212
- }
213
- export const constructDataReadyViewFunc = (
214
- name: string,
215
- data: UI_I_MigrateFormLocal
216
- ): UI_I_MigrateReadyBlockData[] => {
217
- const localization: UI_I_Localization = useLocal()
218
-
219
- return storageDetailsFunc(localization, name, data)
220
- }
1
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
2
+ import type { UI_I_MigrateReadyBlockData } from '~/components/common/wizards/vm/migrate/lib/models/interfaces'
3
+ import type { UI_I_MigrateFormLocal } from '~/components/common/wizards/vm/migrate/lib/models/interfaces'
4
+ import {
5
+ UI_E_VmMigrationStrategy,
6
+ UI_E_VmMigrationType,
7
+ } from '~/components/common/wizards/vm/migrate/lib/models/enums'
8
+ import { UI_E_SelectStorageDiskFormat } from '~/components/common/wizards/vm/migrate/select/storage/lib/models/enums'
9
+ import { virtualDiskFormatOptionsFunc } from '~/components/common/wizards/vm/migrate/select/storage/configure/batch/config/virtualDiskFormat'
10
+ const migrateOnlyStorageDataView = (
11
+ localization: UI_I_Localization,
12
+ form: UI_I_MigrateFormLocal,
13
+ vmName: string
14
+ ): UI_I_MigrateReadyBlockData[] => {
15
+ const { disk_format, configure, storage } = form
16
+
17
+ const isActivePerDiskTab: boolean = configure.type === 'configure-disk'
18
+
19
+ const diskFormat = virtualDiskFormatOptionsFunc(localization).find(
20
+ (file) => file.value === disk_format
21
+ )!
22
+
23
+ let storageResult: UI_I_MigrateReadyBlockData[] = [
24
+ {
25
+ label: localization.common.storage,
26
+ value: storage?.name,
27
+ permissions: ['batch-configure'],
28
+ },
29
+ {
30
+ label: localization.common.diskFormat,
31
+ value: diskFormat.label,
32
+ permissions: ['batch-configure'],
33
+ },
34
+ {
35
+ label: vmName,
36
+ value: '',
37
+ permissions: ['configure-disk'],
38
+ },
39
+ ]
40
+
41
+ if (isActivePerDiskTab && configure.disks) {
42
+ const perDiskItems: UI_I_MigrateReadyBlockData[] = configure.disks.map(
43
+ (disk) => {
44
+ const isConfigurationFile = disk.file === 'Configuration file'
45
+ const diskFormat = UI_E_SelectStorageDiskFormat[disk.disk_format]
46
+
47
+ const text = isConfigurationFile
48
+ ? disk.storage
49
+ : `${disk.storage} (${diskFormat})`
50
+
51
+ return {
52
+ label: disk.file,
53
+ value: text,
54
+ permissions: ['configure-disk'],
55
+ isProperty: true,
56
+ }
57
+ }
58
+ )
59
+ storageResult = [...storageResult, ...perDiskItems]
60
+ }
61
+
62
+ return storageResult.filter(
63
+ (option) =>
64
+ !option.permissions.length || option.permissions.includes(configure.type)
65
+ )
66
+ }
67
+
68
+ const setSelectNetworkDataView = (
69
+ _localization: UI_I_Localization,
70
+ from: UI_I_MigrateFormLocal
71
+ ): string => {
72
+ const result = []
73
+ for (const key in from.network) {
74
+ result.push(`${key}: ${from.network[key]}`)
75
+ }
76
+ return result.join(', ')
77
+ // const {
78
+ // noNetworkReassignments,
79
+ // // networkAdapterReassignedNewDestination,
80
+ // networkAdapterWillBeReassignedTo,
81
+ // } = localization.common
82
+ //
83
+ // const { data } = from.network
84
+ // const { sourceNetwork, value } = data
85
+ //
86
+ // if (sourceNetwork === value) {
87
+ // return noNetworkReassignments
88
+ // }
89
+ //
90
+ // type Replacements = {
91
+ // lan: string
92
+ // network: string
93
+ // }
94
+ //
95
+ // const replacements: Replacements = {
96
+ // lan: sourceNetwork,
97
+ // network: value,
98
+ // }
99
+ // return networkAdapterWillBeReassignedTo.replace(
100
+ // /{(\w+)}/g,
101
+ // (_, key: keyof Replacements) => replacements[key]
102
+ // )
103
+
104
+ // return networkAdapterReassignedNewDestination.replace('{number}', '1')
105
+ }
106
+
107
+ const storageDetailsFunc = (
108
+ localization: UI_I_Localization,
109
+ name: string,
110
+ form: UI_I_MigrateFormLocal
111
+ ): UI_I_MigrateReadyBlockData[] => {
112
+ const { migrate_type, vMotion_priority, resource } = form
113
+
114
+ const migrationType = localization.common[UI_E_VmMigrationType[migrate_type]]
115
+
116
+ let result: UI_I_MigrateReadyBlockData[] = [
117
+ {
118
+ label: localization.common.migrationType,
119
+ value: migrationType,
120
+ permissions: ['batch-configure', 'configure-disk'],
121
+ },
122
+ {
123
+ label: localization.common.virtualMachine,
124
+ value: name,
125
+ permissions: ['batch-configure', 'configure-disk'],
126
+ },
127
+ ]
128
+
129
+ if (migrate_type === 'resource') {
130
+ const resourceResult = [
131
+ {
132
+ label: localization.common.networks,
133
+ value: setSelectNetworkDataView(localization, form),
134
+ permissions: [],
135
+ },
136
+ {
137
+ label: localization.migrateVm.migrationStrategy,
138
+ value:
139
+ localization.migrateVm[UI_E_VmMigrationStrategy[vMotion_priority]],
140
+ permissions: [],
141
+ },
142
+ ]
143
+ Object.entries(resource).forEach(([key, value]) => {
144
+ if (value !== null) {
145
+ resourceResult.unshift({
146
+ label: localization.common[key],
147
+ value: value.name,
148
+ permissions: [],
149
+ })
150
+ }
151
+ })
152
+ result = [...result, ...resourceResult]
153
+ }
154
+
155
+ if (migrate_type === 'storage') {
156
+ const storageData = migrateOnlyStorageDataView(localization, form, name)
157
+ result = [...result, ...storageData]
158
+ }
159
+
160
+ if (migrate_type === 'resource-storage') {
161
+ const resourceStorageResult = [
162
+ {
163
+ label: localization.common.host,
164
+ value: '', //selectedComputeResource.selectedNode.name,
165
+ permissions: [],
166
+ },
167
+ {
168
+ label: localization.migrateVm.migrationStrategy,
169
+ value: localization.migrateVm[UI_E_VmMigrationStrategy[vMotion_priority]],
170
+ permissions: [],
171
+ },
172
+ {
173
+ label: localization.common.networks,
174
+ value: setSelectNetworkDataView(localization, form),
175
+ permissions: [],
176
+ },
177
+ ]
178
+ const storageResult = migrateOnlyStorageDataView(localization, form, name)
179
+
180
+ result = [...result, ...resourceStorageResult, ...storageResult]
181
+ }
182
+
183
+ if (migrate_type === 'server') {
184
+ const serverResult = [
185
+ {
186
+ label: localization.migrateVm.migrationStrategy,
187
+ value: localization.migrateVm[UI_E_VmMigrationStrategy[vMotion_priority]],
188
+ permissions: [],
189
+ },
190
+ {
191
+ label: localization.common.networks,
192
+ value: setSelectNetworkDataView(localization, form),
193
+ permissions: [],
194
+ },
195
+ ]
196
+ Object.entries(resource).forEach(([key, value]) => {
197
+ if (value !== null) {
198
+ serverResult.unshift({
199
+ label: localization.common[key],
200
+ value: value.name,
201
+ permissions: [],
202
+ })
203
+ }
204
+ })
205
+
206
+ const storageResult = migrateOnlyStorageDataView(localization, form, name)
207
+
208
+ result = [...result, ...serverResult, ...storageResult]
209
+ }
210
+
211
+ return result
212
+ }
213
+ export const constructDataReadyViewFunc = (
214
+ name: string,
215
+ data: UI_I_MigrateFormLocal
216
+ ): UI_I_MigrateReadyBlockData[] => {
217
+ const localization: UI_I_Localization = useLocal()
218
+
219
+ return storageDetailsFunc(localization, name, data)
220
+ }