bfg-common 1.4.791 → 1.4.793

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 (171) hide show
  1. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  2. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  3. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  4. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  5. package/assets/scss/common/normalize.scss +361 -361
  6. package/components/atoms/TheIcon3.vue +50 -50
  7. package/components/atoms/modal/bySteps/BySteps.vue +253 -253
  8. package/components/atoms/stack/StackBlock.vue +185 -185
  9. package/components/atoms/table/dataGrid/DataGrid.vue +1704 -1704
  10. package/components/atoms/table/dataGrid/DataGridColumnSwitch.vue +222 -222
  11. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  12. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  13. package/components/common/browse/BrowseNew.vue +237 -237
  14. package/components/common/browse/BrowseOld.vue +217 -217
  15. package/components/common/browse/blocks/contents/Files.vue +37 -37
  16. package/components/common/browse/blocks/contents/FilesOld.vue +72 -72
  17. package/components/common/browse/blocks/contents/filesNew/FilesNew.vue +96 -96
  18. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  19. package/components/common/browse/blocks/lib/models/types.ts +1 -1
  20. package/components/common/browse/lib/models/interfaces.ts +5 -5
  21. package/components/common/context/Context.vue +111 -111
  22. package/components/common/context/lib/models/interfaces.ts +30 -30
  23. package/components/common/context/recursion/Recursion.vue +87 -87
  24. package/components/common/context/recursion/RecursionNew.vue +237 -237
  25. package/components/common/context/recursion/RecursionOld.vue +227 -227
  26. package/components/common/details/DetailsItem.vue +109 -109
  27. package/components/common/diagramMain/Header.vue +211 -211
  28. package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
  29. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  30. package/components/common/diagramMain/lib/models/types.ts +21 -21
  31. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  32. package/components/common/diagramMain/modals/ManagePhysicalAdaptersModal.vue +330 -330
  33. package/components/common/diagramMain/modals/editSettings/ConfirmTeamingSettingsModal.vue +40 -40
  34. package/components/common/diagramMain/modals/editSettings/EditSettings.vue +497 -497
  35. package/components/common/diagramMain/modals/editSettings/EditSettingsModal.vue +812 -812
  36. package/components/common/diagramMain/modals/editSettings/tabs/NetworkProperties.vue +214 -214
  37. package/components/common/diagramMain/modals/editSettings/tabs/Security.vue +189 -189
  38. package/components/common/diagramMain/modals/editSettings/tabs/SwitchProperties.vue +163 -163
  39. package/components/common/diagramMain/modals/editSettings/tabs/TeamingFailover.vue +175 -175
  40. package/components/common/diagramMain/modals/editSettings/tabs/TrafficShaping.vue +398 -398
  41. package/components/common/diagramMain/modals/editSettings/tabs/port/IpvFourSettings.vue +346 -346
  42. package/components/common/diagramMain/modals/editSettings/tabs/port/PortProperties.vue +205 -205
  43. package/components/common/diagramMain/modals/lib/config/diagramConfig.ts +23 -23
  44. package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
  45. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  46. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +87 -87
  47. package/components/common/diagramMain/modals/lib/utils/index.ts +24 -24
  48. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
  49. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +169 -169
  50. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
  51. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +14 -14
  52. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
  53. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
  54. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  55. package/components/common/diagramMain/port/Ports.vue +47 -47
  56. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  57. package/components/common/layout/theHeader/helpMenu/aboutNew/AboutNew.vue +103 -103
  58. package/components/common/mainNavigationPanel/MainNavigationPanel.vue +151 -151
  59. package/components/common/mainNavigationPanel/MainNavigationPanelOld.vue +300 -300
  60. package/components/common/modals/confirmByInput/ConfirmByInput.vue +206 -206
  61. package/components/common/modals/unsavedChanges/UnsavedChanges.vue +56 -56
  62. package/components/common/monitor/overview/filters/customIntervalModal/CustomIntervalModal.vue +250 -250
  63. package/components/common/pages/home/StatusContent.vue +49 -49
  64. package/components/common/pages/home/headline/Headline.vue +45 -45
  65. package/components/common/pages/home/headline/HeadlineNew.vue +71 -71
  66. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  67. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  68. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  69. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  70. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  71. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  72. package/components/common/pages/home/widgets/hosts/HostsNew.vue +100 -100
  73. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  74. package/components/common/pages/home/widgets/services/lib/config/config.ts +108 -108
  75. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  76. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  77. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  78. package/components/common/pages/packages/Packages.vue +208 -208
  79. package/components/common/pages/tasks/Tasks.vue +1 -0
  80. package/components/common/pages/tasks/table/Table.vue +46 -30
  81. package/components/common/pages/tasks/table/errorInfo/ErrorInfo.vue +17 -4
  82. package/components/common/pages/tasks/table/expandDetails/ExpandDetails.vue +12 -0
  83. package/components/common/pages/tasks/table/lib/config/config.ts +5 -5
  84. package/components/common/recursionTree/RecursionTree.vue +223 -223
  85. package/components/common/select/button/ButtonDropdown.vue +108 -108
  86. package/components/common/spiceConsole/Drawer.vue +370 -370
  87. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  88. package/components/common/split/horizontal/HorizontalNew.vue +376 -376
  89. package/components/common/split/horizontal/HorizontalOld.vue +337 -337
  90. package/components/common/split/vertical/Vertical.vue +160 -160
  91. package/components/common/vm/actions/add/Add.vue +621 -621
  92. package/components/common/vm/actions/clone/Clone.vue +639 -639
  93. package/components/common/vm/actions/clone/lib/config/steps.ts +129 -129
  94. package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +271 -271
  95. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +271 -271
  96. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +174 -174
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusNew.vue +117 -117
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveNew.vue +161 -161
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +165 -165
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  102. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +70 -70
  103. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  104. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +338 -338
  105. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  106. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +357 -357
  107. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/ModeOld.vue +56 -56
  108. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/SharingNew.vue +44 -44
  109. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +281 -281
  110. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkNew.vue +124 -124
  111. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/LocationOld.vue +134 -134
  112. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/New.vue +63 -63
  113. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +95 -95
  114. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  115. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressNew.vue +69 -69
  116. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressOld.vue +83 -83
  117. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  118. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  119. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  120. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  121. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoNew.vue +84 -84
  122. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  123. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  124. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  125. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  126. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGrid.vue +41 -41
  127. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridNew.vue +81 -81
  128. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  129. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerNew.vue +56 -56
  130. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  131. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +30 -30
  132. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +104 -104
  133. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardOld.vue +112 -112
  134. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/TotalVideoMemoryNew.vue +54 -54
  135. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  136. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +102 -102
  137. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +75 -75
  138. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +26 -26
  139. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +57 -57
  140. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/FirmwareNew.vue +42 -42
  141. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/MenuNew.vue +25 -25
  142. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +171 -171
  143. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +50 -50
  144. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +141 -141
  145. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +140 -140
  146. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +30 -30
  147. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +30 -30
  148. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/folderSharing/FolderSharingNew.vue +30 -30
  149. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  150. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapNew.vue +39 -39
  151. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  152. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordNew.vue +102 -102
  153. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordOld.vue +94 -94
  154. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  155. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +38 -38
  156. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  157. package/components/common/vm/actions/common/select/storage/Storage.vue +130 -130
  158. package/components/common/vm/actions/common/select/storage/StorageOld.vue +129 -129
  159. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  160. package/components/common/wizards/datastore/add/lib/config/steps.ts +138 -138
  161. package/components/common/wizards/vm/migrate/Migrate.vue +288 -288
  162. package/composables/productNameLocal.ts +30 -30
  163. package/composables/useAppVersion.ts +21 -21
  164. package/package.json +2 -2
  165. package/plugins/date.ts +233 -233
  166. package/plugins/recursion.ts +311 -311
  167. package/public/spice-console/lib/images/bitmap.js +203 -203
  168. package/public/spice-console/network/spicechannel.js +383 -383
  169. package/store/main/mutations.ts +7 -7
  170. package/store/main/state.ts +7 -7
  171. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,271 +1,271 @@
1
- <template>
2
- <div :class="['customize-hardware', themeMode]">
3
- <ui-tabs
4
- v-model="selectedNavItem"
5
- test-id="vm-wizard-tabs"
6
- :tabs="navItemsLocal"
7
- type="underline"
8
- class="navigation"
9
- />
10
- <ui-alert
11
- v-show="props.errors.length"
12
- status="alert-danger"
13
- :messages="props.errors"
14
- test-id="customize-hardware-alert"
15
- class="errors-alert"
16
- @remove="emits('remove-validation-errors')"
17
- />
18
-
19
- <div v-show="selectedNavItem === 0">
20
- <common-vm-actions-common-customize-hardware-virtual-hardware
21
- :vm-name="vmName"
22
- :storage="props.storage"
23
- :max-cpus="props.maxCpus"
24
- :max-memory="props.maxMemory"
25
- :cpu-models="props.cpuModels"
26
- :cpu="props.cpu"
27
- :memory="props.memory"
28
- :is-edit="props.isEdit"
29
- :is-clone="props.isClone"
30
- :state="props.state"
31
- :hard-disks="props.hardDisks"
32
- :cd-dvd-drives="props.cdDvdDrives"
33
- :networks="props.networks"
34
- :networks-table="props.networksTable"
35
- :video-card="props.videoCard"
36
- :usb-controller="props.usbController"
37
- :pci-devices="props.pciDevices"
38
- :nodes="props.nodes"
39
- :files="props.files"
40
- :error-validation-fields="props.errorValidationFields"
41
- :get-datastore-table-func="props.getDatastoreTableFunc"
42
- :datastore="props.datastore"
43
- :vm-cpu-help-text-second="props.vmCpuHelpTextSecond"
44
- :passthrough-devices="props.passthroughDevices"
45
- :mediated-devices="props.mediatedDevices"
46
- :project="props.project"
47
- :guest-machine-type="guestMachineType"
48
- @send-data="emits('send-data-virtual-hardware-method', $event)"
49
- @get-storage="emits('get-storage', $event)"
50
- @get-folders-or-files="emits('get-folders-or-files', $event)"
51
- @get-active-device-child="emits('get-active-device-child', $event)"
52
- @show-datastore-child="emits('show-datastore-child', $event)"
53
- @remove-error-by-title="emits('remove-error-by-title', $event)"
54
- @invalid="virtualHardwareInvalid = $event"
55
- @get-networks-table="emits('get-networks-table', $event)"
56
- @get-pci-devices="emits('get-pci-devices')"
57
- />
58
- </div>
59
- <div v-show="selectedNavItem === 1">
60
- <common-vm-actions-common-customize-hardware-vmoptions
61
- v-model:vm-name="vmName"
62
- v-model:guest-machine-type="guestMachineType"
63
- v-model:guest-os-family="guestOsFamily"
64
- v-model:guest-os-version="guestOsVersion"
65
- :hard-disks="props.hardDisksForBootOptions"
66
- :cd-dvd-drives="props.cdDvdDrivesForBootOptions"
67
- :networks="props.networksForBootOptions"
68
- :options="props.options"
69
- :is-edit="props.isEdit"
70
- :is-clone="props.isClone"
71
- :error-validation-fields="props.errorValidationFields"
72
- :state="props.state"
73
- @change-boot-order="emits('change-boot-order', $event)"
74
- @send-data="emits('send-data-vm-options-method', $event)"
75
- @invalid="vmOptionsInvalid = $event"
76
- @remove-error-by-title="emits('remove-error-by-title', $event)"
77
- />
78
- </div>
79
- </div>
80
- </template>
81
-
82
- <script setup lang="ts">
83
- import type { UI_I_TabItem } from 'bfg-uikit/components/ui/tabs/models/interfaces'
84
- import type { UI_T_Project } from '~/lib/models/types'
85
- import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
86
- import type { UI_I_NetworkTableItem } from '~/lib/models/store/network/interfaces'
87
- import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
88
- import type { UI_I_FolderOrFileTreePayload } from '~/lib/models/store/storage/interfaces'
89
- import type { UI_I_FileTreeNode } from '~/components/lib/models/interfaces'
90
- import type {
91
- UI_I_SendDataNewPciDevice,
92
- UI_I_SendDataNewCdDvdDrive,
93
- UI_I_SendDataNewHardDisk,
94
- UI_I_SendDataNewNetwork,
95
- UI_I_SendDataVideoCard,
96
- UI_I_SendDataVirtualHardware,
97
- } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
98
- import type { UI_I_SendDataVmoptions } from '~/components/common/vm/actions/common/customizeHardware/vmoptions/lib/models/interfaces'
99
- import type { UI_T_SelectedNavItem } from '~/components/common/vm/actions/common/lib/models/types'
100
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
101
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
102
- import type { UI_T_ChangeBootOrder } from '~/components/common/vm/actions/lib/models/types'
103
- import type {
104
- API_UI_I_VmEditCpu,
105
- API_UI_I_VmEditMemory,
106
- UI_I_MediatedDevice,
107
- UI_I_PciDevice,
108
- } from '~/lib/models/store/vm/interfaces'
109
- import type { UI_I_Localization } from '~/lib/models/interfaces'
110
- import { navItemsNewViewFunc } from '~/components/common/vm/actions/common/customizeHardware/lib/config/navItems'
111
-
112
- const vmName = defineModel<string>('vmName', { required: true })
113
- const guestOsFamily = defineModel<UI_I_OptionItem | null>('guestOsFamily', {
114
- required: true,
115
- })
116
- const guestOsVersion = defineModel<UI_I_OptionItem | null>('guestOsVersion', {
117
- required: true,
118
- })
119
- const selectedNavItem = defineModel<UI_T_SelectedNavItem>('selectedNavItem', {
120
- required: true,
121
- })
122
- const guestMachineType = defineModel<UI_I_OptionItem | null>(
123
- 'guestMachineType',
124
- { required: true }
125
- )
126
- const vmOptionsInvalid = defineModel<string[]>('vmOptionsInvalid', {
127
- required: true,
128
- })
129
- const virtualHardwareInvalid = defineModel<string[]>('virtualHardwareInvalid', {
130
- required: true,
131
- })
132
-
133
- const props = defineProps<{
134
- nodes: UI_I_FileTreeNode[]
135
- files: UI_I_FileTreeNode[]
136
- errors: string[]
137
- storage: UI_I_DatastoreTableItem | null
138
- maxCpus: number
139
- navItems: UI_I_TabItem[]
140
- cpuModels: UI_I_OptionItem[]
141
- maxMemory: number
142
- datastore: UI_I_DatastoreTableItem[]
143
- networksTable: UI_I_NetworkTableItem[]
144
- errorValidationFields: UI_I_ErrorValidationField[]
145
- networksForBootOptions: UI_I_SendDataNewNetwork[] | null
146
- hardDisksForBootOptions: UI_I_SendDataNewHardDisk[] | null
147
- cdDvdDrivesForBootOptions: UI_I_SendDataNewCdDvdDrive[] | null
148
- cpu?: API_UI_I_VmEditCpu
149
- state?: string | number
150
- isEdit?: boolean
151
- memory?: API_UI_I_VmEditMemory
152
- project?: UI_T_Project
153
- isClone?: boolean
154
- options?: UI_I_SendDataVmoptions
155
- networks?: UI_I_SendDataNewNetwork[] | null
156
- videoCard?: UI_I_SendDataVideoCard
157
- hardDisks?: UI_I_SendDataNewHardDisk[] | null
158
- pciDevices?: UI_I_SendDataNewPciDevice[]
159
- cdDvdDrives?: UI_I_SendDataNewCdDvdDrive[] | null
160
- usbController?: string
161
- passthroughDevices?: UI_I_PciDevice[]
162
- mediatedDevices?: UI_I_MediatedDevice[]
163
- vmCpuHelpTextSecond?: string
164
- getDatastoreTableFunc?: (payload: UI_I_TablePayload) => Promise<void>
165
- }>()
166
- const emits = defineEmits<{
167
- (event: 'get-storage', value: UI_I_TablePayload): void
168
- (event: 'get-pci-devices'): void
169
- (event: 'get-networks-table', value: UI_I_TablePayload): void
170
- (event: 'get-folders-or-files', value: UI_I_FolderOrFileTreePayload): void
171
- (event: 'show-datastore-child', value: UI_I_FileTreeNode): void
172
- (event: 'remove-error-by-title', value: string): void
173
- (event: 'get-active-device-child', value: UI_I_FileTreeNode): void
174
- (event: 'remove-validation-errors'): void
175
- (event: 'send-data-vm-options-method', value: UI_I_SendDataVmoptions): void
176
- (
177
- event: 'send-data-virtual-hardware-method',
178
- value: UI_I_SendDataVirtualHardware
179
- ): void
180
- (event: 'change-boot-order', value: UI_T_ChangeBootOrder): void
181
- }>()
182
-
183
- const localization = computed<UI_I_Localization>(() => useLocal())
184
-
185
- const navItemsLocal = computed<UI_I_TabItem[]>(() =>
186
- navItemsNewViewFunc(localization.value)
187
- )
188
-
189
- const themeMode = useLocalStorage('themeMode')
190
- </script>
191
-
192
- <style lang="scss">
193
- :root {
194
- --divider-color: #e9ebed;
195
- }
196
- :root.dark-theme {
197
- --divider-color: #e9ebed1f;
198
- }
199
- </style>
200
-
201
- <style scoped lang="scss">
202
- .customize-hardware {
203
- padding: 0 32px;
204
-
205
- .errors-alert {
206
- margin-top: 12px;
207
- }
208
-
209
- .navigation {
210
- border-bottom: 1px solid var(--divider-color);
211
- }
212
- }
213
-
214
- .light-theme {
215
- :deep(.stack-block-label .ui-main-select-toggle) {
216
- background-color: #ffffff;
217
- }
218
- :deep(.stack-block-expanded > .stack-block-label .ui-main-select-toggle) {
219
- background-color: #1b2a371f;
220
- border-color: #e9ebed3d;
221
-
222
- .ui-arrow-icon {
223
- color: #e9eaec;
224
- }
225
- }
226
- :deep(.stack-block-expanded > .stack-block-label .combobox-input) {
227
- color: #e9eaec;
228
- }
229
- :deep(.stack-block-expanded > .stack-block-label .ui-selected-text) {
230
- color: #e9eaec;
231
- }
232
-
233
- :deep(.stack-block-label .ui-main-input) {
234
- background-color: #ffffff;
235
- }
236
- :deep(.stack-block-expanded > .stack-block-label .ui-main-input) {
237
- background-color: #1b2a371f;
238
- border-color: #e9ebed3d;
239
- color: #e9eaec;
240
- }
241
- }
242
-
243
- .dark-theme {
244
- :deep(.stack-block-label .ui-main-select-toggle) {
245
- background-color: #1b2a371f;
246
- }
247
- :deep(.stack-block-expanded > .stack-block-label .ui-main-select-toggle) {
248
- background-color: #ffffff;
249
- border-color: #d3d6da;
250
-
251
- .ui-arrow-icon {
252
- color: #182531;
253
- }
254
- }
255
- :deep(.stack-block-expanded > .stack-block-label .combobox-input) {
256
- color: #182531;
257
- }
258
- :deep(.stack-block-expanded > .stack-block-label .ui-selected-text) {
259
- color: #182531;
260
- }
261
-
262
- :deep(.stack-block-label .ui-main-input) {
263
- background-color: #1b2a371f;
264
- }
265
- :deep(.stack-block-expanded > .stack-block-label .ui-main-input) {
266
- background-color: #ffffff;
267
- border-color: #d3d6da;
268
- color: #182531;
269
- }
270
- }
271
- </style>
1
+ <template>
2
+ <div :class="['customize-hardware', themeMode]">
3
+ <ui-tabs
4
+ v-model="selectedNavItem"
5
+ test-id="vm-wizard-tabs"
6
+ :tabs="navItemsLocal"
7
+ type="underline"
8
+ class="navigation"
9
+ />
10
+ <ui-alert
11
+ v-show="props.errors.length"
12
+ status="alert-danger"
13
+ :messages="props.errors"
14
+ test-id="customize-hardware-alert"
15
+ class="errors-alert"
16
+ @remove="emits('remove-validation-errors')"
17
+ />
18
+
19
+ <div v-show="selectedNavItem === 0">
20
+ <common-vm-actions-common-customize-hardware-virtual-hardware
21
+ :vm-name="vmName"
22
+ :storage="props.storage"
23
+ :max-cpus="props.maxCpus"
24
+ :max-memory="props.maxMemory"
25
+ :cpu-models="props.cpuModels"
26
+ :cpu="props.cpu"
27
+ :memory="props.memory"
28
+ :is-edit="props.isEdit"
29
+ :is-clone="props.isClone"
30
+ :state="props.state"
31
+ :hard-disks="props.hardDisks"
32
+ :cd-dvd-drives="props.cdDvdDrives"
33
+ :networks="props.networks"
34
+ :networks-table="props.networksTable"
35
+ :video-card="props.videoCard"
36
+ :usb-controller="props.usbController"
37
+ :pci-devices="props.pciDevices"
38
+ :nodes="props.nodes"
39
+ :files="props.files"
40
+ :error-validation-fields="props.errorValidationFields"
41
+ :get-datastore-table-func="props.getDatastoreTableFunc"
42
+ :datastore="props.datastore"
43
+ :vm-cpu-help-text-second="props.vmCpuHelpTextSecond"
44
+ :passthrough-devices="props.passthroughDevices"
45
+ :mediated-devices="props.mediatedDevices"
46
+ :project="props.project"
47
+ :guest-machine-type="guestMachineType"
48
+ @send-data="emits('send-data-virtual-hardware-method', $event)"
49
+ @get-storage="emits('get-storage', $event)"
50
+ @get-folders-or-files="emits('get-folders-or-files', $event)"
51
+ @get-active-device-child="emits('get-active-device-child', $event)"
52
+ @show-datastore-child="emits('show-datastore-child', $event)"
53
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
54
+ @invalid="virtualHardwareInvalid = $event"
55
+ @get-networks-table="emits('get-networks-table', $event)"
56
+ @get-pci-devices="emits('get-pci-devices')"
57
+ />
58
+ </div>
59
+ <div v-show="selectedNavItem === 1">
60
+ <common-vm-actions-common-customize-hardware-vmoptions
61
+ v-model:vm-name="vmName"
62
+ v-model:guest-machine-type="guestMachineType"
63
+ v-model:guest-os-family="guestOsFamily"
64
+ v-model:guest-os-version="guestOsVersion"
65
+ :hard-disks="props.hardDisksForBootOptions"
66
+ :cd-dvd-drives="props.cdDvdDrivesForBootOptions"
67
+ :networks="props.networksForBootOptions"
68
+ :options="props.options"
69
+ :is-edit="props.isEdit"
70
+ :is-clone="props.isClone"
71
+ :error-validation-fields="props.errorValidationFields"
72
+ :state="props.state"
73
+ @change-boot-order="emits('change-boot-order', $event)"
74
+ @send-data="emits('send-data-vm-options-method', $event)"
75
+ @invalid="vmOptionsInvalid = $event"
76
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
77
+ />
78
+ </div>
79
+ </div>
80
+ </template>
81
+
82
+ <script setup lang="ts">
83
+ import type { UI_I_TabItem } from 'bfg-uikit/components/ui/tabs/models/interfaces'
84
+ import type { UI_T_Project } from '~/lib/models/types'
85
+ import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
86
+ import type { UI_I_NetworkTableItem } from '~/lib/models/store/network/interfaces'
87
+ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
88
+ import type { UI_I_FolderOrFileTreePayload } from '~/lib/models/store/storage/interfaces'
89
+ import type { UI_I_FileTreeNode } from '~/components/lib/models/interfaces'
90
+ import type {
91
+ UI_I_SendDataNewPciDevice,
92
+ UI_I_SendDataNewCdDvdDrive,
93
+ UI_I_SendDataNewHardDisk,
94
+ UI_I_SendDataNewNetwork,
95
+ UI_I_SendDataVideoCard,
96
+ UI_I_SendDataVirtualHardware,
97
+ } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
98
+ import type { UI_I_SendDataVmoptions } from '~/components/common/vm/actions/common/customizeHardware/vmoptions/lib/models/interfaces'
99
+ import type { UI_T_SelectedNavItem } from '~/components/common/vm/actions/common/lib/models/types'
100
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
101
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
102
+ import type { UI_T_ChangeBootOrder } from '~/components/common/vm/actions/lib/models/types'
103
+ import type {
104
+ API_UI_I_VmEditCpu,
105
+ API_UI_I_VmEditMemory,
106
+ UI_I_MediatedDevice,
107
+ UI_I_PciDevice,
108
+ } from '~/lib/models/store/vm/interfaces'
109
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
110
+ import { navItemsNewViewFunc } from '~/components/common/vm/actions/common/customizeHardware/lib/config/navItems'
111
+
112
+ const vmName = defineModel<string>('vmName', { required: true })
113
+ const guestOsFamily = defineModel<UI_I_OptionItem | null>('guestOsFamily', {
114
+ required: true,
115
+ })
116
+ const guestOsVersion = defineModel<UI_I_OptionItem | null>('guestOsVersion', {
117
+ required: true,
118
+ })
119
+ const selectedNavItem = defineModel<UI_T_SelectedNavItem>('selectedNavItem', {
120
+ required: true,
121
+ })
122
+ const guestMachineType = defineModel<UI_I_OptionItem | null>(
123
+ 'guestMachineType',
124
+ { required: true }
125
+ )
126
+ const vmOptionsInvalid = defineModel<string[]>('vmOptionsInvalid', {
127
+ required: true,
128
+ })
129
+ const virtualHardwareInvalid = defineModel<string[]>('virtualHardwareInvalid', {
130
+ required: true,
131
+ })
132
+
133
+ const props = defineProps<{
134
+ nodes: UI_I_FileTreeNode[]
135
+ files: UI_I_FileTreeNode[]
136
+ errors: string[]
137
+ storage: UI_I_DatastoreTableItem | null
138
+ maxCpus: number
139
+ navItems: UI_I_TabItem[]
140
+ cpuModels: UI_I_OptionItem[]
141
+ maxMemory: number
142
+ datastore: UI_I_DatastoreTableItem[]
143
+ networksTable: UI_I_NetworkTableItem[]
144
+ errorValidationFields: UI_I_ErrorValidationField[]
145
+ networksForBootOptions: UI_I_SendDataNewNetwork[] | null
146
+ hardDisksForBootOptions: UI_I_SendDataNewHardDisk[] | null
147
+ cdDvdDrivesForBootOptions: UI_I_SendDataNewCdDvdDrive[] | null
148
+ cpu?: API_UI_I_VmEditCpu
149
+ state?: string | number
150
+ isEdit?: boolean
151
+ memory?: API_UI_I_VmEditMemory
152
+ project?: UI_T_Project
153
+ isClone?: boolean
154
+ options?: UI_I_SendDataVmoptions
155
+ networks?: UI_I_SendDataNewNetwork[] | null
156
+ videoCard?: UI_I_SendDataVideoCard
157
+ hardDisks?: UI_I_SendDataNewHardDisk[] | null
158
+ pciDevices?: UI_I_SendDataNewPciDevice[]
159
+ cdDvdDrives?: UI_I_SendDataNewCdDvdDrive[] | null
160
+ usbController?: string
161
+ passthroughDevices?: UI_I_PciDevice[]
162
+ mediatedDevices?: UI_I_MediatedDevice[]
163
+ vmCpuHelpTextSecond?: string
164
+ getDatastoreTableFunc?: (payload: UI_I_TablePayload) => Promise<void>
165
+ }>()
166
+ const emits = defineEmits<{
167
+ (event: 'get-storage', value: UI_I_TablePayload): void
168
+ (event: 'get-pci-devices'): void
169
+ (event: 'get-networks-table', value: UI_I_TablePayload): void
170
+ (event: 'get-folders-or-files', value: UI_I_FolderOrFileTreePayload): void
171
+ (event: 'show-datastore-child', value: UI_I_FileTreeNode): void
172
+ (event: 'remove-error-by-title', value: string): void
173
+ (event: 'get-active-device-child', value: UI_I_FileTreeNode): void
174
+ (event: 'remove-validation-errors'): void
175
+ (event: 'send-data-vm-options-method', value: UI_I_SendDataVmoptions): void
176
+ (
177
+ event: 'send-data-virtual-hardware-method',
178
+ value: UI_I_SendDataVirtualHardware
179
+ ): void
180
+ (event: 'change-boot-order', value: UI_T_ChangeBootOrder): void
181
+ }>()
182
+
183
+ const localization = computed<UI_I_Localization>(() => useLocal())
184
+
185
+ const navItemsLocal = computed<UI_I_TabItem[]>(() =>
186
+ navItemsNewViewFunc(localization.value)
187
+ )
188
+
189
+ const themeMode = useLocalStorage('themeMode')
190
+ </script>
191
+
192
+ <style lang="scss">
193
+ :root {
194
+ --divider-color: #e9ebed;
195
+ }
196
+ :root.dark-theme {
197
+ --divider-color: #e9ebed1f;
198
+ }
199
+ </style>
200
+
201
+ <style scoped lang="scss">
202
+ .customize-hardware {
203
+ padding: 0 32px;
204
+
205
+ .errors-alert {
206
+ margin-top: 12px;
207
+ }
208
+
209
+ .navigation {
210
+ border-bottom: 1px solid var(--divider-color);
211
+ }
212
+ }
213
+
214
+ .light-theme {
215
+ :deep(.stack-block-label .ui-main-select-toggle) {
216
+ background-color: #ffffff;
217
+ }
218
+ :deep(.stack-block-expanded > .stack-block-label .ui-main-select-toggle) {
219
+ background-color: #1b2a371f;
220
+ border-color: #e9ebed3d;
221
+
222
+ .ui-arrow-icon {
223
+ color: #e9eaec;
224
+ }
225
+ }
226
+ :deep(.stack-block-expanded > .stack-block-label .combobox-input) {
227
+ color: #e9eaec;
228
+ }
229
+ :deep(.stack-block-expanded > .stack-block-label .ui-selected-text) {
230
+ color: #e9eaec;
231
+ }
232
+
233
+ :deep(.stack-block-label .ui-main-input) {
234
+ background-color: #ffffff;
235
+ }
236
+ :deep(.stack-block-expanded > .stack-block-label .ui-main-input) {
237
+ background-color: #1b2a371f;
238
+ border-color: #e9ebed3d;
239
+ color: #e9eaec;
240
+ }
241
+ }
242
+
243
+ .dark-theme {
244
+ :deep(.stack-block-label .ui-main-select-toggle) {
245
+ background-color: #1b2a371f;
246
+ }
247
+ :deep(.stack-block-expanded > .stack-block-label .ui-main-select-toggle) {
248
+ background-color: #ffffff;
249
+ border-color: #d3d6da;
250
+
251
+ .ui-arrow-icon {
252
+ color: #182531;
253
+ }
254
+ }
255
+ :deep(.stack-block-expanded > .stack-block-label .combobox-input) {
256
+ color: #182531;
257
+ }
258
+ :deep(.stack-block-expanded > .stack-block-label .ui-selected-text) {
259
+ color: #182531;
260
+ }
261
+
262
+ :deep(.stack-block-label .ui-main-input) {
263
+ background-color: #1b2a371f;
264
+ }
265
+ :deep(.stack-block-expanded > .stack-block-label .ui-main-input) {
266
+ background-color: #ffffff;
267
+ border-color: #d3d6da;
268
+ color: #182531;
269
+ }
270
+ }
271
+ </style>