bfg-common 1.5.199 → 1.5.200

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 (125) 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/graph/GraphOld.vue +50 -50
  13. package/components/common/graph/graphNew/GraphNew.vue +194 -194
  14. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  15. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  16. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/lib/config/utils.ts +1040 -1040
  17. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  18. package/components/common/pages/home/headline/Headline.vue +45 -45
  19. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  20. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  21. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  22. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  23. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  24. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  25. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  26. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  27. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  28. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  29. package/components/common/pages/packages/Packages.vue +208 -208
  30. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  31. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  32. package/components/common/recursionTree/RecursionTree.vue +223 -223
  33. package/components/common/select/button/ButtonDropdown.vue +108 -108
  34. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  35. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  36. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  37. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  38. package/components/common/vm/actions/add/lib/config/steps.ts +263 -263
  39. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  40. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  41. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +337 -337
  42. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +480 -480
  43. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +319 -319
  44. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  45. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +100 -100
  46. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  47. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  48. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  49. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +78 -78
  50. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  51. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +2 -17
  52. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuNew.vue +190 -190
  53. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/model/ModelNew.vue +237 -237
  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/cpu/tooltip/TooltipNew.vue +154 -154
  57. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  58. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +288 -304
  59. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryNew.vue +154 -154
  60. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +375 -382
  61. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskNew.vue +289 -289
  62. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +151 -151
  63. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationNew.vue +73 -73
  64. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +83 -83
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -288
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +30 -30
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/inputDevices/InputDevicesNew.vue +40 -40
  80. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  81. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +106 -106
  82. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +81 -81
  83. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  84. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  85. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  86. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +67 -67
  87. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +149 -149
  88. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +140 -140
  89. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +31 -31
  90. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +31 -31
  91. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  92. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordNew.vue +128 -128
  93. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  94. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +39 -39
  95. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  96. package/components/common/vm/actions/common/lib/utils/capabilities.ts +52 -52
  97. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  98. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +134 -134
  99. package/components/common/vm/actions/common/select/computeResource/treeView/New.vue +44 -44
  100. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +118 -118
  101. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  102. package/components/common/vm/actions/common/select/createType/New.vue +84 -84
  103. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  104. package/components/common/vm/actions/common/select/name/Name.vue +167 -167
  105. package/components/common/vm/actions/common/select/os/New.vue +122 -122
  106. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  107. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  108. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  109. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  110. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  111. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  112. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  113. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  114. package/components/common/wizards/vm/migrate/select/computeResource/tableView/TableView.vue +137 -137
  115. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  116. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  117. package/composables/productNameLocal.ts +30 -30
  118. package/composables/useAppVersion.ts +21 -21
  119. package/package.json +2 -2
  120. package/plugins/date.ts +233 -233
  121. package/public/spice-console/lib/images/bitmap.js +203 -203
  122. package/public/spice-console/network/spicechannel.js +383 -383
  123. package/store/main/mutations.ts +7 -7
  124. package/store/main/state.ts +7 -7
  125. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,52 +1,52 @@
1
- import type { UI_I_Capabilities } from '~/components/common/vm/actions/common/lib/models/interfaces'
2
- import { capabilities } from '~/components/common/vm/actions/common/lib/config/capabilities'
3
-
4
- export const mapCapabilities = (
5
- capabilitiesFromApi: UI_I_Capabilities
6
- ): void => {
7
- if (!capabilitiesFromApi) return
8
- const { $binary } = useNuxtApp()
9
-
10
- // Machine Types
11
- capabilities.value.machineTypes = Object.keys(
12
- capabilitiesFromApi.machine_types
13
- ).map((key) => {
14
- return {
15
- text: capabilitiesFromApi.machine_types[key],
16
- value: key,
17
- }
18
- })
19
- // CPU Models
20
- capabilities.value.cpuModels = Object.keys(capabilitiesFromApi.cpu_models).map(
21
- (key) => {
22
- return {
23
- text: capabilitiesFromApi.cpu_models[key],
24
- value: key,
25
- }
26
- }
27
- )
28
-
29
- Object.keys(capabilitiesFromApi.bus_types).forEach((key) => {
30
- capabilities.value.bus[key] = Object.keys(capabilitiesFromApi.bus_types[key]).map(
31
- (key2) => {
32
- return {
33
- text: capabilitiesFromApi.bus_types[key][key2],
34
- value: key2,
35
- }
36
- }
37
- )
38
- })
39
- Object.keys(capabilitiesFromApi.cdrom_bus_type).forEach((key) => {
40
- capabilities.value.cdromBus[key] = Object.keys(
41
- capabilitiesFromApi.cdrom_bus_type[key]
42
- ).map((key2) => {
43
- return {
44
- text: capabilitiesFromApi.cdrom_bus_type[key][key2],
45
- value: key2,
46
- }
47
- })
48
- })
49
-
50
- capabilities.value.maxCpus = capabilitiesFromApi.max_vcpus
51
- capabilities.value.maxMemory = $binary.kbToMb(capabilitiesFromApi.max_mem_kib)
52
- }
1
+ import type { UI_I_Capabilities } from '~/components/common/vm/actions/common/lib/models/interfaces'
2
+ import { capabilities } from '~/components/common/vm/actions/common/lib/config/capabilities'
3
+
4
+ export const mapCapabilities = (
5
+ capabilitiesFromApi: UI_I_Capabilities
6
+ ): void => {
7
+ if (!capabilitiesFromApi) return
8
+ const { $binary } = useNuxtApp()
9
+
10
+ // Machine Types
11
+ capabilities.value.machineTypes = Object.keys(
12
+ capabilitiesFromApi.machine_types
13
+ ).map((key) => {
14
+ return {
15
+ text: capabilitiesFromApi.machine_types[key],
16
+ value: key,
17
+ }
18
+ })
19
+ // CPU Models
20
+ capabilities.value.cpuModels = Object.keys(capabilitiesFromApi.cpu_models).map(
21
+ (key) => {
22
+ return {
23
+ text: capabilitiesFromApi.cpu_models[key],
24
+ value: key,
25
+ }
26
+ }
27
+ )
28
+
29
+ Object.keys(capabilitiesFromApi.bus_types).forEach((key) => {
30
+ capabilities.value.bus[key] = Object.keys(capabilitiesFromApi.bus_types[key]).map(
31
+ (key2) => {
32
+ return {
33
+ text: capabilitiesFromApi.bus_types[key][key2],
34
+ value: key2,
35
+ }
36
+ }
37
+ )
38
+ })
39
+ Object.keys(capabilitiesFromApi.cdrom_bus_type).forEach((key) => {
40
+ capabilities.value.cdromBus[key] = Object.keys(
41
+ capabilitiesFromApi.cdrom_bus_type[key]
42
+ ).map((key2) => {
43
+ return {
44
+ text: capabilitiesFromApi.cdrom_bus_type[key][key2],
45
+ value: key2,
46
+ }
47
+ })
48
+ })
49
+
50
+ capabilities.value.maxCpus = capabilitiesFromApi.max_vcpus
51
+ capabilities.value.maxMemory = $binary.kbToMb(capabilitiesFromApi.max_mem_kib)
52
+ }
@@ -1,107 +1,107 @@
1
- <template>
2
- <div class="select-compatibility">
3
- <p class="select-compatibility-block">
4
- {{ props.description }}
5
- </p>
6
- <div class="select-compatibility-block version-select-wrap">
7
- <label for="version-select"
8
- >{{ localization.common.compatibleWith }}:</label
9
- >
10
-
11
- <atoms-tooltip-error
12
- :has-error="!!props.apiError"
13
- selector="#vm-wizard-version-select"
14
- @remove="emits('remove-validation-error')"
15
- >
16
- <template #elem>
17
- <select
18
- id="vm-wizard-version-select"
19
- v-model="selectedVersion"
20
- data-id="vm-wizard-version-select"
21
- >
22
- <option v-for="(item, key) in props.versions" :key="key" :value="item">
23
- {{ item.text }}
24
- </option>
25
- </select>
26
- </template>
27
- <template #content>{{ props.apiError }}</template>
28
- </atoms-tooltip-error>
29
- <!-- <div id="version-select-help-icon" class="flex-align-center relative">-->
30
- <!-- <atoms-the-icon-->
31
- <!-- fill="#0072a3"-->
32
- <!-- width="24px"-->
33
- <!-- height="24px"-->
34
- <!-- name="info-circle"-->
35
- <!-- @click="isShowHelp = !isShowHelp"-->
36
- <!-- />-->
37
- <!-- <atoms-tooltip-signpost-->
38
- <!-- v-if="isShowHelp"-->
39
- <!-- elem-id="version-select-help-icon"-->
40
- <!-- @hide="isShowHelp = false"-->
41
- <!-- >-->
42
- <!-- <h3 class="help-title">{{ localization.common.help }}</h3>-->
43
-
44
- <!-- <p>-->
45
- <!-- {{-->
46
- <!-- localization.common.eachVirtualMachineCompatibilitySettingIncludesHardwareAvailableVirtualMachine-->
47
- <!-- }}-->
48
- <!-- </p>-->
49
-
50
- <!-- <a id="more-information-link" class="pointer">{{-->
51
- <!-- localization.common.moreInformation-->
52
- <!-- }}</a>-->
53
- <!-- </atoms-tooltip-signpost>-->
54
- <!-- </div>-->
55
- </div>
56
- <p class="select-compatibility-block">
57
- {{ props.versionDescription }}
58
- </p>
59
- </div>
60
- </template>
61
-
62
- <script setup lang="ts">
63
- import type { UI_I_Localization } from '~/lib/models/interfaces'
64
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
65
-
66
- const selectedVersion = defineModel<UI_I_OptionItem | null>('selectedVersion', {required: true})
67
-
68
- const props = defineProps<{
69
- versions: UI_I_OptionItem[]
70
- description: string
71
- versionDescription: string
72
- apiError: string
73
- }>()
74
- const emits = defineEmits<{
75
- (event: 'remove-validation-error'): void
76
- }>()
77
-
78
- const localization = computed<UI_I_Localization>(() => useLocal())
79
-
80
- </script>
81
-
82
- <style scoped lang="scss">
83
- .select-compatibility-block {
84
- margin-top: 12px;
85
- font-size: 13px;
86
-
87
- &.version-select-wrap {
88
- display: flex;
89
- align-items: center;
90
- gap: 6px;
91
-
92
- //#version-select-help-icon {
93
- // .help-title {
94
- // font-size: 22px;
95
- // }
96
- //
97
- // p {
98
- // width: 200px;
99
- // }
100
- //
101
- // a {
102
- // color: #0072a3;
103
- // }
104
- //}
105
- }
106
- }
107
- </style>
1
+ <template>
2
+ <div class="select-compatibility">
3
+ <p class="select-compatibility-block">
4
+ {{ props.description }}
5
+ </p>
6
+ <div class="select-compatibility-block version-select-wrap">
7
+ <label for="version-select"
8
+ >{{ localization.common.compatibleWith }}:</label
9
+ >
10
+
11
+ <atoms-tooltip-error
12
+ :has-error="!!props.apiError"
13
+ selector="#vm-wizard-version-select"
14
+ @remove="emits('remove-validation-error')"
15
+ >
16
+ <template #elem>
17
+ <select
18
+ id="vm-wizard-version-select"
19
+ v-model="selectedVersion"
20
+ data-id="vm-wizard-version-select"
21
+ >
22
+ <option v-for="(item, key) in props.versions" :key="key" :value="item">
23
+ {{ item.text }}
24
+ </option>
25
+ </select>
26
+ </template>
27
+ <template #content>{{ props.apiError }}</template>
28
+ </atoms-tooltip-error>
29
+ <!-- <div id="version-select-help-icon" class="flex-align-center relative">-->
30
+ <!-- <atoms-the-icon-->
31
+ <!-- fill="#0072a3"-->
32
+ <!-- width="24px"-->
33
+ <!-- height="24px"-->
34
+ <!-- name="info-circle"-->
35
+ <!-- @click="isShowHelp = !isShowHelp"-->
36
+ <!-- />-->
37
+ <!-- <atoms-tooltip-signpost-->
38
+ <!-- v-if="isShowHelp"-->
39
+ <!-- elem-id="version-select-help-icon"-->
40
+ <!-- @hide="isShowHelp = false"-->
41
+ <!-- >-->
42
+ <!-- <h3 class="help-title">{{ localization.common.help }}</h3>-->
43
+
44
+ <!-- <p>-->
45
+ <!-- {{-->
46
+ <!-- localization.common.eachVirtualMachineCompatibilitySettingIncludesHardwareAvailableVirtualMachine-->
47
+ <!-- }}-->
48
+ <!-- </p>-->
49
+
50
+ <!-- <a id="more-information-link" class="pointer">{{-->
51
+ <!-- localization.common.moreInformation-->
52
+ <!-- }}</a>-->
53
+ <!-- </atoms-tooltip-signpost>-->
54
+ <!-- </div>-->
55
+ </div>
56
+ <p class="select-compatibility-block">
57
+ {{ props.versionDescription }}
58
+ </p>
59
+ </div>
60
+ </template>
61
+
62
+ <script setup lang="ts">
63
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
64
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
65
+
66
+ const selectedVersion = defineModel<UI_I_OptionItem | null>('selectedVersion', {required: true})
67
+
68
+ const props = defineProps<{
69
+ versions: UI_I_OptionItem[]
70
+ description: string
71
+ versionDescription: string
72
+ apiError: string
73
+ }>()
74
+ const emits = defineEmits<{
75
+ (event: 'remove-validation-error'): void
76
+ }>()
77
+
78
+ const localization = computed<UI_I_Localization>(() => useLocal())
79
+
80
+ </script>
81
+
82
+ <style scoped lang="scss">
83
+ .select-compatibility-block {
84
+ margin-top: 12px;
85
+ font-size: 13px;
86
+
87
+ &.version-select-wrap {
88
+ display: flex;
89
+ align-items: center;
90
+ gap: 6px;
91
+
92
+ //#version-select-help-icon {
93
+ // .help-title {
94
+ // font-size: 22px;
95
+ // }
96
+ //
97
+ // p {
98
+ // width: 200px;
99
+ // }
100
+ //
101
+ // a {
102
+ // color: #0072a3;
103
+ // }
104
+ //}
105
+ }
106
+ }
107
+ </style>
@@ -1,134 +1,134 @@
1
- <template>
2
- <common-vm-actions-common-select-compute-resource-new
3
- v-if="isNewView"
4
- v-model="selectedNode"
5
- :data-center="props.dataCenter"
6
- :compute-resource="props.computeResource"
7
- :compute-resource-tree="props.computeResourceTree"
8
- :errors="errors"
9
- :compatibility-text="compatibilityText"
10
- @get-compute-resource-tree="emits('get-compute-resource-tree', $event)"
11
- @show-compute-resource-tree="emits('show-compute-resource-tree', $event)"
12
- @select-compute-resource-tree="
13
- emits('select-compute-resource-tree', $event)
14
- "
15
- @clear-compute-resource-tree="emits('clear-compute-resource-tree')"
16
- @remove-validation-errors="onRemoveValidationErrors"
17
- />
18
- <common-vm-actions-common-select-compute-resource-old
19
- v-else
20
- v-model="selectedNode"
21
- :data-center="props.dataCenter"
22
- :compute-resource="props.computeResource"
23
- :compute-resource-tree="props.computeResourceTree"
24
- :errors="errors"
25
- :compatibility-text="compatibilityText"
26
- @get-compute-resource-tree="emits('get-compute-resource-tree', $event)"
27
- @show-compute-resource-tree="emits('show-compute-resource-tree', $event)"
28
- @select-compute-resource-tree="
29
- emits('select-compute-resource-tree', $event)
30
- "
31
- @clear-compute-resource-tree="emits('clear-compute-resource-tree')"
32
- @remove-validation-errors="onRemoveValidationErrors"
33
- />
34
- </template>
35
-
36
- <script setup lang="ts">
37
- import type { UI_I_Localization } from '~/lib/models/interfaces'
38
- import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
39
-
40
- const props = defineProps<{
41
- computeResourceSubmit: null | Function
42
- dataCenter: UI_I_TreeNode | null
43
- computeResource: UI_I_TreeNode
44
- computeResourceTree: UI_I_TreeNode[]
45
- }>()
46
-
47
- const emits = defineEmits<{
48
- (event: 'submit', value: UI_I_TreeNode): void
49
- (
50
- event: 'get-compute-resource-tree',
51
- value: { id: string | number; cb: () => void }
52
- ): void
53
- (event: 'show-compute-resource-tree', value: UI_I_TreeNode): void
54
- (event: 'select-compute-resource-tree', value: UI_I_TreeNode): void
55
- (event: 'clear-compute-resource-tree'): void
56
- }>()
57
-
58
- const { $store }: any = useNuxtApp()
59
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
60
-
61
- const localization = computed<UI_I_Localization>(() => useLocal())
62
-
63
- watch(
64
- () => props.computeResourceSubmit,
65
- (newValue: null | Function) => {
66
- newValue && submit(newValue)
67
- }
68
- )
69
- const submit = (cb: Function): void => {
70
- if (
71
- !selectedNode.value ||
72
- // !compatibilityText.value[1] ||
73
- !compatibilityText.value[0] ||
74
- selectedNode.value.type === 'datacenter' ||
75
- selectedNode.value.type === 'folder' ||
76
- (selectedNode.value.type === 'cluster' && !selectedNode.value.nodes.length)
77
- ) {
78
- showValidationErrors(
79
- localization.value.common.specifyValidClusterOrHostDestination
80
- )
81
- cb(false)
82
- return
83
- }
84
-
85
- onRemoveValidationErrors()
86
- emits('submit', selectedNode.value)
87
- cb(true)
88
- }
89
-
90
- const errors = ref<string[]>([])
91
- const showValidationErrors = (text: string): void => {
92
- errors.value = [text]
93
- }
94
- const onRemoveValidationErrors = (): void => {
95
- errors.value = []
96
- }
97
-
98
- const selectedNode = defineModel<UI_I_TreeNode | null>('modelValue')
99
-
100
- const compatibilityText = computed<[boolean, string]>(() => {
101
- let res: [boolean, string] = [
102
- true,
103
- localization.value.common.compatibilityChecksSucceeded,
104
- ]
105
-
106
- if (!selectedNode.value) res = [true, '']
107
-
108
- if (
109
- !['cluster', 'host', 'resource_pool'].includes(selectedNode.value?.type)
110
- ) {
111
- res = [false, localization.value.common.selectValidClusterOrHostDestination]
112
- }
113
- if (selectedNode.value?.type === 'cluster') {
114
- const hasHost = !!selectedNode.value.nodes.length
115
- if (!hasHost) {
116
- res = [false, localization.value.common.clusterNotContainAnyHosts]
117
- }
118
- }
119
-
120
- if (selectedNode.value?.type === 'host') {
121
- if (selectedNode.value.state === 'Error') {
122
- // TODO check Maintenance Mode
123
- res = [
124
- false,
125
- localization.value.common.selectedHostDisconnectedMaintenanceMode,
126
- ]
127
- }
128
- }
129
-
130
- return res
131
- })
132
- </script>
133
-
134
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <common-vm-actions-common-select-compute-resource-new
3
+ v-if="isNewView"
4
+ v-model="selectedNode"
5
+ :data-center="props.dataCenter"
6
+ :compute-resource="props.computeResource"
7
+ :compute-resource-tree="props.computeResourceTree"
8
+ :errors="errors"
9
+ :compatibility-text="compatibilityText"
10
+ @get-compute-resource-tree="emits('get-compute-resource-tree', $event)"
11
+ @show-compute-resource-tree="emits('show-compute-resource-tree', $event)"
12
+ @select-compute-resource-tree="
13
+ emits('select-compute-resource-tree', $event)
14
+ "
15
+ @clear-compute-resource-tree="emits('clear-compute-resource-tree')"
16
+ @remove-validation-errors="onRemoveValidationErrors"
17
+ />
18
+ <common-vm-actions-common-select-compute-resource-old
19
+ v-else
20
+ v-model="selectedNode"
21
+ :data-center="props.dataCenter"
22
+ :compute-resource="props.computeResource"
23
+ :compute-resource-tree="props.computeResourceTree"
24
+ :errors="errors"
25
+ :compatibility-text="compatibilityText"
26
+ @get-compute-resource-tree="emits('get-compute-resource-tree', $event)"
27
+ @show-compute-resource-tree="emits('show-compute-resource-tree', $event)"
28
+ @select-compute-resource-tree="
29
+ emits('select-compute-resource-tree', $event)
30
+ "
31
+ @clear-compute-resource-tree="emits('clear-compute-resource-tree')"
32
+ @remove-validation-errors="onRemoveValidationErrors"
33
+ />
34
+ </template>
35
+
36
+ <script setup lang="ts">
37
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
38
+ import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
39
+
40
+ const props = defineProps<{
41
+ computeResourceSubmit: null | Function
42
+ dataCenter: UI_I_TreeNode | null
43
+ computeResource: UI_I_TreeNode
44
+ computeResourceTree: UI_I_TreeNode[]
45
+ }>()
46
+
47
+ const emits = defineEmits<{
48
+ (event: 'submit', value: UI_I_TreeNode): void
49
+ (
50
+ event: 'get-compute-resource-tree',
51
+ value: { id: string | number; cb: () => void }
52
+ ): void
53
+ (event: 'show-compute-resource-tree', value: UI_I_TreeNode): void
54
+ (event: 'select-compute-resource-tree', value: UI_I_TreeNode): void
55
+ (event: 'clear-compute-resource-tree'): void
56
+ }>()
57
+
58
+ const { $store }: any = useNuxtApp()
59
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
60
+
61
+ const localization = computed<UI_I_Localization>(() => useLocal())
62
+
63
+ watch(
64
+ () => props.computeResourceSubmit,
65
+ (newValue: null | Function) => {
66
+ newValue && submit(newValue)
67
+ }
68
+ )
69
+ const submit = (cb: Function): void => {
70
+ if (
71
+ !selectedNode.value ||
72
+ // !compatibilityText.value[1] ||
73
+ !compatibilityText.value[0] ||
74
+ selectedNode.value.type === 'datacenter' ||
75
+ selectedNode.value.type === 'folder' ||
76
+ (selectedNode.value.type === 'cluster' && !selectedNode.value.nodes.length)
77
+ ) {
78
+ showValidationErrors(
79
+ localization.value.common.specifyValidClusterOrHostDestination
80
+ )
81
+ cb(false)
82
+ return
83
+ }
84
+
85
+ onRemoveValidationErrors()
86
+ emits('submit', selectedNode.value)
87
+ cb(true)
88
+ }
89
+
90
+ const errors = ref<string[]>([])
91
+ const showValidationErrors = (text: string): void => {
92
+ errors.value = [text]
93
+ }
94
+ const onRemoveValidationErrors = (): void => {
95
+ errors.value = []
96
+ }
97
+
98
+ const selectedNode = defineModel<UI_I_TreeNode | null>('modelValue')
99
+
100
+ const compatibilityText = computed<[boolean, string]>(() => {
101
+ let res: [boolean, string] = [
102
+ true,
103
+ localization.value.common.compatibilityChecksSucceeded,
104
+ ]
105
+
106
+ if (!selectedNode.value) res = [true, '']
107
+
108
+ if (
109
+ !['cluster', 'host', 'resource_pool'].includes(selectedNode.value?.type)
110
+ ) {
111
+ res = [false, localization.value.common.selectValidClusterOrHostDestination]
112
+ }
113
+ if (selectedNode.value?.type === 'cluster') {
114
+ const hasHost = !!selectedNode.value.nodes.length
115
+ if (!hasHost) {
116
+ res = [false, localization.value.common.clusterNotContainAnyHosts]
117
+ }
118
+ }
119
+
120
+ if (selectedNode.value?.type === 'host') {
121
+ if (selectedNode.value.state === 'Error') {
122
+ // TODO check Maintenance Mode
123
+ res = [
124
+ false,
125
+ localization.value.common.selectedHostDisconnectedMaintenanceMode,
126
+ ]
127
+ }
128
+ }
129
+
130
+ return res
131
+ })
132
+ </script>
133
+
134
+ <style scoped lang="scss"></style>