bfg-common 1.5.558 → 1.5.559

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 (173) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  3. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  4. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  5. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  6. package/assets/localization/local_be.json +26 -5
  7. package/assets/localization/local_en.json +26 -5
  8. package/assets/localization/local_hy.json +26 -5
  9. package/assets/localization/local_kk.json +26 -5
  10. package/assets/localization/local_ru.json +26 -5
  11. package/assets/localization/local_zh.json +27 -6
  12. package/components/atoms/TheIcon3.vue +50 -50
  13. package/components/atoms/collapse/CollapseNav.vue +170 -170
  14. package/components/atoms/perPage/PerPage.vue +58 -58
  15. package/components/atoms/table/dataGrid/DataGrid.vue +1718 -1718
  16. package/components/atoms/table/dataGrid/DataGridPagination.vue +97 -97
  17. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  18. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  19. package/components/common/backup/storage/actions/add/Add.vue +251 -251
  20. package/components/common/backup/storage/actions/add/lib/utils.ts +51 -51
  21. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  22. package/components/common/diagramMain/modals/lib/config/portModal.ts +251 -251
  23. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  24. package/components/common/diagramMain/port/Port.vue +580 -580
  25. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  26. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  27. package/components/common/modals/confirmByInput/ConfirmByInput.vue +9 -1
  28. package/components/common/modals/confirmByInput/ConfirmByInputNew.vue +7 -2
  29. package/components/common/pages/backups/DetailView.vue +52 -52
  30. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  31. package/components/common/pages/backups/modals/Modals.vue +243 -243
  32. package/components/common/pages/backups/modals/createBackup/New.vue +8 -2
  33. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  34. package/components/common/pages/backups/modals/createBackup/lib/config/readyToCompleteOptions.ts +69 -69
  35. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  36. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  37. package/components/common/pages/backups/modals/restore/Restore.vue +9 -5
  38. package/components/common/pages/backups/modals/restore/RestoreNew.vue +13 -3
  39. package/components/common/pages/backups/modals/restore/RestoreOld.vue +6 -18
  40. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  41. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  42. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  43. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  44. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  45. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  46. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  47. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  48. package/components/common/select/radio/RadioGroup.vue +137 -137
  49. package/components/common/spiceConsole/Drawer.vue +420 -420
  50. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  51. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  52. package/components/common/tools/Actions.vue +207 -207
  53. package/components/common/treeView/TreeView.vue +52 -52
  54. package/components/common/vm/actions/add/Add.vue +119 -46
  55. package/components/common/vm/actions/add/New.vue +54 -16
  56. package/components/common/vm/actions/add/Old.vue +55 -16
  57. package/components/common/vm/actions/add/lib/config/steps.ts +347 -347
  58. package/components/common/vm/actions/clone/Clone.vue +809 -809
  59. package/components/common/vm/actions/clone/new/New.vue +457 -457
  60. package/components/common/vm/actions/clone/old/Old.vue +378 -378
  61. package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +81 -14
  62. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +56 -7
  63. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +56 -8
  64. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +142 -73
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +54 -60
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +55 -61
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +159 -139
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuNew.vue +15 -8
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuOld.vue +13 -8
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +75 -62
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryNew.vue +158 -158
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryOld.vue +155 -155
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +427 -427
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +74 -58
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbController.vue +17 -6
  81. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerNew.vue +3 -6
  82. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerOld.vue +3 -6
  83. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  84. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCard.vue +39 -17
  85. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +5 -6
  86. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardOld.vue +5 -6
  87. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/lib/config/options.ts +4 -4
  88. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  89. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +93 -6
  90. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +62 -8
  91. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsOld.vue +60 -8
  92. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptions.vue +69 -5
  93. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +32 -12
  94. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsOld.vue +33 -12
  95. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  96. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  97. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +132 -114
  98. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +6 -41
  99. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderOld.vue +6 -44
  100. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptions.vue +23 -8
  101. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +31 -21
  102. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsOld.vue +34 -26
  103. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +34 -28
  104. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/Old.vue +30 -24
  105. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/RemoteConsoleOptions.vue +112 -8
  106. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +3 -3
  107. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/{New.vue → KeymapNew.vue} +6 -6
  108. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/{Old.vue → KeymapOld.vue} +5 -5
  109. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +7 -6
  110. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  111. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/Tools.vue +38 -4
  112. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/ToolsNew.vue +26 -7
  113. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/ToolsOld.vue +50 -24
  114. package/components/common/vm/actions/common/lib/models/interfaces.ts +25 -57
  115. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  116. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  117. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  118. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  119. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  120. package/components/common/vm/actions/common/select/storage/Old.vue +125 -125
  121. package/components/common/vm/actions/common/select/storage/Storage.vue +178 -178
  122. package/components/common/vm/actions/common/select/storage/new/New.vue +311 -311
  123. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  124. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  125. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  126. package/components/common/vm/actions/editSettings/EditSettings.vue +35 -21
  127. package/components/common/vm/actions/editSettings/EditSettingsOld.vue +41 -14
  128. package/components/common/vm/actions/editSettings/new/New.vue +41 -14
  129. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  130. package/components/common/vm/actions/lib/models/interfaces.ts +29 -4
  131. package/components/common/vm/actions/lib/utils.ts +32 -37
  132. package/components/common/vm/actions/register/Register.vue +352 -352
  133. package/components/common/vm/actions/register/lib/config/steps.ts +86 -86
  134. package/components/common/wizards/common/compatibility/Compatibility.vue +35 -35
  135. package/components/common/wizards/common/compatibility/New.vue +99 -99
  136. package/components/common/wizards/common/compatibility/Old.vue +53 -53
  137. package/components/common/wizards/common/steps/computeResource/ComputeResource.vue +86 -86
  138. package/components/common/wizards/common/steps/computeResource/New.vue +93 -93
  139. package/components/common/wizards/common/steps/computeResource/Old.vue +103 -103
  140. package/components/common/wizards/common/steps/name/Name.vue +178 -178
  141. package/components/common/wizards/common/steps/name/New.vue +221 -221
  142. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  143. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  144. package/components/common/wizards/common/steps/name/location/Location.vue +85 -85
  145. package/components/common/wizards/common/steps/name/location/New.vue +40 -40
  146. package/components/common/wizards/datastore/add/Add.vue +228 -228
  147. package/components/common/wizards/datastore/add/lib/utils.ts +85 -85
  148. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  149. package/components/common/wizards/vm/migrate/select/computeResource/ComputeResource.vue +205 -205
  150. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  151. package/composables/useAppVersion.ts +21 -21
  152. package/composables/useLocal.ts +6 -6
  153. package/composables/useLocalCommon.ts +39 -39
  154. package/package.json +3 -1
  155. package/plugins/console.ts +21 -21
  156. package/plugins/date.ts +233 -233
  157. package/plugins/mouse.ts +21 -21
  158. package/plugins/panelStates.ts +70 -70
  159. package/plugins/text.ts +59 -59
  160. package/public/spice-console/application/clientgui.js +854 -854
  161. package/public/spice-console/application/packetfactory.js +211 -211
  162. package/public/spice-console/application/virtualmouse.js +147 -147
  163. package/public/spice-console/lib/images/bitmap.js +203 -203
  164. package/public/spice-console/network/spicechannel.js +440 -440
  165. package/public/spice-console/process/cursorprocess.js +121 -121
  166. package/public/spice-console/process/inputprocess.js +227 -227
  167. package/public/spice-console/process/mainprocess.js +210 -210
  168. package/public/spice-console/run.js +210 -210
  169. package/store/main/mutations.ts +7 -7
  170. package/store/main/state.ts +7 -7
  171. package/store/tasks/mappers/recentTasks.ts +4 -0
  172. /package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/{New.vue → PasswordNew.vue} +0 -0
  173. /package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/{Old.vue → PasswordOld.vue} +0 -0
@@ -34,21 +34,24 @@
34
34
  <div class="overflow-auto virtual-hardware-content-block">
35
35
  <div class="stack-view">
36
36
  <common-vm-actions-common-customize-hardware-virtual-hardware-cpu
37
- v-model="model"
37
+ :max-cpus="props.maxCpus"
38
38
  :cpu-models="props.cpuModels"
39
+ :cpu="props.cpu"
39
40
  :is-edit="props.isEdit"
40
41
  :state="props.state"
41
42
  :error-validation-fields="props.errorValidationFields"
42
43
  :vm-cpu-help-text-second="props.vmCpuHelpTextSecond"
44
+ @send-data="emits('send-data-cpu-method', $event)"
43
45
  @remove-error-by-title="emits('remove-error-by-title', $event)"
44
46
  @invalid="cpuInvalid = $event"
45
47
  />
46
48
  <common-vm-actions-common-customize-hardware-virtual-hardware-memory
47
- v-model="model"
48
49
  :max-memory="props.maxMemory"
49
50
  :is-edit="props.isEdit"
51
+ :memory="props.memory"
50
52
  :state="props.state"
51
53
  :error-validation-fields="props.errorValidationFields"
54
+ @send-data="emits('send-data-memory-method', $event)"
52
55
  @invalid="memoryInvalid = $event"
53
56
  @remove-error-by-title="emits('remove-error-by-title', $event)"
54
57
  />
@@ -80,54 +83,30 @@
80
83
  "
81
84
  @remove-error-by-title="emits('remove-error-by-title', $event)"
82
85
  />
83
- <!-- <common-vm-actions-common-customize-hardware-virtual-hardware-new-network-->
84
- <!-- v-for="(item, key) in props.networks"-->
85
- <!-- :key="props.networksIndex[key]"-->
86
- <!-- :index="props.networksIndex[key]"-->
87
- <!-- :type="props.networksType[key]"-->
88
- <!-- :network="item"-->
89
- <!-- :networks-table="props.networksTable"-->
90
- <!-- :error-validation-fields="props.errorValidationFields"-->
91
- <!-- :is-edit="props.isEdit"-->
92
- <!-- :state="props.state"-->
93
- <!-- :project="props.project"-->
94
- <!-- @remove="emits('remove-network', props.networksIndex[key])"-->
95
- <!-- @send-data="-->
96
- <!-- emits('send-data-new-network-method', [-->
97
- <!-- $event,-->
98
- <!-- props.networksIndex[key],-->
99
- <!-- ])-->
100
- <!-- "-->
101
- <!-- @invalid="-->
102
- <!-- emits('set-invalid-network', [$event, props.networksIndex[key]])-->
103
- <!-- "-->
104
- <!-- @remove-error-by-title="emits('remove-error-by-title', $event)"-->
105
- <!-- @get-networks-table="emits('get-networks-table', $event)"-->
106
- <!-- />-->
107
- <div
108
- v-for="(item, key) in model.network_devices"
86
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-network
87
+ v-for="(item, key) in props.networks"
109
88
  :key="props.networksIndex[key]"
110
- >
111
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-network
112
- v-model:network="item.network"
113
- v-model:net-bridge="item.net_bridge"
114
- v-model:mac="item.mac"
115
- v-model:model="item.model"
116
- :index="props.networksIndex[key]"
117
- :type="props.networksType[key]"
118
- :networks-table="props.networksTable"
119
- :error-validation-fields="props.errorValidationFields"
120
- :is-edit="props.isEdit"
121
- :state="props.state"
122
- :project="props.project"
123
- @remove="emits('remove-network', props.networksIndex[key])"
124
- @invalid="
125
- emits('set-invalid-network', [$event, props.networksIndex[key]])
126
- "
127
- @remove-error-by-title="emits('remove-error-by-title', $event)"
128
- @get-networks-table="emits('get-networks-table', $event)"
129
- />
130
- </div>
89
+ :index="props.networksIndex[key]"
90
+ :type="props.networksType[key]"
91
+ :network="item"
92
+ :networks-table="props.networksTable"
93
+ :error-validation-fields="props.errorValidationFields"
94
+ :is-edit="props.isEdit"
95
+ :state="props.state"
96
+ :project="props.project"
97
+ @remove="emits('remove-network', props.networksIndex[key])"
98
+ @send-data="
99
+ emits('send-data-new-network-method', [
100
+ $event,
101
+ props.networksIndex[key],
102
+ ])
103
+ "
104
+ @invalid="
105
+ emits('set-invalid-network', [$event, props.networksIndex[key]])
106
+ "
107
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
108
+ @get-networks-table="emits('get-networks-table', $event)"
109
+ />
131
110
  <common-vm-actions-common-customize-hardware-virtual-hardware-cd-dvd-drive
132
111
  v-for="(item, key) in props.cdDvdDrives"
133
112
  :key="props.cdDvdDrivesIndex[key]"
@@ -160,13 +139,12 @@
160
139
  ])
161
140
  "
162
141
  />
163
- <div v-for="(item, key) in model.usb_controllers" :key="key">
164
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-usb-controller
165
- v-model="item.type"
166
- :is-edit="props.isEdit"
167
- :state="props.state"
168
- />
169
- </div>
142
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-usb-controller
143
+ :usb-controller="props.usbController"
144
+ :is-edit="props.isEdit"
145
+ :state="props.state"
146
+ @send-data="emits('send-data-new-usb-controller-method', $event)"
147
+ />
170
148
  <template v-if="props.passthroughDevices || props.mediatedDevices">
171
149
  <common-vm-actions-common-customize-hardware-virtual-hardware-new-pci-device
172
150
  v-for="(item, key) in props.pciDevices"
@@ -196,11 +174,11 @@
196
174
  />
197
175
  </template>
198
176
  <common-vm-actions-common-customize-hardware-virtual-hardware-video-card
199
- v-model="model.video_card"
200
177
  :is-edit="props.isEdit"
201
178
  :video-card="props.videoCard"
202
179
  :error-validation-fields="props.errorValidationFields"
203
180
  :state="props.state"
181
+ @send-data="emits('send-data-video-card-method', $event)"
204
182
  @invalid="videoCardInvalid = $event"
205
183
  @remove-error-by-title="emits('remove-error-by-title', $event)"
206
184
  />
@@ -242,7 +220,10 @@ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
242
220
  import type { UI_I_FolderOrFileTreePayload } from '~/lib/models/store/storage/interfaces'
243
221
  import type { UI_I_FileTreeNode } from '~/components/lib/models/interfaces'
244
222
  import type {
223
+ UI_I_SendDataCpu,
224
+ UI_I_SendDataMemory,
245
225
  UI_I_SendDataNewHardDisk,
226
+ UI_I_SendDataNewNetwork,
246
227
  UI_I_SendDataVideoCard,
247
228
  UI_I_SendDataNewCdDvdDrive,
248
229
  UI_I_SendDataNewPciDevice,
@@ -256,15 +237,13 @@ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
256
237
  import type { UI_I_Localization } from '~/lib/models/interfaces'
257
238
  import type {
258
239
  API_UI_I_VmEditCpu,
240
+ API_UI_I_VmEditMemory,
259
241
  UI_I_MediatedDevice,
260
242
  UI_I_PciDevice,
261
243
  } from '~/lib/models/store/vm/interfaces'
262
244
  import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
263
- import type { UI_I_CreateVmData } from '~/components/common/vm/actions/common/lib/models/interfaces'
264
245
  import { dropdownItemsNewFunc } from './lib/config/dropdownItems'
265
246
 
266
- const model = defineModel<UI_I_CreateVmData>({ required: true })
267
-
268
247
  const cpuInvalid = defineModel<boolean>('cpuInvalid', { required: true })
269
248
  const memoryInvalid = defineModel<boolean>('memoryInvalid', { required: true })
270
249
  const videoCardInvalid = defineModel<boolean>('videoCardInvalid', {
@@ -278,6 +257,7 @@ const props = withDefaults(
278
257
  isEdit: boolean
279
258
  storage: UI_I_DatastoreTableItem | null
280
259
  project: UI_T_Project
260
+ maxCpus: number
281
261
  maxMemory: number
282
262
  cpuModels: UI_I_OptionItem[]
283
263
  datastore: UI_I_DatastoreTableItem[]
@@ -297,10 +277,13 @@ const props = withDefaults(
297
277
  getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
298
278
  cpu?: API_UI_I_VmEditCpu
299
279
  state?: string | number
280
+ memory?: API_UI_I_VmEditMemory
281
+ networks?: UI_I_SendDataNewNetwork[] | null
300
282
  hardDisks?: UI_I_SendDataNewHardDisk[] | null
301
283
  videoCard?: UI_I_SendDataVideoCard
302
284
  pciDevices?: UI_I_SendDataNewPciDevice[]
303
285
  cdDvdDrives?: UI_I_SendDataNewCdDvdDrive[] | null
286
+ usbController?: string
304
287
  guestMachineType?: UI_I_OptionItem | null
305
288
  passthroughDevices?: UI_I_PciDevice[]
306
289
  mediatedDevices?: UI_I_MediatedDevice[]
@@ -311,10 +294,13 @@ const props = withDefaults(
311
294
  {
312
295
  cpu: undefined,
313
296
  state: undefined,
297
+ memory: undefined,
298
+ networks: undefined,
314
299
  hardDisks: undefined,
315
300
  videoCard: undefined,
316
301
  pciDevices: undefined,
317
302
  cdDvdDrives: undefined,
303
+ usbController: undefined,
318
304
  guestMachineType: undefined,
319
305
  passthroughDevices: undefined,
320
306
  mediatedDevices: undefined,
@@ -340,11 +326,18 @@ const emits = defineEmits<{
340
326
  ): void
341
327
  (event: 'show-datastore-child', value: UI_I_FileTreeNode): void
342
328
  (event: 'get-folders-or-files', value: UI_I_FolderOrFileTreePayload): void
329
+ (event: 'send-data-cpu-method', value: UI_I_SendDataCpu): void
343
330
  (event: 'set-invalid-hard-disk', value: [boolean, number]): void
344
331
  (event: 'remove-error-by-title', value: string): void
345
332
  (event: 'roll-back-cd-dvd-drive', value: number): void
346
333
  (event: 'set-invalid-pci-device', value: [boolean, number]): void
347
334
  (event: 'get-active-device-child', value: UI_I_FileTreeNode): void
335
+ (event: 'send-data-memory-method', value: UI_I_SendDataMemory): void
336
+ (event: 'send-data-video-card-method', value: UI_I_SendDataVideoCard): void
337
+ (
338
+ event: 'send-data-new-network-method',
339
+ value: [UI_I_SendDataNewNetwork, number]
340
+ ): void
348
341
  (
349
342
  event: 'send-data-pci-devices-method',
350
343
  value: [UI_I_SendDataNewPciDevice, number]
@@ -357,6 +350,7 @@ const emits = defineEmits<{
357
350
  event: 'send-data-new-cd-dvd-drive-method',
358
351
  value: [UI_I_SendDataNewCdDvdDrive, number]
359
352
  ): void
353
+ (event: 'send-data-new-usb-controller-method', value: string): void
360
354
  }>()
361
355
 
362
356
  const { $text } = useNuxtApp()
@@ -12,21 +12,24 @@
12
12
  <div class="clr-component">
13
13
  <div class="stack-view">
14
14
  <common-vm-actions-common-customize-hardware-virtual-hardware-cpu
15
- v-model="model"
15
+ :max-cpus="props.maxCpus"
16
16
  :cpu-models="props.cpuModels"
17
+ :cpu="props.cpu"
17
18
  :is-edit="props.isEdit"
18
19
  :state="props.state"
19
20
  :error-validation-fields="props.errorValidationFields"
20
21
  :vm-cpu-help-text-second="props.vmCpuHelpTextSecond"
22
+ @send-data="emits('send-data-cpu-method', $event)"
21
23
  @remove-error-by-title="emits('remove-error-by-title', $event)"
22
24
  @invalid="cpuInvalid = $event"
23
25
  />
24
26
  <common-vm-actions-common-customize-hardware-virtual-hardware-memory
25
- v-model="model"
26
27
  :max-memory="props.maxMemory"
27
28
  :is-edit="props.isEdit"
29
+ :memory="props.memory"
28
30
  :state="props.state"
29
31
  :error-validation-fields="props.errorValidationFields"
32
+ @send-data="emits('send-data-memory-method', $event)"
30
33
  @invalid="memoryInvalid = $event"
31
34
  @remove-error-by-title="emits('remove-error-by-title', $event)"
32
35
  />
@@ -58,54 +61,30 @@
58
61
  "
59
62
  @remove-error-by-title="emits('remove-error-by-title', $event)"
60
63
  />
61
- <!-- <common-vm-actions-common-customize-hardware-virtual-hardware-new-network-->
62
- <!-- v-for="(item, key) in props.networks"-->
63
- <!-- :key="props.networksIndex[key]"-->
64
- <!-- :index="props.networksIndex[key]"-->
65
- <!-- :type="props.networksType[key]"-->
66
- <!-- :network="item"-->
67
- <!-- :networks-table="props.networksTable"-->
68
- <!-- :error-validation-fields="props.errorValidationFields"-->
69
- <!-- :is-edit="props.isEdit"-->
70
- <!-- :state="props.state"-->
71
- <!-- :project="props.project"-->
72
- <!-- @remove="emits('remove-network', props.networksIndex[key])"-->
73
- <!-- @send-data="-->
74
- <!-- emits('send-data-new-network-method', [-->
75
- <!-- $event,-->
76
- <!-- props.networksIndex[key],-->
77
- <!-- ])-->
78
- <!-- "-->
79
- <!-- @invalid="-->
80
- <!-- emits('set-invalid-network', [$event, props.networksIndex[key]])-->
81
- <!-- "-->
82
- <!-- @remove-error-by-title="emits('remove-error-by-title', $event)"-->
83
- <!-- @get-networks-table="emits('get-networks-table', $event)"-->
84
- <!-- />-->
85
- <div
86
- v-for="(item, key) in model.network_devices"
64
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-network
65
+ v-for="(item, key) in props.networks"
87
66
  :key="props.networksIndex[key]"
88
- >
89
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-network
90
- v-model:network="item.network"
91
- v-model:net-bridge="item.net_bridge"
92
- v-model:mac="item.mac"
93
- v-model:model="item.model"
94
- :index="props.networksIndex[key]"
95
- :type="props.networksType[key]"
96
- :networks-table="props.networksTable"
97
- :error-validation-fields="props.errorValidationFields"
98
- :is-edit="props.isEdit"
99
- :state="props.state"
100
- :project="props.project"
101
- @remove="emits('remove-network', props.networksIndex[key])"
102
- @invalid="
103
- emits('set-invalid-network', [$event, props.networksIndex[key]])
104
- "
105
- @remove-error-by-title="emits('remove-error-by-title', $event)"
106
- @get-networks-table="emits('get-networks-table', $event)"
107
- />
108
- </div>
67
+ :index="props.networksIndex[key]"
68
+ :type="props.networksType[key]"
69
+ :network="item"
70
+ :networks-table="props.networksTable"
71
+ :error-validation-fields="props.errorValidationFields"
72
+ :is-edit="props.isEdit"
73
+ :state="props.state"
74
+ :project="props.project"
75
+ @remove="emits('remove-network', props.networksIndex[key])"
76
+ @send-data="
77
+ emits('send-data-new-network-method', [
78
+ $event,
79
+ props.networksIndex[key],
80
+ ])
81
+ "
82
+ @invalid="
83
+ emits('set-invalid-network', [$event, props.networksIndex[key]])
84
+ "
85
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
86
+ @get-networks-table="emits('get-networks-table', $event)"
87
+ />
109
88
  <common-vm-actions-common-customize-hardware-virtual-hardware-cd-dvd-drive
110
89
  v-for="(item, key) in props.cdDvdDrives"
111
90
  :key="props.cdDvdDrivesIndex[key]"
@@ -138,13 +117,12 @@
138
117
  ])
139
118
  "
140
119
  />
141
- <div v-for="(item, key) in model.usb_controllers" :key="key">
142
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-usb-controller
143
- v-model="item.type"
144
- :is-edit="props.isEdit"
145
- :state="props.state"
146
- />
147
- </div>
120
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-usb-controller
121
+ :usb-controller="props.usbController"
122
+ :is-edit="props.isEdit"
123
+ :state="props.state"
124
+ @send-data="emits('send-data-new-usb-controller-method', $event)"
125
+ />
148
126
  <template v-if="props.passthroughDevices || props.mediatedDevices">
149
127
  <common-vm-actions-common-customize-hardware-virtual-hardware-new-pci-device
150
128
  v-for="(item, key) in props.pciDevices"
@@ -174,11 +152,11 @@
174
152
  />
175
153
  </template>
176
154
  <common-vm-actions-common-customize-hardware-virtual-hardware-video-card
177
- v-model="model.video_card"
178
155
  :is-edit="props.isEdit"
179
156
  :video-card="props.videoCard"
180
157
  :error-validation-fields="props.errorValidationFields"
181
158
  :state="props.state"
159
+ @send-data="emits('send-data-video-card-method', $event)"
182
160
  @invalid="videoCardInvalid = $event"
183
161
  @remove-error-by-title="emits('remove-error-by-title', $event)"
184
162
  />
@@ -211,7 +189,10 @@ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
211
189
  import type { UI_I_FolderOrFileTreePayload } from '~/lib/models/store/storage/interfaces'
212
190
  import type { UI_I_FileTreeNode } from '~/components/lib/models/interfaces'
213
191
  import type {
192
+ UI_I_SendDataCpu,
193
+ UI_I_SendDataMemory,
214
194
  UI_I_SendDataNewHardDisk,
195
+ UI_I_SendDataNewNetwork,
215
196
  UI_I_SendDataVideoCard,
216
197
  UI_I_SendDataNewCdDvdDrive,
217
198
  // UI_I_HardDisk,
@@ -230,13 +211,11 @@ import type {
230
211
  import type { UI_I_Localization } from '~/lib/models/interfaces'
231
212
  import type {
232
213
  API_UI_I_VmEditCpu,
214
+ API_UI_I_VmEditMemory,
233
215
  UI_I_MediatedDevice,
234
216
  UI_I_PciDevice,
235
217
  } from '~/lib/models/store/vm/interfaces'
236
218
  import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
237
- import type { UI_I_CreateVmData } from '~/components/common/vm/actions/common/lib/models/interfaces'
238
-
239
- const model = defineModel<UI_I_CreateVmData>({ required: true })
240
219
 
241
220
  const cpuInvalid = defineModel<boolean>('cpuInvalid', { required: true })
242
221
  const memoryInvalid = defineModel<boolean>('memoryInvalid', { required: true })
@@ -251,6 +230,7 @@ const props = withDefaults(
251
230
  isEdit: boolean
252
231
  storage: UI_I_DatastoreTableItem | null
253
232
  project: UI_T_Project
233
+ maxCpus: number
254
234
  maxMemory: number
255
235
  cpuModels: UI_I_OptionItem[]
256
236
  datastore: UI_I_DatastoreTableItem[]
@@ -266,14 +246,17 @@ const props = withDefaults(
266
246
  pciDevicesIndex: number[]
267
247
  cdDvdDrivesType: UI_T_NetworkType[]
268
248
  cdDvdDrivesIndex: number[]
269
- errorValidationFields: UI_I_ErrorValidationField[]
249
+ errorValidationFields: UI_I_ErrorValidationField<string>[]
270
250
  getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
271
251
  cpu?: API_UI_I_VmEditCpu
272
252
  state?: string | number
253
+ memory?: API_UI_I_VmEditMemory
254
+ networks?: UI_I_SendDataNewNetwork[] | null
273
255
  hardDisks?: UI_I_SendDataNewHardDisk[] | null
274
256
  videoCard?: UI_I_SendDataVideoCard
275
257
  pciDevices?: UI_I_SendDataNewPciDevice[]
276
258
  cdDvdDrives?: UI_I_SendDataNewCdDvdDrive[] | null
259
+ usbController?: string
277
260
  guestMachineType?: UI_I_OptionItem | null
278
261
  passthroughDevices?: UI_I_PciDevice[]
279
262
  mediatedDevices?: UI_I_MediatedDevice[]
@@ -283,10 +266,13 @@ const props = withDefaults(
283
266
  {
284
267
  cpu: undefined,
285
268
  state: undefined,
269
+ memory: undefined,
270
+ networks: undefined,
286
271
  hardDisks: undefined,
287
272
  videoCard: undefined,
288
273
  pciDevices: undefined,
289
274
  cdDvdDrives: undefined,
275
+ usbController: undefined,
290
276
  guestMachineType: undefined,
291
277
  passthroughDevices: undefined,
292
278
  mediatedDevices: undefined,
@@ -311,11 +297,18 @@ const emits = defineEmits<{
311
297
  ): void
312
298
  (event: 'show-datastore-child', value: UI_I_FileTreeNode): void
313
299
  (event: 'get-folders-or-files', value: UI_I_FolderOrFileTreePayload): void
300
+ (event: 'send-data-cpu-method', value: UI_I_SendDataCpu): void
314
301
  (event: 'set-invalid-hard-disk', value: [boolean, number]): void
315
302
  (event: 'remove-error-by-title', value: string): void
316
303
  (event: 'roll-back-cd-dvd-drive', value: number): void
317
304
  (event: 'set-invalid-pci-device', value: [boolean, number]): void
318
305
  (event: 'get-active-device-child', value: UI_I_FileTreeNode): void
306
+ (event: 'send-data-memory-method', value: UI_I_SendDataMemory): void
307
+ (event: 'send-data-video-card-method', value: UI_I_SendDataVideoCard): void
308
+ (
309
+ event: 'send-data-new-network-method',
310
+ value: [UI_I_SendDataNewNetwork, number]
311
+ ): void
319
312
  (
320
313
  event: 'send-data-pci-devices-method',
321
314
  value: [UI_I_SendDataNewPciDevice, number]
@@ -328,6 +321,7 @@ const emits = defineEmits<{
328
321
  event: 'send-data-new-cd-dvd-drive-method',
329
322
  value: [UI_I_SendDataNewCdDvdDrive, number]
330
323
  ): void
324
+ (event: 'send-data-new-usb-controller-method', value: string): void
331
325
  }>()
332
326
 
333
327
  const localization = computed<UI_I_Localization>(() => useLocal())