bfg-common 1.5.420 → 1.5.421

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 (300) 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/scss/common/theme.scss +214 -0
  7. package/components/atoms/TheIcon3.vue +50 -50
  8. package/components/atoms/collapse/CollapseNav.vue +170 -170
  9. package/components/atoms/perPage/PerPage.vue +58 -58
  10. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  11. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  12. package/components/common/backup/storage/actions/add/lib/config/steps.ts +168 -168
  13. package/components/common/backup/storage/actions/add/steps/hostAccessibility/table/old/lib/config/incompatibleTable.ts +3 -3
  14. package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyComplete.vue +45 -45
  15. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  16. package/components/common/context/lib/models/interfaces.ts +33 -33
  17. package/components/common/diagramMain/modals/lib/config/networkModal.ts +398 -398
  18. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  19. package/components/common/pages/backups/Backups.vue +102 -102
  20. package/components/common/pages/backups/DetailView.vue +52 -52
  21. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  22. package/components/common/pages/backups/modals/Modals.vue +226 -226
  23. package/components/common/pages/backups/modals/createBackup/CreateBackup.vue +353 -353
  24. package/components/common/pages/backups/modals/createBackup/configuration/Configuration.vue +29 -29
  25. package/components/common/pages/backups/modals/createBackup/configuration/backupWindow/BackupWindow.vue +26 -26
  26. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/MaxBandwidth.vue +66 -66
  27. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  28. package/components/common/pages/backups/modals/createBackup/configuration/strategy/Strategy.vue +35 -35
  29. package/components/common/pages/backups/modals/createBackup/datastores/Datastores.vue +59 -59
  30. package/components/common/pages/backups/modals/createBackup/datastores/tableView/TableView.vue +95 -95
  31. package/components/common/pages/backups/modals/createBackup/datastores/tableView/lib/config/table.ts +119 -119
  32. package/components/common/pages/backups/modals/createBackup/disks/tableView/lib/config/table.ts +117 -117
  33. package/components/common/pages/backups/modals/createBackup/general/General.vue +48 -48
  34. package/components/common/pages/backups/modals/createBackup/lib/config/steps.ts +117 -117
  35. package/components/common/pages/backups/modals/createBackup/lib/config/strategyOptions.ts +12 -12
  36. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  37. package/components/common/pages/backups/modals/lib/models/interfaces.ts +185 -185
  38. package/components/common/pages/backups/modals/restore/Restore.vue +417 -417
  39. package/components/common/pages/backups/modals/restore/disks/Disks.vue +27 -27
  40. package/components/common/pages/backups/modals/restore/disks/tableView/TableView.vue +102 -102
  41. package/components/common/pages/backups/modals/restore/disks/tableView/lib/config/table.ts +117 -117
  42. package/components/common/pages/backups/modals/restore/lib/config/steps.ts +108 -108
  43. package/components/common/pages/backups/modals/restore/name/Name.vue +160 -160
  44. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  45. package/components/common/pages/backups/modals/restore/networks/Networks.vue +67 -67
  46. package/components/common/pages/backups/modals/restore/networks/table/Table.vue +214 -214
  47. package/components/common/pages/backups/modals/restore/types/lib/config/typeOptions.ts +25 -25
  48. package/components/common/pages/backups/tools/Tools.vue +75 -75
  49. package/components/common/pages/backups/tools/lib/config/tabs.ts +36 -36
  50. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  51. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  52. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  53. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  54. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  55. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  56. package/components/common/pages/home/widgets/warnings/lib/config/config.ts +2 -2
  57. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  58. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  59. package/components/common/resource/simple/Simple.vue +10 -3
  60. package/components/common/select/button/ButtonDropdown.vue +112 -112
  61. package/components/common/select/radio/RadioGroup.vue +137 -137
  62. package/components/common/selectLanguage/SelectLanguage.vue +1 -1
  63. package/components/common/spiceConsole/Drawer.vue +381 -381
  64. package/components/common/spiceConsole/SpiceConsole.vue +127 -127
  65. package/components/common/spiceConsole/keyboard/Keyboard.vue +1 -1
  66. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  67. package/components/common/split/horizontal/HorizontalNew.vue +5 -22
  68. package/components/common/split/horizontal/HorizontalOld.vue +3 -10
  69. package/components/common/split/vertical/VerticalNew.vue +2 -13
  70. package/components/common/split/vertical/VerticalOld.vue +1 -1
  71. package/components/common/summary/notification/NotificationNew.vue +4 -20
  72. package/components/common/titleBar/titleBarNew/notification/Notification.vue +0 -31
  73. package/components/common/tools/Actions.vue +207 -207
  74. package/components/common/tooltip/Help.vue +5 -18
  75. package/components/common/tooltip/lib/models/types.ts +1 -1
  76. package/components/common/treeView/TreeView.vue +52 -52
  77. package/components/common/vm/actions/add/Add.vue +35 -26
  78. package/components/common/vm/actions/add/New.vue +54 -55
  79. package/components/common/vm/actions/add/Old.vue +398 -388
  80. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  81. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  82. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  83. package/components/common/vm/actions/clone/Clone.vue +823 -823
  84. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  85. package/components/common/vm/actions/clone/toTemplate/ToTemplate.vue +32 -36
  86. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  87. package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +61 -37
  88. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +61 -46
  89. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +59 -36
  90. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +50 -31
  91. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +64 -68
  92. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +339 -321
  93. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +232 -227
  94. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +110 -100
  95. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusNew.vue +16 -10
  96. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusOld.vue +16 -10
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +239 -232
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveNew.vue +24 -18
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +174 -168
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +70 -78
  102. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  103. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +16 -11
  104. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuNew.vue +48 -51
  105. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuOld.vue +20 -15
  106. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/model/ModelNew.vue +4 -4
  107. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  108. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  109. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipNew.vue +153 -154
  110. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +221 -220
  111. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +313 -307
  112. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/hotPlug/HotPlugNew.vue +2 -2
  113. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +392 -385
  114. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskNew.vue +34 -42
  115. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskOld.vue +50 -40
  116. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/cache/Cache.vue +6 -6
  117. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/file/FileNew.vue +0 -8
  118. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/file/FileOld.vue +2 -2
  119. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/limitIops/LimitIops.vue +2 -2
  120. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/limitIops/lib/config/options.ts +4 -0
  121. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  122. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +85 -85
  123. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/storageModal/StorageModal.vue +13 -8
  124. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/storageModal/new/New.vue +15 -12
  125. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/maximumSize/MaximumSize.vue +23 -23
  126. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/maximumSize/MaximumSizeNew.vue +2 -10
  127. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/maximumSize/MaximumSizeOld.vue +1 -2
  128. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +293 -288
  129. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkNew.vue +20 -15
  130. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkOld.vue +1 -1
  131. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/New.vue +1 -1
  132. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
  133. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  134. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +210 -205
  135. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDeviceNew.vue +5 -2
  136. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDeviceOld.vue +1 -1
  137. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  138. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  139. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  140. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  141. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  142. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  143. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  144. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  145. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbController.vue +3 -3
  146. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerNew.vue +2 -2
  147. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  148. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +1 -1
  149. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherOld.vue +1 -1
  150. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/inputDevices/InputDevicesNew.vue +0 -10
  151. package/components/common/vm/actions/common/customizeHardware/virtualHardware/reservation/Reservation.vue +1 -0
  152. package/components/common/vm/actions/common/customizeHardware/virtualHardware/reservation/ReservationNew.vue +1 -0
  153. package/components/common/vm/actions/common/customizeHardware/virtualHardware/reservation/ReservationOld.vue +1 -0
  154. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCard.vue +162 -154
  155. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +17 -12
  156. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardOld.vue +17 -12
  157. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/model/Model.vue +3 -5
  158. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  159. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/TotalVideoMemory.vue +6 -4
  160. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/lib/config/options.ts +3 -0
  161. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +163 -155
  162. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +138 -130
  163. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsOld.vue +120 -113
  164. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptions.vue +15 -9
  165. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +1 -1
  166. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsOld.vue +19 -14
  167. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/Secure.vue +1 -1
  168. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  169. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/DelayNew.vue +1 -1
  170. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/DelayOld.vue +2 -2
  171. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  172. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/FirmwareNew.vue +1 -1
  173. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/FirmwareOld.vue +1 -1
  174. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/MenuNew.vue +1 -1
  175. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/MenuOld.vue +1 -1
  176. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  177. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +2 -2
  178. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderOld.vue +1 -1
  179. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptions.vue +101 -95
  180. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +1 -1
  181. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsOld.vue +158 -155
  182. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +1 -1
  183. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/Old.vue +7 -7
  184. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/PowerControl.vue +2 -2
  185. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/RemoteConsoleOptions.vue +15 -9
  186. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +1 -1
  187. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +1 -1
  188. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  189. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapOld.vue +44 -44
  190. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  191. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/sharePolicy/SharePolicy.vue +2 -2
  192. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  193. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  194. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/zlibCompression/ZlibCompression.vue +2 -2
  195. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/ToolsNew.vue +3 -3
  196. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/ToolsOld.vue +17 -12
  197. package/components/common/vm/actions/common/select/compatibility/New.vue +0 -18
  198. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  199. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +143 -143
  200. package/components/common/vm/actions/common/select/computeResource/New.vue +168 -184
  201. package/components/common/vm/actions/common/select/computeResource/treeView/Old.vue +1 -1
  202. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +131 -131
  203. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  204. package/components/common/vm/actions/common/select/createType/New.vue +0 -16
  205. package/components/common/vm/actions/common/select/createType/Old.vue +0 -9
  206. package/components/common/vm/actions/common/select/createType/lib/config/items.ts +48 -48
  207. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  208. package/components/common/vm/actions/common/select/name/Name.vue +13 -7
  209. package/components/common/vm/actions/common/select/name/New.vue +15 -30
  210. package/components/common/vm/actions/common/select/name/Old.vue +11 -8
  211. package/components/common/vm/actions/common/select/options/New.vue +8 -3
  212. package/components/common/vm/actions/common/select/options/Old.vue +10 -5
  213. package/components/common/vm/actions/common/select/options/Options.vue +8 -3
  214. package/components/common/vm/actions/common/select/os/New.vue +0 -10
  215. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  216. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  217. package/components/common/vm/actions/common/select/storage/Old.vue +13 -10
  218. package/components/common/vm/actions/common/select/storage/Storage.vue +164 -155
  219. package/components/common/vm/actions/common/select/storage/new/New.vue +278 -300
  220. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  221. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  222. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  223. package/components/common/vm/actions/common/select/template/treeView/New.vue +0 -10
  224. package/components/common/vm/actions/common/select/template/treeView/Old.vue +1 -1
  225. package/components/common/vm/actions/confirm/Confirm.vue +11 -6
  226. package/components/common/vm/actions/editSettings/EditSettings.vue +252 -242
  227. package/components/common/vm/actions/editSettings/EditSettingsOld.vue +35 -24
  228. package/components/common/vm/actions/editSettings/new/New.vue +34 -23
  229. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  230. package/components/common/vmt/actions/add/Add.vue +25 -19
  231. package/components/common/vmt/actions/add/New.vue +1 -0
  232. package/components/common/vmt/actions/add/Old.vue +0 -10
  233. package/components/common/vmt/actions/add/lib/models/interfaces.ts +23 -23
  234. package/components/common/wizards/datastore/add/Add.vue +14 -7
  235. package/components/common/wizards/datastore/add/New.vue +24 -17
  236. package/components/common/wizards/datastore/add/Old.vue +18 -14
  237. package/components/common/wizards/datastore/add/lib/config/steps.ts +2 -1
  238. package/components/common/wizards/datastore/add/lib/models/enums.ts +1 -1
  239. package/components/common/wizards/datastore/add/steps/hostAccessibility/HostAccessibility.vue +9 -4
  240. package/components/common/wizards/datastore/add/steps/hostAccessibility/HostAccessibilityNew.vue +10 -5
  241. package/components/common/wizards/datastore/add/steps/hostAccessibility/HostAccessibilityOld.vue +12 -7
  242. package/components/common/wizards/datastore/add/steps/hostAccessibility/table/Table.vue +0 -2
  243. package/components/common/wizards/datastore/add/steps/hostAccessibility/table/new/New.vue +3 -3
  244. package/components/common/wizards/datastore/add/steps/hostAccessibility/table/old/Old.vue +5 -5
  245. package/components/common/wizards/datastore/add/steps/hostAccessibility/table/old/lib/config/incompatibleTable.ts +3 -3
  246. package/components/common/wizards/datastore/add/steps/nameAndConfigure/NameAndConfigure.vue +0 -2
  247. package/components/common/wizards/datastore/add/steps/nameAndConfigure/NameAndConfigureNew.vue +27 -26
  248. package/components/common/wizards/datastore/add/steps/nameAndConfigure/NameAndConfigureOld.vue +5 -11
  249. package/components/common/wizards/datastore/add/steps/nameAndConfigure/_serversList/DeletePopover.vue +0 -9
  250. package/components/common/wizards/datastore/add/steps/nameAndConfigure/_serversList/ServersList.vue +9 -4
  251. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDevice.vue +18 -14
  252. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceNew.vue +20 -15
  253. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceOld.vue +26 -17
  254. package/components/common/wizards/datastore/add/steps/nameAndDevice/table/Table.vue +12 -17
  255. package/components/common/wizards/datastore/add/steps/nameAndDevice/table/new/New.vue +2 -13
  256. package/components/common/wizards/datastore/add/steps/nameAndDevice/table/new/lib/config/lunDiskTable.ts +14 -14
  257. package/components/common/wizards/datastore/add/steps/nameAndDevice/table/new/lib/models/enums.ts +3 -3
  258. package/components/common/wizards/datastore/add/steps/nameAndDevice/table/old/Old.vue +18 -13
  259. package/components/common/wizards/datastore/add/steps/readyComplete/ReadyCompleteNew.vue +1 -1
  260. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  261. package/components/common/wizards/network/add/Add.vue +2 -2
  262. package/components/common/wizards/network/add/lib/models/interfaces.ts +2 -2
  263. package/components/common/wizards/network/add/modals/SelectNetwork.vue +7 -5
  264. package/components/common/wizards/network/add/modals/SelectStandardSwitch.vue +7 -15
  265. package/components/common/wizards/network/add/modals/SelectSwitch.vue +7 -15
  266. package/components/common/wizards/network/add/modals/lib/models/interfaces.ts +21 -0
  267. package/components/common/wizards/network/add/steps/ConnectionSettings.vue +3 -3
  268. package/components/common/wizards/network/add/steps/CreateStandardSwitch.vue +3 -3
  269. package/components/common/wizards/network/add/steps/IpFourSettings.vue +6 -6
  270. package/components/common/wizards/network/add/steps/PhysicalAdapter.vue +2 -2
  271. package/components/common/wizards/network/add/steps/PortProperties.vue +12 -12
  272. package/components/common/wizards/network/add/steps/SelectConnectionType.vue +112 -104
  273. package/components/common/wizards/network/add/steps/SelectedTargetDevice.vue +467 -467
  274. package/components/common/wizards/vm/common/computeResource/TreeView.vue +1 -1
  275. package/components/common/wizards/vm/common/validation/compatibility/Compatibility.vue +1 -1
  276. package/components/common/wizards/vm/migrate/Migrate.vue +353 -349
  277. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +221 -220
  278. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  279. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  280. package/components/common/wizards/vm/migrate/select/computeResource/ComputeResource.vue +13 -8
  281. package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/config/tableKeys.ts +8 -8
  282. package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/models/types.ts +4 -4
  283. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  284. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  285. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/basicTable.ts +1 -1
  286. package/components/common/wizards/vm/migrate/select/targetServer/new/New.vue +4 -7
  287. package/components/common/wizards/vm/migrate/select/type/lib/config/typeOptions.ts +45 -45
  288. package/composables/productNameLocal.ts +30 -30
  289. package/composables/useAppVersion.ts +21 -21
  290. package/lib/models/enums.ts +1 -1
  291. package/package.json +1 -1
  292. package/plugins/date.ts +233 -233
  293. package/plugins/panelStates.ts +70 -70
  294. package/plugins/text.ts +59 -59
  295. package/public/spice-console/lib/images/bitmap.js +203 -203
  296. package/public/spice-console/network/spicechannel.js +390 -390
  297. package/store/main/mutations.ts +7 -7
  298. package/store/main/state.ts +7 -7
  299. package/store/tasks/lib/models/enums.ts +4 -4
  300. package/store/tasks/mappers/recentTasks.ts +79 -79
@@ -1,823 +1,823 @@
1
- <template>
2
- <div class="clone-vm">
3
- <atoms-wizard
4
- show
5
- :wizard="wizard"
6
- :selected-scheme="selectedScheme"
7
- :title="title"
8
- :localization="localization"
9
- @change-steps="onChangeSteps"
10
- @hide="onHideModal"
11
- @submit="onFinish"
12
- >
13
- <template #modalBody="{ selectedStep }">
14
- <atoms-loader v-show="!vmSettings || isLoading" id="loader" />
15
- <div v-if="vmSettings" class="vm-context">
16
- <common-pages-scheduled-tasks-modals-common-new-task-form
17
- v-show="selectedStep.id === dynamicSteps.scheduledTasks"
18
- v-model="newTaskForm"
19
- :target="selectedVirtualMachine"
20
- class="new-task-form"
21
- />
22
- <common-vm-actions-common-select-name
23
- v-show="
24
- selectedStep.id === dynamicSteps.selectName ||
25
- selectedStep.id === dynamicSteps.selectNameFolder
26
- "
27
- :show="
28
- selectedStep.id === dynamicSteps.selectName ||
29
- selectedStep.id === dynamicSteps.selectNameFolder
30
- "
31
- :name-form-submit="nameFormSubmit"
32
- :project="props.project"
33
- :data-center="props.dataCenter"
34
- @submit="onChangeName(...$event)"
35
- @check-name="emits('check-name', $event)"
36
- />
37
- <common-vm-actions-common-select-compute-resource
38
- v-if="isSphere"
39
- v-show="selectedStep.id === dynamicSteps.selectComputeResource"
40
- v-model="computeResource"
41
- :compute-resource-submit="computeResourceSubmit"
42
- :data-center="vmForm.dataCenter"
43
- :compute-resource="props.computeResource"
44
- :compute-resource-tree="props.computeResourceTree"
45
- @submit="onChangeComputeResource"
46
- @select-compute-resource-tree="onSelectComputeResourceTree"
47
- @get-compute-resource-tree="
48
- emits('get-compute-resource-tree', $event)
49
- "
50
- @show-compute-resource-tree="
51
- emits('show-compute-resource-tree', $event)
52
- "
53
- @clear-compute-resource-tree="emits('clear-compute-resource-tree')"
54
- />
55
- <common-vm-actions-common-select-storage
56
- v-show="selectedStep.id === dynamicSteps.selectStorage"
57
- :storage-submit="storageSubmit"
58
- :datastore="props.datastore"
59
- :is-datastore-loading="props.isDatastoreLoading"
60
- :storage="vmForm.storage"
61
- :get-datastore-table-func="props.getDatastoreTableFunc"
62
- @submit="onChangeStorage"
63
- />
64
- <common-vm-actions-common-select-options
65
- v-show="selectedStep.id === dynamicSteps.selectOptions"
66
- :is-create-template="props.isNewVmFromTemplate"
67
- @change="onChangeSelectOptions"
68
- />
69
- <common-vm-actions-common-select-os
70
- v-show="selectedStep.id === dynamicSteps.selectGuestOSMachineType"
71
- v-model:machine-type="vmForm.guestMachineType"
72
- v-model:guest-os-family="vmForm.guestOsFamily"
73
- v-model:guest-os-version="vmForm.guestOsVersion"
74
- :families-options="guestOsFamilies"
75
- :versions-options="guestOsVersions"
76
- :machine-types-options="machineTypes"
77
- :error-validation-fields="props.errorValidationFields"
78
- @remove-error-by-title="emits('remove-error-by-title', $event)"
79
- />
80
- <common-vm-actions-common-customize-hardware
81
- v-show="selectedStep.id === dynamicSteps.customizeHardware"
82
- v-model:vm-name="vmName"
83
- v-model:guest-machine-type="vmSettings.guestMachineType"
84
- v-model:guest-os-family="vmSettings.guestOsFamily"
85
- v-model:guest-os-version="vmSettings.guestOsVersion"
86
- :storage="vmForm.storage"
87
- :hard-disks-for-boot-options="virtualHardwareHardDisksLocal"
88
- :cd-dvd-drives-for-boot-options="virtualHardwareCdDvdDrivesLocal"
89
- :networks-for-boot-options="virtualHardwareNetworksLocal"
90
- :cd-dvd-drives="vmSettings.cdDvdDrives"
91
- :hard-disks="vmSettings.hardDisks"
92
- :networks="vmSettings.networks"
93
- :customize-hardware-submit="customizeHardwareSubmit"
94
- :max-cpus="vmSettings.maxCpus"
95
- :max-memory="vmSettings.maxMemory"
96
- :cpu-models="vmSettings.cpuModels"
97
- :cpu="vmSettings.cpu"
98
- :memory="vmSettings.memory"
99
- :video-card="vmSettings.videoCard"
100
- :usb-controller="vmSettings.usbController"
101
- :pci-devices="vmSettings.pciDevices"
102
- :selected-nav-item="selectedNavItem"
103
- :hard-disks-for-edit="vmSettings.hardDisks"
104
- :options="vmSettings.options"
105
- :nodes="props.nodes"
106
- :files="props.files"
107
- :networks-table="props.networksTable"
108
- :error-validation-fields="props.errorValidationFields"
109
- :vm-cpu-help-text-second="props.vmCpuHelpTextSecond"
110
- :passthrough-devices="props.passthroughDevices"
111
- :mediated-devices="props.mediatedDevices"
112
- :get-datastore-table-func="props.getDatastoreTableFunc"
113
- :datastore="props.datastore"
114
- :is-datastore-loading="props.isDatastoreLoading"
115
- :project="props.project"
116
- is-clone
117
- @change-boot-order="onChangeBootOrder"
118
- @send-data="onChangeCustomizeHardware"
119
- @get-storage="emits('get-storage', $event)"
120
- @get-folders-or-files="emits('get-folders-or-files', $event)"
121
- @get-active-device-child="emits('get-active-device-child', $event)"
122
- @show-datastore-child="emits('show-datastore-child', $event)"
123
- @get-networks-table="emits('get-networks-table', $event)"
124
- @get-pci-devices="emits('get-pci-devices')"
125
- />
126
- <common-ready-to-complete
127
- v-show="selectedStep.id === dynamicSteps.readyComplete"
128
- :data="props.readyCompleteTableInfo"
129
- />
130
- </div>
131
- </template>
132
- </atoms-wizard>
133
- </div>
134
- </template>
135
-
136
- <script setup lang="ts">
137
- import type {
138
- UI_I_DatastoreTableItem,
139
- UI_I_FolderOrFileTreePayload,
140
- } from '~/lib/models/store/storage/interfaces'
141
- import type { UI_I_NetworkTableItem } from '~/lib/models/store/network/interfaces'
142
- import type { API_UI_I_Error } from '~/lib/models/store/interfaces'
143
- import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
144
- import type { UI_I_FileTreeNode } from '~/components/lib/models/interfaces'
145
- import type {
146
- UI_I_ArbitraryObject,
147
- UI_I_Localization,
148
- } from '~/lib/models/interfaces'
149
- import type { UI_I_SendDataCustomizeHardware } from '~/components/common/vm/actions/common/customizeHardware/lib/models/interfaces'
150
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
151
- import type {
152
- UI_I_SendDataCpu,
153
- UI_I_SendDataMemory,
154
- UI_I_SendDataNewCdDvdDrive,
155
- UI_I_SendDataNewHardDisk,
156
- UI_I_SendDataNewNetwork,
157
- } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
158
- import type { UI_T_SelectedNavItem } from '~/components/common/vm/actions/common/lib/models/types'
159
- import type { UI_I_TableInfoItem } from '~/components/atoms/table/info/lib/models/interfaces'
160
- import type { UI_T_ChangeBootOrder } from '~/components/common/vm/actions/lib/models/types'
161
- import type { UI_T_Project } from '~/lib/models/types'
162
- import type {
163
- UI_I_MediatedDevice,
164
- UI_I_PciDevice,
165
- UI_I_VmSettings,
166
- } from '~/lib/models/store/vm/interfaces'
167
- import type { UI_I_VmForm } from '~/components/common/vm/actions/common/lib/models/interfaces'
168
- import type {
169
- UI_I_ValidationReturn,
170
- UI_I_WizardStep,
171
- } from '~/components/atoms/wizard/lib/models/interfaces'
172
- import type { UI_I_Capabilities } from '~/components/common/vm/actions/common/lib/models/interfaces'
173
- import type { UI_I_ScheduleNewTasksForm } from '~/components/common/pages/scheduledTasks/modals/lib/models/interfaces'
174
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
175
- import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
176
- import {
177
- stepsSchemeInitial,
178
- stepsFunc,
179
- dynamicSteps,
180
- } from '~/components/common/vm/actions/clone/lib/config/steps'
181
- import Wizard from '~/components/atoms/wizard/lib/utils/utils'
182
- import { mapCapabilities } from '~/components/common/vm/actions/common/lib/utils/capabilities'
183
- import { scheduledTaskDefaultFormFunc } from '~/components/common/pages/scheduledTasks/modals/lib/config/createScheduledTask'
184
- import { capabilities } from '~/components/common/vm/actions/common/lib/config/capabilities'
185
-
186
- const props = defineProps<{
187
- project: UI_T_Project
188
- vmSettings: UI_I_VmSettings | null
189
- nodes: UI_I_FileTreeNode[]
190
- files: UI_I_FileTreeNode[]
191
- networksTable: UI_I_NetworkTableItem[]
192
- datastore: UI_I_DatastoreTableItem[]
193
- isDatastoreLoading: boolean
194
- errorValidationFields: UI_I_ErrorValidationField[]
195
- readyCompleteTableInfo: UI_I_TableInfoItem[]
196
- vmCpuHelpTextSecond: string
197
- finishFunc: any
198
- getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
199
- validateSendDataFunc: any
200
- passthroughDevices: UI_I_PciDevice[]
201
- mediatedDevices: UI_I_MediatedDevice[]
202
- vmNameInWizard: string
203
- capabilities?: UI_I_Capabilities
204
- schedulerTask?: any // TODO надо interface переместить глобално
205
- selectedVirtualMachine?: UI_I_Capabilities
206
- isNewVmFromTemplate?: boolean
207
- dataCenter?: UI_I_TreeNode // для сферы
208
- computeResource?: UI_I_TreeNode // для сферы
209
- computeResourceTree?: UI_I_TreeNode[] // для сферы
210
- }>()
211
-
212
- const emits = defineEmits<{
213
- (event: 'check-name', value: [string, (error: API_UI_I_Error) => void]): void
214
- (event: 'get-storage', value: UI_I_TablePayload): void
215
- (event: 'get-folders-or-files', value: UI_I_FolderOrFileTreePayload): void
216
- (event: 'get-active-device-child', value: UI_I_FileTreeNode): void
217
- (event: 'show-datastore-child', value: UI_I_FileTreeNode): void
218
- (event: 'remove-error-by-title', value: string): void
219
- (event: 'get-networks-table', value: UI_I_TablePayload): void
220
- (event: 'get-pci-devices'): void
221
- (event: 'hide'): void
222
- (
223
- event: 'get-compute-resource-tree',
224
- value: { id: string | number; cb: () => void }
225
- ): void // для сферы
226
- (event: 'show-compute-resource-tree', value: UI_I_TreeNode): void // для сферы
227
- (event: 'select-compute-resource-tree', value: UI_I_TreeNode): void // для сферы
228
- (event: 'clear-compute-resource-tree'): void // для сферы
229
- }>()
230
-
231
- const { $recursion } = useNuxtApp()
232
-
233
- const localization = computed<UI_I_Localization>(() => useLocal())
234
-
235
- const isSphere = computed<boolean>(() => props.project === 'sphere')
236
-
237
- const isScheduledTasks = computed<boolean>(
238
- () => props.schedulerTask?.isSchedulerTask
239
- )
240
-
241
- const title = computed<string>(() => {
242
- const { scheduleNewTasks, scheduleTaskEdit, cloneExistingVirtualMachine } =
243
- localization.value.common
244
-
245
- let result = cloneExistingVirtualMachine
246
- if (isScheduledTasks.value) {
247
- const schedulerMode = props.schedulerTask.editTask
248
- ? scheduleTaskEdit
249
- : scheduleNewTasks
250
-
251
- result = `${schedulerMode} (${cloneExistingVirtualMachine})`
252
- }
253
-
254
- if (props.isNewVmFromTemplate) {
255
- result = localization.value.vmWizard.deployFromTemplate
256
- }
257
-
258
- return result
259
- })
260
-
261
- watch(
262
- () => props.capabilities,
263
- () => {
264
- if (props.capabilities) {
265
- mapCapabilities(props.capabilities)
266
- }
267
- },
268
- { deep: true, immediate: true }
269
- )
270
-
271
- const wizard: Wizard = new Wizard(
272
- stepsFunc(localization.value),
273
- stepsSchemeInitial
274
- )
275
- watch(
276
- isScheduledTasks,
277
- (newValue) => {
278
- if (newValue) {
279
- wizard.changeScheme(isSphere.value ? 12 : 4)
280
- } else {
281
- wizard.changeScheme(isSphere.value ? 8 : 0)
282
- wizard.selectStepHard(isSphere.value ? 2 : 1)
283
- }
284
- },
285
- { immediate: true }
286
- )
287
-
288
- // TODO move to common
289
- const newTaskForm = ref<UI_I_ScheduleNewTasksForm>(
290
- useDeepCopy(scheduledTaskDefaultFormFunc())
291
- )
292
- watch(
293
- newTaskForm,
294
- (newValue: UI_I_ScheduleNewTasksForm) => {
295
- if (isScheduledTasks.value) wizard.setDisabledNextButton(newValue.isValid)
296
- },
297
- { immediate: true, deep: true }
298
- )
299
-
300
- const selectedScheme = computed<number[]>(() => wizard.selectedScheme.value)
301
-
302
- const onChangeSteps = async (value: UI_I_WizardStep[]): Promise<void> => {
303
- wizard.changeSteps(value, validationFunc, validateSendData)
304
- }
305
-
306
- const validationFunc = async (
307
- value: UI_I_WizardStep[],
308
- currentStep: UI_I_WizardStep,
309
- nextStep: UI_I_WizardStep
310
- ): Promise<UI_I_ValidationReturn> => {
311
- let stepHasError = false
312
- let stepShouldStop = {
313
- ifOnCurrentStep: false,
314
- ifFromAnyStep: false,
315
- stoppageStepId: -1,
316
- }
317
-
318
- wizard.setLoader(true)
319
- if (
320
- wizard.isValidateForStep(
321
- isSphere.value ? dynamicSteps.selectNameFolder : dynamicSteps.selectName,
322
- currentStep.id,
323
- nextStep.id
324
- )
325
- ) {
326
- const nameValidation = await checkName(value)
327
-
328
- value = nameValidation.newValue
329
- stepHasError = stepHasError || nameValidation.stepHasError
330
- } else if (
331
- isSphere.value &&
332
- wizard.isValidateForStep(
333
- dynamicSteps.selectComputeResource,
334
- currentStep.id,
335
- nextStep.id
336
- )
337
- ) {
338
- const computeResourceValidation = await checkComputeResource(value)
339
-
340
- value = computeResourceValidation.newValue
341
- stepHasError = stepHasError || computeResourceValidation.stepHasError
342
- } else if (
343
- wizard.isValidateForStep(
344
- dynamicSteps.selectStorage,
345
- currentStep.id,
346
- nextStep.id
347
- )
348
- ) {
349
- const storageValidation = await checkStorage(value)
350
-
351
- value = storageValidation.newValue
352
-
353
- stepHasError = stepHasError || storageValidation.stepHasError
354
- } else if (
355
- wizard.isValidateForStep(
356
- dynamicSteps.customizeHardware,
357
- currentStep.id,
358
- nextStep.id
359
- )
360
- ) {
361
- const customizeHardwareValidation = await checkCustomizeHardware(value)
362
-
363
- value = customizeHardwareValidation.newValue
364
-
365
- stepHasError = stepHasError || customizeHardwareValidation.stepHasError
366
- }
367
- wizard.setLoader(false)
368
-
369
- return {
370
- newValue: value,
371
- stepHasError,
372
- stepShouldStop,
373
- }
374
- }
375
- const checkName = async (
376
- value: UI_I_WizardStep[]
377
- ): Promise<UI_I_ValidationReturn> => {
378
- let stepHasError = false
379
-
380
- return new Promise((resolve) => {
381
- const step = isSphere.value
382
- ? dynamicSteps.selectNameFolder
383
- : dynamicSteps.selectName
384
- nameFormSubmit.value = (isValid: boolean) => {
385
- if (!isValid) {
386
- stepHasError = wizard.setValidation(step, 'name', {
387
- fieldMessage: 'aaa',
388
- alertMessage: 'aaa',
389
- })
390
- } else if (wizard.hasMessage(step, 'name')) {
391
- value = wizard.removeValidation(step, 'name', value)
392
- }
393
-
394
- resolve({
395
- stepHasError,
396
- newValue: value,
397
- })
398
- nameFormSubmit.value = null
399
- }
400
- })
401
- }
402
- const checkComputeResource = async (
403
- value: UI_I_WizardStep[]
404
- ): Promise<UI_I_ValidationReturn> => {
405
- let stepHasError = false
406
-
407
- return new Promise((resolve) => {
408
- computeResourceSubmit.value = (isValid: boolean) => {
409
- if (!isValid) {
410
- stepHasError = wizard.setValidation(
411
- dynamicSteps.selectComputeResource,
412
- 'computeResource',
413
- {
414
- fieldMessage: 'aaa',
415
- alertMessage: 'aaa',
416
- }
417
- )
418
- } else if (
419
- wizard.hasMessage(dynamicSteps.selectComputeResource, 'computeResource')
420
- ) {
421
- value = wizard.removeValidation(
422
- dynamicSteps.selectComputeResource,
423
- 'computeResource',
424
- value
425
- )
426
- }
427
-
428
- resolve({
429
- stepHasError,
430
- newValue: value,
431
- })
432
- computeResourceSubmit.value = null
433
- }
434
- })
435
- }
436
- const checkStorage = async (
437
- value: UI_I_WizardStep[]
438
- ): Promise<UI_I_ValidationReturn> => {
439
- let stepHasError = false
440
-
441
- return new Promise((resolve) => {
442
- storageSubmit.value = (isValid: boolean) => {
443
- if (!isValid) {
444
- stepHasError = wizard.setValidation(
445
- dynamicSteps.selectStorage,
446
- 'storage',
447
- {
448
- fieldMessage: 'aaa',
449
- alertMessage: 'aaa',
450
- }
451
- )
452
- } else if (wizard.hasMessage(dynamicSteps.selectStorage, 'storage')) {
453
- value = wizard.removeValidation(
454
- dynamicSteps.selectStorage,
455
- 'storage',
456
- value
457
- )
458
- }
459
-
460
- resolve({
461
- stepHasError,
462
- newValue: value,
463
- })
464
- storageSubmit.value = null
465
- }
466
- })
467
- }
468
- const checkCustomizeHardware = async (
469
- value: UI_I_WizardStep[]
470
- ): Promise<UI_I_ValidationReturn> => {
471
- let stepHasError = false
472
-
473
- return new Promise((resolve) => {
474
- customizeHardwareSubmit.value = (isValid: boolean) => {
475
- if (!isValid) {
476
- stepHasError = wizard.setValidation(
477
- dynamicSteps.customizeHardware,
478
- 'customizeHardware',
479
- {
480
- fieldMessage: 'aaa',
481
- alertMessage: 'aaa',
482
- }
483
- )
484
- } else if (
485
- wizard.hasMessage(dynamicSteps.customizeHardware, 'customizeHardware')
486
- ) {
487
- value = wizard.removeValidation(
488
- dynamicSteps.customizeHardware,
489
- 'customizeHardware',
490
- value
491
- )
492
- }
493
-
494
- resolve({
495
- stepHasError,
496
- newValue: value,
497
- })
498
- storageSubmit.value = null
499
- }
500
- })
501
- }
502
-
503
- const vmForm = ref<UI_I_VmForm>({
504
- name: '',
505
- compatibility: '',
506
- guestMachineType: null,
507
- guestOsFamily: null,
508
- guestOsVersion: null,
509
- computeResource: null,
510
- storage: null,
511
- locationPath: '',
512
- dataCenter: null,
513
- options: [],
514
- })
515
- const onChangeName = (name: string, node: UI_I_TreeNode): void => {
516
- vmForm.value.name = name
517
- if (isSphere.value) {
518
- vmForm.value.locationPath = node.id
519
- vmForm.value.dataCenter = $recursion.findParentByValue(
520
- node,
521
- 'datacenter',
522
- 'type',
523
- 'parent'
524
- )
525
- }
526
- }
527
- const onChangeStorage = (storage: UI_I_DatastoreTableItem | null): void => {
528
- if (!storage) return
529
-
530
- vmForm.value.storage = storage
531
- }
532
- const onChangeSelectOptions = (options: string[]): void => {
533
- vmForm.value.options = options
534
- if (
535
- options.includes('customize-os') &&
536
- options.includes('customize-hardware')
537
- ) {
538
- let procuratorSchame = isScheduledTasks.value ? 7 : 3
539
- let sphereSchame = isScheduledTasks.value ? 15 : 11
540
- wizard.changeScheme(isSphere.value ? sphereSchame : procuratorSchame)
541
- } else if (options.includes('customize-os')) {
542
- let procuratorSchame = isScheduledTasks.value ? 5 : 1
543
- let sphereSchame = isScheduledTasks.value ? 13 : 9
544
- wizard.changeScheme(isSphere.value ? sphereSchame : procuratorSchame)
545
- } else if (options.includes('customize-hardware')) {
546
- let procuratorSchame = isScheduledTasks.value ? 6 : 2
547
- let sphereSchame = isScheduledTasks.value ? 14 : 10
548
- wizard.changeScheme(isSphere.value ? sphereSchame : procuratorSchame)
549
- } else {
550
- let procuratorSchame = isScheduledTasks.value ? 4 : 0
551
- let sphereSchame = isScheduledTasks.value ? 12 : 8
552
- wizard.changeScheme(isSphere.value ? sphereSchame : procuratorSchame)
553
- }
554
-
555
- // Change power on by default
556
- isPowerOnByDefault.value = options.includes('power-on')
557
- }
558
- const customizeHardware = ref<UI_I_SendDataCustomizeHardware | null>(null)
559
- const onChangeCustomizeHardware = (
560
- data: UI_I_SendDataCustomizeHardware
561
- ): void => {
562
- customizeHardware.value = data
563
- }
564
-
565
- const virtualHardwareHardDisksLocal = computed<
566
- UI_I_SendDataNewHardDisk[] | null
567
- >(() => customizeHardware.value?.virtualHardware?.hardDisks || null)
568
- const virtualHardwareNetworksLocal = computed<UI_I_SendDataNewNetwork[] | null>(
569
- () => customizeHardware.value?.virtualHardware?.networks || null
570
- )
571
- const virtualHardwareCdDvdDrivesLocal = computed<
572
- UI_I_SendDataNewCdDvdDrive[] | null
573
- >(() => customizeHardware.value?.virtualHardware?.cdDvdDrives || null)
574
-
575
- const virtualHardwareCpu = computed<UI_I_SendDataCpu | null>(
576
- () => customizeHardware.value?.virtualHardware?.cpu || null
577
- )
578
- const virtualHardwareMemory = computed<UI_I_SendDataMemory | null>(
579
- () => customizeHardware.value?.virtualHardware?.memory || null
580
- )
581
- const virtualHardwareHardDisks = ref<UI_I_SendDataNewHardDisk[] | null>(null)
582
- const virtualHardwareCdDvdDrives = ref<UI_I_SendDataNewCdDvdDrive[] | null>(
583
- null
584
- )
585
- const virtualHardwareNetworks = ref<UI_I_SendDataNewNetwork[] | null>(null)
586
- const onChangeBootOrder = (data: UI_T_ChangeBootOrder): void => {
587
- virtualHardwareHardDisks.value = data[0]
588
- virtualHardwareCdDvdDrives.value = data[1]
589
- virtualHardwareNetworks.value = data[2]
590
- }
591
-
592
- const isPowerOnByDefault = ref<boolean>(false)
593
-
594
- watch(
595
- () => props.vmNameInWizard,
596
- (newValue) => {
597
- vmForm.value.name = newValue
598
- }
599
- )
600
-
601
- const validateSendData = async (
602
- value: UI_I_WizardStep[]
603
- ): Promise<UI_I_ValidationReturn> => {
604
- wizard.setLoader(true)
605
- let stepHasError = false
606
-
607
- const data = await props.validateSendDataFunc(
608
- vmForm.value,
609
- virtualHardwareCpu.value,
610
- virtualHardwareMemory.value,
611
- customizeHardware.value,
612
- virtualHardwareNetworks.value,
613
- virtualHardwareHardDisks.value,
614
- virtualHardwareCdDvdDrives.value,
615
- isPowerOnByDefault.value,
616
- localization.value,
617
- vmForm.value.locationPath, // для сферы
618
- // computeResourcePath.value // для сферы
619
- vmSettings.value.host_id // для сферы // TODO rollback
620
- )
621
-
622
- wizard.setLoader(false)
623
- if (data) {
624
- stepHasError = true
625
- selectedNavItem.value = data[0]
626
- }
627
-
628
- return {
629
- stepHasError,
630
- newValue: value,
631
- }
632
- }
633
-
634
- const isLoading = ref<boolean>(false)
635
- const onFinish = (): void => {
636
- isLoading.value = true
637
- wizard.setLoader(false)
638
- props
639
- .finishFunc(
640
- vmForm.value,
641
- virtualHardwareCpu.value,
642
- virtualHardwareMemory.value,
643
- customizeHardware.value,
644
- virtualHardwareNetworks.value,
645
- virtualHardwareHardDisks.value,
646
- virtualHardwareCdDvdDrives.value,
647
- isPowerOnByDefault.value,
648
- localization.value,
649
- vmForm.value.locationPath, // для сферы
650
- // computeResourcePath.value, // для сферы
651
- vmSettings.value.host_id, // для сферы // TODO rollback
652
- false,
653
- newTaskForm.value,
654
- props.schedulerTask
655
- )
656
- .then(() => {
657
- isLoading.value = false
658
- onHideModal()
659
- wizard.setLoader(false)
660
- })
661
- }
662
-
663
- const selectedNavItem = ref<UI_T_SelectedNavItem>(0)
664
-
665
- const nameFormSubmit = ref<null | Function>(null)
666
- const computeResourceSubmit = ref<null | Function>(null)
667
- const storageSubmit = ref<null | Function>(null)
668
- const customizeHardwareSubmit = ref<null | Function>(null)
669
-
670
- const vmSettings = computed<UI_I_VmSettings | null>(() => props.vmSettings)
671
- const vmName = ref<string>(vmSettings.value?.name || '')
672
-
673
- const guestOsFamilies = ref<UI_I_OptionItem[]>(
674
- capabilities.value.guestOsFamilies
675
- )
676
- const guestOsVersions = ref<UI_I_ArbitraryObject<UI_I_OptionItem[]>>(
677
- capabilities.value.guestOsVersions
678
- )
679
- const machineTypes = ref<UI_I_OptionItem[]>(capabilities.value.machineTypes)
680
-
681
- const computeResource = ref<UI_I_TreeNode | null>(null)
682
- const onChangeComputeResource = (node: UI_I_TreeNode): void => {
683
- computeResource.value = node
684
- }
685
- // // Для сферы
686
- const computeResourcePath = ref<string>('')
687
- const onSelectComputeResourceTree = (node: UI_I_TreeNode): void => {
688
- emits('select-compute-resource-tree', node)
689
- computeResourcePath.value = node.id
690
- }
691
-
692
- watch(vmSettings, (newValue) => {
693
- vmName.value = newValue?.name || ''
694
-
695
- if (newValue?.guestOsFamily)
696
- vmForm.value.guestOsFamily = newValue.guestOsFamily
697
- if (newValue?.guestMachineType)
698
- vmForm.value.guestMachineType = newValue.guestMachineType
699
- if (newValue?.guestOsVersion)
700
- vmForm.value.guestOsVersion = newValue.guestOsVersion
701
-
702
- if (newValue?.compatibility)
703
- vmForm.value.compatibility = newValue.compatibility
704
-
705
- if (newValue?.storage) {
706
- const datastore = props.datastore.find(
707
- (item) => item.id === newValue.storage.id
708
- )
709
- if (datastore) vmForm.value.storage = datastore
710
- }
711
- })
712
-
713
- const onHideModal = (): void => {
714
- emits('hide')
715
- }
716
- </script>
717
-
718
- <style scoped lang="scss">
719
- :deep(.has-solid.close-icon.clr-icon) {
720
- width: 20px;
721
- top: 0;
722
- }
723
- .vm-context {
724
- padding: 16px 15px 10px 10px;
725
- height: 100%;
726
- display: flex;
727
- flex-direction: column;
728
-
729
- .context-title-wrap {
730
- padding-bottom: 3px;
731
- border-bottom: 1px solid #a6a6a6;
732
-
733
- h4 {
734
- font-weight: 700;
735
- font-size: 13px;
736
- color: var(--vm-context-title);
737
- }
738
- p {
739
- font-weight: 400;
740
- font-size: 13px;
741
- color: var(--vm-context-sub-title);
742
- }
743
- }
744
-
745
- .finish-block {
746
- padding: 18px 24px 24px 24px;
747
-
748
- .add-hosts-ready-to-complete-mt-12 {
749
- margin-top: 12px;
750
-
751
- .add-hosts-ready-to-complete-bold {
752
- line-height: 18px;
753
- font-weight: 700;
754
- }
755
- }
756
- }
757
-
758
- .vm-hardware-version {
759
- align-self: flex-end;
760
- margin-top: auto;
761
- }
762
- }
763
-
764
- :deep(.modal .modal-dialog .modal-content .modal-footer) {
765
- flex: unset;
766
- height: unset;
767
- min-height: unset;
768
- }
769
- :deep(.wizard-modal-titlebar h3) {
770
- color: #000;
771
- font-size: 24px;
772
- font-weight: 200;
773
- line-height: 27px;
774
- margin: 0;
775
- padding: 0;
776
- }
777
- :deep(.clr-wizard-stepnav-item) {
778
- padding-left: 0;
779
- }
780
- :deep(.clr-wizard-stepnav
781
- .clr-wizard-stepnav-item
782
- button
783
- .clr-wizard-stepnav-link-title) {
784
- width: 189px;
785
- font-weight: 700;
786
- font-size: 13px;
787
- }
788
-
789
- #vm-wizard-notification {
790
- h3 {
791
- color: var(--global-font-color7);
792
- margin-top: 6px;
793
- }
794
- p {
795
- color: var(--global-font-color6);
796
- line-height: 16px;
797
- }
798
- }
799
-
800
- .power-on-by-default-wrap {
801
- display: flex;
802
- align-items: center;
803
-
804
- input {
805
- margin-right: 6px;
806
- }
807
- }
808
-
809
- .new-task-form {
810
- padding: 0 25px 0 5px;
811
- }
812
- </style>
813
-
814
- <style>
815
- :root {
816
- --vm-context-title: #333;
817
- --vm-context-sub-title: #000;
818
- }
819
- :root.dark-theme {
820
- --vm-context-title: #adbbc4;
821
- --vm-context-sub-title: #adbbc4;
822
- }
823
- </style>
1
+ <template>
2
+ <div class="clone-vm">
3
+ <atoms-wizard
4
+ :wizard="wizard"
5
+ :selected-scheme="selectedScheme"
6
+ :title="title"
7
+ :localization="localization"
8
+ show
9
+ @change-steps="onChangeSteps"
10
+ @hide="onHideModal"
11
+ @submit="onFinish"
12
+ >
13
+ <template #modalBody="{ selectedStep }">
14
+ <atoms-loader v-show="!vmSettings || isLoading" id="loader" />
15
+ <div v-if="vmSettings" class="vm-context">
16
+ <common-pages-scheduled-tasks-modals-common-new-task-form
17
+ v-show="selectedStep.id === dynamicSteps.scheduledTasks"
18
+ v-model="newTaskForm"
19
+ :target="selectedVirtualMachine"
20
+ class="new-task-form"
21
+ />
22
+ <common-vm-actions-common-select-name
23
+ v-show="
24
+ selectedStep.id === dynamicSteps.selectName ||
25
+ selectedStep.id === dynamicSteps.selectNameFolder
26
+ "
27
+ :show="
28
+ selectedStep.id === dynamicSteps.selectName ||
29
+ selectedStep.id === dynamicSteps.selectNameFolder
30
+ "
31
+ :name-form-submit="nameFormSubmit"
32
+ :project="props.project"
33
+ :data-center="props.dataCenter"
34
+ @submit="onChangeName(...$event)"
35
+ @check-name="emits('check-name', $event)"
36
+ />
37
+ <common-vm-actions-common-select-compute-resource
38
+ v-if="isSphere"
39
+ v-show="selectedStep.id === dynamicSteps.selectComputeResource"
40
+ v-model="computeResource"
41
+ :compute-resource-submit="computeResourceSubmit"
42
+ :data-center="vmForm.dataCenter"
43
+ :compute-resource="props.computeResource"
44
+ :compute-resource-tree="props.computeResourceTree"
45
+ @submit="onChangeComputeResource"
46
+ @select-compute-resource-tree="onSelectComputeResourceTree"
47
+ @get-compute-resource-tree="
48
+ emits('get-compute-resource-tree', $event)
49
+ "
50
+ @show-compute-resource-tree="
51
+ emits('show-compute-resource-tree', $event)
52
+ "
53
+ @clear-compute-resource-tree="emits('clear-compute-resource-tree')"
54
+ />
55
+ <common-vm-actions-common-select-storage
56
+ v-show="selectedStep.id === dynamicSteps.selectStorage"
57
+ :storage-submit="storageSubmit"
58
+ :datastore="props.datastore"
59
+ :is-datastore-loading="props.isDatastoreLoading"
60
+ :storage="vmForm.storage"
61
+ :get-datastore-table-func="props.getDatastoreTableFunc"
62
+ @submit="onChangeStorage"
63
+ />
64
+ <common-vm-actions-common-select-options
65
+ v-show="selectedStep.id === dynamicSteps.selectOptions"
66
+ :is-create-template="props.isNewVmFromTemplate"
67
+ @change="onChangeSelectOptions"
68
+ />
69
+ <common-vm-actions-common-select-os
70
+ v-show="selectedStep.id === dynamicSteps.selectGuestOSMachineType"
71
+ v-model:machine-type="vmForm.guestMachineType"
72
+ v-model:guest-os-family="vmForm.guestOsFamily"
73
+ v-model:guest-os-version="vmForm.guestOsVersion"
74
+ :families-options="guestOsFamilies"
75
+ :versions-options="guestOsVersions"
76
+ :machine-types-options="machineTypes"
77
+ :error-validation-fields="props.errorValidationFields"
78
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
79
+ />
80
+ <common-vm-actions-common-customize-hardware
81
+ v-show="selectedStep.id === dynamicSteps.customizeHardware"
82
+ v-model:vm-name="vmName"
83
+ v-model:guest-machine-type="vmSettings.guestMachineType"
84
+ v-model:guest-os-family="vmSettings.guestOsFamily"
85
+ v-model:guest-os-version="vmSettings.guestOsVersion"
86
+ :storage="vmForm.storage"
87
+ :hard-disks-for-boot-options="virtualHardwareHardDisksLocal"
88
+ :cd-dvd-drives-for-boot-options="virtualHardwareCdDvdDrivesLocal"
89
+ :networks-for-boot-options="virtualHardwareNetworksLocal"
90
+ :cd-dvd-drives="vmSettings.cdDvdDrives"
91
+ :hard-disks="vmSettings.hardDisks"
92
+ :networks="vmSettings.networks"
93
+ :customize-hardware-submit="customizeHardwareSubmit"
94
+ :max-cpus="vmSettings.maxCpus"
95
+ :max-memory="vmSettings.maxMemory"
96
+ :cpu-models="vmSettings.cpuModels"
97
+ :cpu="vmSettings.cpu"
98
+ :memory="vmSettings.memory"
99
+ :video-card="vmSettings.videoCard"
100
+ :usb-controller="vmSettings.usbController"
101
+ :pci-devices="vmSettings.pciDevices"
102
+ :selected-nav-item="selectedNavItem"
103
+ :hard-disks-for-edit="vmSettings.hardDisks"
104
+ :options="vmSettings.options"
105
+ :nodes="props.nodes"
106
+ :files="props.files"
107
+ :networks-table="props.networksTable"
108
+ :error-validation-fields="props.errorValidationFields"
109
+ :vm-cpu-help-text-second="props.vmCpuHelpTextSecond"
110
+ :passthrough-devices="props.passthroughDevices"
111
+ :mediated-devices="props.mediatedDevices"
112
+ :get-datastore-table-func="props.getDatastoreTableFunc"
113
+ :datastore="props.datastore"
114
+ :is-datastore-loading="props.isDatastoreLoading"
115
+ :project="props.project"
116
+ is-clone
117
+ @change-boot-order="onChangeBootOrder"
118
+ @send-data="onChangeCustomizeHardware"
119
+ @get-storage="emits('get-storage', $event)"
120
+ @get-folders-or-files="emits('get-folders-or-files', $event)"
121
+ @get-active-device-child="emits('get-active-device-child', $event)"
122
+ @show-datastore-child="emits('show-datastore-child', $event)"
123
+ @get-networks-table="emits('get-networks-table', $event)"
124
+ @get-pci-devices="emits('get-pci-devices')"
125
+ />
126
+ <common-ready-to-complete
127
+ v-show="selectedStep.id === dynamicSteps.readyComplete"
128
+ :data="props.readyCompleteTableInfo"
129
+ />
130
+ </div>
131
+ </template>
132
+ </atoms-wizard>
133
+ </div>
134
+ </template>
135
+
136
+ <script setup lang="ts">
137
+ import type {
138
+ UI_I_DatastoreTableItem,
139
+ UI_I_FolderOrFileTreePayload,
140
+ } from '~/lib/models/store/storage/interfaces'
141
+ import type { UI_I_NetworkTableItem } from '~/lib/models/store/network/interfaces'
142
+ import type { API_UI_I_Error } from '~/lib/models/store/interfaces'
143
+ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
144
+ import type { UI_I_FileTreeNode } from '~/components/lib/models/interfaces'
145
+ import type {
146
+ UI_I_ArbitraryObject,
147
+ UI_I_Localization,
148
+ } from '~/lib/models/interfaces'
149
+ import type { UI_I_SendDataCustomizeHardware } from '~/components/common/vm/actions/common/customizeHardware/lib/models/interfaces'
150
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
151
+ import type {
152
+ UI_I_SendDataCpu,
153
+ UI_I_SendDataMemory,
154
+ UI_I_SendDataNewCdDvdDrive,
155
+ UI_I_SendDataNewHardDisk,
156
+ UI_I_SendDataNewNetwork,
157
+ } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
158
+ import type { UI_T_SelectedNavItem } from '~/components/common/vm/actions/common/lib/models/types'
159
+ import type { UI_I_TableInfoItem } from '~/components/atoms/table/info/lib/models/interfaces'
160
+ import type { UI_T_ChangeBootOrder } from '~/components/common/vm/actions/lib/models/types'
161
+ import type { UI_T_Project } from '~/lib/models/types'
162
+ import type {
163
+ UI_I_MediatedDevice,
164
+ UI_I_PciDevice,
165
+ UI_I_VmSettings,
166
+ } from '~/lib/models/store/vm/interfaces'
167
+ import type { UI_I_VmForm } from '~/components/common/vm/actions/common/lib/models/interfaces'
168
+ import type {
169
+ UI_I_ValidationReturn,
170
+ UI_I_WizardStep,
171
+ } from '~/components/atoms/wizard/lib/models/interfaces'
172
+ import type { UI_I_Capabilities } from '~/components/common/vm/actions/common/lib/models/interfaces'
173
+ import type { UI_I_ScheduleNewTasksForm } from '~/components/common/pages/scheduledTasks/modals/lib/models/interfaces'
174
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
175
+ import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
176
+ import {
177
+ stepsSchemeInitial,
178
+ stepsFunc,
179
+ dynamicSteps,
180
+ } from '~/components/common/vm/actions/clone/lib/config/steps'
181
+ import Wizard from '~/components/atoms/wizard/lib/utils/utils'
182
+ import { mapCapabilities } from '~/components/common/vm/actions/common/lib/utils/capabilities'
183
+ import { scheduledTaskDefaultFormFunc } from '~/components/common/pages/scheduledTasks/modals/lib/config/createScheduledTask'
184
+ import { capabilities } from '~/components/common/vm/actions/common/lib/config/capabilities'
185
+
186
+ const props = withDefaults(
187
+ defineProps<{
188
+ project: UI_T_Project
189
+ vmSettings: UI_I_VmSettings | null
190
+ nodes: UI_I_FileTreeNode[]
191
+ files: UI_I_FileTreeNode[]
192
+ networksTable: UI_I_NetworkTableItem[]
193
+ datastore: UI_I_DatastoreTableItem[]
194
+ isDatastoreLoading: boolean
195
+ errorValidationFields: UI_I_ErrorValidationField[]
196
+ readyCompleteTableInfo: UI_I_TableInfoItem[]
197
+ vmCpuHelpTextSecond: string
198
+ finishFunc: any
199
+ getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
200
+ validateSendDataFunc: any
201
+ passthroughDevices: UI_I_PciDevice[]
202
+ mediatedDevices: UI_I_MediatedDevice[]
203
+ vmNameInWizard: string
204
+ capabilities?: UI_I_Capabilities
205
+ schedulerTask?: any // TODO надо interface переместить глобално
206
+ selectedVirtualMachine?: UI_I_Capabilities
207
+ isNewVmFromTemplate?: boolean
208
+ dataCenter?: UI_I_TreeNode // для сферы
209
+ computeResource?: UI_I_TreeNode // для сферы
210
+ computeResourceTree?: UI_I_TreeNode[] // для сферы
211
+ }>(),
212
+ {
213
+ capabilities: undefined,
214
+ schedulerTask: undefined,
215
+ selectedVirtualMachine: undefined,
216
+ isNewVmFromTemplate: undefined,
217
+ dataCenter: undefined,
218
+ computeResource: undefined,
219
+ computeResourceTree: undefined,
220
+ }
221
+ )
222
+
223
+ const emits = defineEmits<{
224
+ (event: 'check-name', value: [string, (error: API_UI_I_Error) => void]): void
225
+ (event: 'get-storage', value: UI_I_TablePayload): void
226
+ (event: 'get-folders-or-files', value: UI_I_FolderOrFileTreePayload): void
227
+ (event: 'get-active-device-child', value: UI_I_FileTreeNode): void
228
+ (event: 'show-datastore-child', value: UI_I_FileTreeNode): void
229
+ (event: 'remove-error-by-title', value: string): void
230
+ (event: 'get-networks-table', value: UI_I_TablePayload): void
231
+ (event: 'get-pci-devices'): void
232
+ (event: 'hide'): void
233
+ (
234
+ event: 'get-compute-resource-tree',
235
+ value: { id: string | number; cb: () => void }
236
+ ): void // для сферы
237
+ (event: 'show-compute-resource-tree', value: UI_I_TreeNode): void // для сферы
238
+ (event: 'select-compute-resource-tree', value: UI_I_TreeNode): void // для сферы
239
+ (event: 'clear-compute-resource-tree'): void // для сферы
240
+ }>()
241
+
242
+ const { $recursion } = useNuxtApp()
243
+
244
+ const localization = computed<UI_I_Localization>(() => useLocal())
245
+
246
+ const isSphere = computed<boolean>(() => props.project === 'sphere')
247
+
248
+ const isScheduledTasks = computed<boolean>(
249
+ () => props.schedulerTask?.isSchedulerTask
250
+ )
251
+
252
+ const title = computed<string>(() => {
253
+ const { scheduleNewTasks, scheduleTaskEdit, cloneExistingVirtualMachine } =
254
+ localization.value.common
255
+
256
+ let result = cloneExistingVirtualMachine
257
+ if (isScheduledTasks.value) {
258
+ const schedulerMode = props.schedulerTask.editTask
259
+ ? scheduleTaskEdit
260
+ : scheduleNewTasks
261
+
262
+ result = `${schedulerMode} (${cloneExistingVirtualMachine})`
263
+ }
264
+
265
+ if (props.isNewVmFromTemplate) {
266
+ result = localization.value.vmWizard.deployFromTemplate
267
+ }
268
+
269
+ return result
270
+ })
271
+
272
+ watch(
273
+ () => props.capabilities,
274
+ () => {
275
+ if (props.capabilities) {
276
+ mapCapabilities(props.capabilities)
277
+ }
278
+ },
279
+ { deep: true, immediate: true }
280
+ )
281
+
282
+ const wizard: Wizard = new Wizard(
283
+ stepsFunc(localization.value),
284
+ stepsSchemeInitial
285
+ )
286
+ watch(
287
+ isScheduledTasks,
288
+ (newValue) => {
289
+ if (newValue) {
290
+ wizard.changeScheme(isSphere.value ? 12 : 4)
291
+ } else {
292
+ wizard.changeScheme(isSphere.value ? 8 : 0)
293
+ wizard.selectStepHard(isSphere.value ? 2 : 1)
294
+ }
295
+ },
296
+ { immediate: true }
297
+ )
298
+
299
+ // TODO move to common
300
+ const newTaskForm = ref<UI_I_ScheduleNewTasksForm>(
301
+ useDeepCopy(scheduledTaskDefaultFormFunc())
302
+ )
303
+ watch(
304
+ newTaskForm,
305
+ (newValue: UI_I_ScheduleNewTasksForm) => {
306
+ if (isScheduledTasks.value) wizard.setDisabledNextButton(newValue.isValid)
307
+ },
308
+ { immediate: true, deep: true }
309
+ )
310
+
311
+ const selectedScheme = computed<number[]>(() => wizard.selectedScheme.value)
312
+
313
+ const onChangeSteps = async (value: UI_I_WizardStep[]): Promise<void> => {
314
+ wizard.changeSteps(value, validationFunc, validateSendData)
315
+ }
316
+
317
+ const validationFunc = async (
318
+ value: UI_I_WizardStep[],
319
+ currentStep: UI_I_WizardStep,
320
+ nextStep: UI_I_WizardStep
321
+ ): Promise<UI_I_ValidationReturn> => {
322
+ let stepHasError = false
323
+ let stepShouldStop = {
324
+ ifOnCurrentStep: false,
325
+ ifFromAnyStep: false,
326
+ stoppageStepId: -1,
327
+ }
328
+
329
+ wizard.setLoader(true)
330
+ if (
331
+ wizard.isValidateForStep(
332
+ isSphere.value ? dynamicSteps.selectNameFolder : dynamicSteps.selectName,
333
+ currentStep.id,
334
+ nextStep.id
335
+ )
336
+ ) {
337
+ const nameValidation = await checkName(value)
338
+
339
+ value = nameValidation.newValue
340
+ stepHasError = stepHasError || nameValidation.stepHasError
341
+ } else if (
342
+ isSphere.value &&
343
+ wizard.isValidateForStep(
344
+ dynamicSteps.selectComputeResource,
345
+ currentStep.id,
346
+ nextStep.id
347
+ )
348
+ ) {
349
+ const computeResourceValidation = await checkComputeResource(value)
350
+
351
+ value = computeResourceValidation.newValue
352
+ stepHasError = stepHasError || computeResourceValidation.stepHasError
353
+ } else if (
354
+ wizard.isValidateForStep(
355
+ dynamicSteps.selectStorage,
356
+ currentStep.id,
357
+ nextStep.id
358
+ )
359
+ ) {
360
+ const storageValidation = await checkStorage(value)
361
+
362
+ value = storageValidation.newValue
363
+
364
+ stepHasError = stepHasError || storageValidation.stepHasError
365
+ } else if (
366
+ wizard.isValidateForStep(
367
+ dynamicSteps.customizeHardware,
368
+ currentStep.id,
369
+ nextStep.id
370
+ )
371
+ ) {
372
+ const customizeHardwareValidation = await checkCustomizeHardware(value)
373
+
374
+ value = customizeHardwareValidation.newValue
375
+
376
+ stepHasError = stepHasError || customizeHardwareValidation.stepHasError
377
+ }
378
+ wizard.setLoader(false)
379
+
380
+ return {
381
+ newValue: value,
382
+ stepHasError,
383
+ stepShouldStop,
384
+ }
385
+ }
386
+ const checkName = async (
387
+ value: UI_I_WizardStep[]
388
+ ): Promise<UI_I_ValidationReturn> => {
389
+ let stepHasError = false
390
+
391
+ return new Promise((resolve) => {
392
+ const step = isSphere.value
393
+ ? dynamicSteps.selectNameFolder
394
+ : dynamicSteps.selectName
395
+ nameFormSubmit.value = (isValid: boolean) => {
396
+ if (!isValid) {
397
+ stepHasError = wizard.setValidation(step, 'name', {
398
+ fieldMessage: 'aaa',
399
+ alertMessage: 'aaa',
400
+ })
401
+ } else if (wizard.hasMessage(step, 'name')) {
402
+ value = wizard.removeValidation(step, 'name', value)
403
+ }
404
+
405
+ resolve({
406
+ stepHasError,
407
+ newValue: value,
408
+ })
409
+ nameFormSubmit.value = null
410
+ }
411
+ })
412
+ }
413
+ const checkComputeResource = async (
414
+ value: UI_I_WizardStep[]
415
+ ): Promise<UI_I_ValidationReturn> => {
416
+ let stepHasError = false
417
+
418
+ return new Promise((resolve) => {
419
+ computeResourceSubmit.value = (isValid: boolean) => {
420
+ if (!isValid) {
421
+ stepHasError = wizard.setValidation(
422
+ dynamicSteps.selectComputeResource,
423
+ 'computeResource',
424
+ {
425
+ fieldMessage: 'aaa',
426
+ alertMessage: 'aaa',
427
+ }
428
+ )
429
+ } else if (
430
+ wizard.hasMessage(dynamicSteps.selectComputeResource, 'computeResource')
431
+ ) {
432
+ value = wizard.removeValidation(
433
+ dynamicSteps.selectComputeResource,
434
+ 'computeResource',
435
+ value
436
+ )
437
+ }
438
+
439
+ resolve({
440
+ stepHasError,
441
+ newValue: value,
442
+ })
443
+ computeResourceSubmit.value = null
444
+ }
445
+ })
446
+ }
447
+ const checkStorage = async (
448
+ value: UI_I_WizardStep[]
449
+ ): Promise<UI_I_ValidationReturn> => {
450
+ let stepHasError = false
451
+
452
+ return new Promise((resolve) => {
453
+ storageSubmit.value = (isValid: boolean) => {
454
+ if (!isValid) {
455
+ stepHasError = wizard.setValidation(
456
+ dynamicSteps.selectStorage,
457
+ 'storage',
458
+ {
459
+ fieldMessage: 'aaa',
460
+ alertMessage: 'aaa',
461
+ }
462
+ )
463
+ } else if (wizard.hasMessage(dynamicSteps.selectStorage, 'storage')) {
464
+ value = wizard.removeValidation(
465
+ dynamicSteps.selectStorage,
466
+ 'storage',
467
+ value
468
+ )
469
+ }
470
+
471
+ resolve({
472
+ stepHasError,
473
+ newValue: value,
474
+ })
475
+ storageSubmit.value = null
476
+ }
477
+ })
478
+ }
479
+ const checkCustomizeHardware = async (
480
+ value: UI_I_WizardStep[]
481
+ ): Promise<UI_I_ValidationReturn> => {
482
+ let stepHasError = false
483
+
484
+ return new Promise((resolve) => {
485
+ customizeHardwareSubmit.value = (isValid: boolean) => {
486
+ if (!isValid) {
487
+ stepHasError = wizard.setValidation(
488
+ dynamicSteps.customizeHardware,
489
+ 'customizeHardware',
490
+ {
491
+ fieldMessage: 'aaa',
492
+ alertMessage: 'aaa',
493
+ }
494
+ )
495
+ } else if (
496
+ wizard.hasMessage(dynamicSteps.customizeHardware, 'customizeHardware')
497
+ ) {
498
+ value = wizard.removeValidation(
499
+ dynamicSteps.customizeHardware,
500
+ 'customizeHardware',
501
+ value
502
+ )
503
+ }
504
+
505
+ resolve({
506
+ stepHasError,
507
+ newValue: value,
508
+ })
509
+ storageSubmit.value = null
510
+ }
511
+ })
512
+ }
513
+
514
+ const vmForm = ref<UI_I_VmForm>({
515
+ name: '',
516
+ compatibility: '',
517
+ guestMachineType: null,
518
+ guestOsFamily: null,
519
+ guestOsVersion: null,
520
+ computeResource: null,
521
+ storage: null,
522
+ locationPath: '',
523
+ dataCenter: null,
524
+ options: [],
525
+ })
526
+ const onChangeName = (name: string, node: UI_I_TreeNode): void => {
527
+ vmForm.value.name = name
528
+ if (isSphere.value) {
529
+ vmForm.value.locationPath = node.id
530
+ vmForm.value.dataCenter = $recursion.findParentByValue(
531
+ node,
532
+ 'datacenter',
533
+ 'type',
534
+ 'parent'
535
+ )
536
+ }
537
+ }
538
+ const onChangeStorage = (storage: UI_I_DatastoreTableItem | null): void => {
539
+ if (!storage) return
540
+
541
+ vmForm.value.storage = storage
542
+ }
543
+ const onChangeSelectOptions = (options: string[]): void => {
544
+ vmForm.value.options = options
545
+ if (
546
+ options.includes('customize-os') &&
547
+ options.includes('customize-hardware')
548
+ ) {
549
+ let procuratorSchame = isScheduledTasks.value ? 7 : 3
550
+ let sphereSchame = isScheduledTasks.value ? 15 : 11
551
+ wizard.changeScheme(isSphere.value ? sphereSchame : procuratorSchame)
552
+ } else if (options.includes('customize-os')) {
553
+ let procuratorSchame = isScheduledTasks.value ? 5 : 1
554
+ let sphereSchame = isScheduledTasks.value ? 13 : 9
555
+ wizard.changeScheme(isSphere.value ? sphereSchame : procuratorSchame)
556
+ } else if (options.includes('customize-hardware')) {
557
+ let procuratorSchame = isScheduledTasks.value ? 6 : 2
558
+ let sphereSchame = isScheduledTasks.value ? 14 : 10
559
+ wizard.changeScheme(isSphere.value ? sphereSchame : procuratorSchame)
560
+ } else {
561
+ let procuratorSchame = isScheduledTasks.value ? 4 : 0
562
+ let sphereSchame = isScheduledTasks.value ? 12 : 8
563
+ wizard.changeScheme(isSphere.value ? sphereSchame : procuratorSchame)
564
+ }
565
+
566
+ // Change power on by default
567
+ isPowerOnByDefault.value = options.includes('power-on')
568
+ }
569
+ const customizeHardware = ref<UI_I_SendDataCustomizeHardware | null>(null)
570
+ const onChangeCustomizeHardware = (
571
+ data: UI_I_SendDataCustomizeHardware
572
+ ): void => {
573
+ customizeHardware.value = data
574
+ }
575
+
576
+ const virtualHardwareHardDisksLocal = computed<
577
+ UI_I_SendDataNewHardDisk[] | null
578
+ >(() => customizeHardware.value?.virtualHardware?.hardDisks || null)
579
+ const virtualHardwareNetworksLocal = computed<UI_I_SendDataNewNetwork[] | null>(
580
+ () => customizeHardware.value?.virtualHardware?.networks || null
581
+ )
582
+ const virtualHardwareCdDvdDrivesLocal = computed<
583
+ UI_I_SendDataNewCdDvdDrive[] | null
584
+ >(() => customizeHardware.value?.virtualHardware?.cdDvdDrives || null)
585
+
586
+ const virtualHardwareCpu = computed<UI_I_SendDataCpu | null>(
587
+ () => customizeHardware.value?.virtualHardware?.cpu || null
588
+ )
589
+ const virtualHardwareMemory = computed<UI_I_SendDataMemory | null>(
590
+ () => customizeHardware.value?.virtualHardware?.memory || null
591
+ )
592
+ const virtualHardwareHardDisks = ref<UI_I_SendDataNewHardDisk[] | null>(null)
593
+ const virtualHardwareCdDvdDrives = ref<UI_I_SendDataNewCdDvdDrive[] | null>(
594
+ null
595
+ )
596
+ const virtualHardwareNetworks = ref<UI_I_SendDataNewNetwork[] | null>(null)
597
+ const onChangeBootOrder = (data: UI_T_ChangeBootOrder): void => {
598
+ virtualHardwareHardDisks.value = data[0]
599
+ virtualHardwareCdDvdDrives.value = data[1]
600
+ virtualHardwareNetworks.value = data[2]
601
+ }
602
+
603
+ const isPowerOnByDefault = ref<boolean>(false)
604
+
605
+ watch(
606
+ () => props.vmNameInWizard,
607
+ (newValue) => {
608
+ vmForm.value.name = newValue
609
+ }
610
+ )
611
+
612
+ const validateSendData = async (
613
+ value: UI_I_WizardStep[]
614
+ ): Promise<UI_I_ValidationReturn> => {
615
+ wizard.setLoader(true)
616
+ let stepHasError = false
617
+
618
+ const data = await props.validateSendDataFunc(
619
+ vmForm.value,
620
+ virtualHardwareCpu.value,
621
+ virtualHardwareMemory.value,
622
+ customizeHardware.value,
623
+ virtualHardwareNetworks.value,
624
+ virtualHardwareHardDisks.value,
625
+ virtualHardwareCdDvdDrives.value,
626
+ isPowerOnByDefault.value,
627
+ localization.value,
628
+ vmForm.value.locationPath, // для сферы
629
+ // computeResourcePath.value // для сферы
630
+ vmSettings.value.host_id // для сферы // TODO rollback
631
+ )
632
+
633
+ wizard.setLoader(false)
634
+ if (data) {
635
+ stepHasError = true
636
+ selectedNavItem.value = data[0]
637
+ }
638
+
639
+ return {
640
+ stepHasError,
641
+ newValue: value,
642
+ }
643
+ }
644
+
645
+ const isLoading = ref<boolean>(false)
646
+ const onFinish = (): void => {
647
+ isLoading.value = true
648
+ wizard.setLoader(false)
649
+ props
650
+ .finishFunc(
651
+ vmForm.value,
652
+ virtualHardwareCpu.value,
653
+ virtualHardwareMemory.value,
654
+ customizeHardware.value,
655
+ virtualHardwareNetworks.value,
656
+ virtualHardwareHardDisks.value,
657
+ virtualHardwareCdDvdDrives.value,
658
+ isPowerOnByDefault.value,
659
+ localization.value,
660
+ vmForm.value.locationPath, // для сферы
661
+ // computeResourcePath.value, // для сферы
662
+ vmSettings.value.host_id, // для сферы // TODO rollback
663
+ false,
664
+ newTaskForm.value,
665
+ props.schedulerTask
666
+ )
667
+ .then(() => {
668
+ isLoading.value = false
669
+ onHideModal()
670
+ wizard.setLoader(false)
671
+ })
672
+ }
673
+
674
+ const selectedNavItem = ref<UI_T_SelectedNavItem>(0)
675
+
676
+ const nameFormSubmit = ref<null | Function>(null)
677
+ const computeResourceSubmit = ref<null | Function>(null)
678
+ const storageSubmit = ref<null | Function>(null)
679
+ const customizeHardwareSubmit = ref<null | Function>(null)
680
+
681
+ const vmSettings = computed<UI_I_VmSettings | null>(() => props.vmSettings)
682
+ const vmName = ref<string>(vmSettings.value?.name || '')
683
+
684
+ const guestOsFamilies = ref<UI_I_OptionItem[]>(
685
+ capabilities.value.guestOsFamilies
686
+ )
687
+ const guestOsVersions = ref<UI_I_ArbitraryObject<UI_I_OptionItem[]>>(
688
+ capabilities.value.guestOsVersions
689
+ )
690
+ const machineTypes = ref<UI_I_OptionItem[]>(capabilities.value.machineTypes)
691
+
692
+ const computeResource = ref<UI_I_TreeNode | null>(null)
693
+ const onChangeComputeResource = (node: UI_I_TreeNode): void => {
694
+ computeResource.value = node
695
+ }
696
+ // // Для сферы
697
+ const computeResourcePath = ref<string>('')
698
+ const onSelectComputeResourceTree = (node: UI_I_TreeNode): void => {
699
+ emits('select-compute-resource-tree', node)
700
+ computeResourcePath.value = node.id
701
+ }
702
+
703
+ watch(vmSettings, (newValue) => {
704
+ vmName.value = newValue?.name || ''
705
+
706
+ if (newValue?.guestOsFamily)
707
+ vmForm.value.guestOsFamily = newValue.guestOsFamily
708
+ if (newValue?.guestMachineType)
709
+ vmForm.value.guestMachineType = newValue.guestMachineType
710
+ if (newValue?.guestOsVersion)
711
+ vmForm.value.guestOsVersion = newValue.guestOsVersion
712
+
713
+ if (newValue?.compatibility)
714
+ vmForm.value.compatibility = newValue.compatibility
715
+
716
+ if (newValue?.storage) {
717
+ const datastore = props.datastore.find(
718
+ (item) => item.id === newValue.storage.id
719
+ )
720
+ if (datastore) vmForm.value.storage = datastore
721
+ }
722
+ })
723
+
724
+ const onHideModal = (): void => {
725
+ emits('hide')
726
+ }
727
+ </script>
728
+
729
+ <style scoped lang="scss">
730
+ :deep(.has-solid.close-icon.clr-icon) {
731
+ width: 20px;
732
+ top: 0;
733
+ }
734
+ .vm-context {
735
+ padding: 16px 15px 10px 10px;
736
+ height: 100%;
737
+ display: flex;
738
+ flex-direction: column;
739
+
740
+ .context-title-wrap {
741
+ padding-bottom: 3px;
742
+ border-bottom: 1px solid #a6a6a6;
743
+
744
+ h4 {
745
+ font-weight: 700;
746
+ font-size: 13px;
747
+ color: var(--vm-context-title);
748
+ }
749
+ p {
750
+ font-weight: 400;
751
+ font-size: 13px;
752
+ color: var(--vm-context-sub-title);
753
+ }
754
+ }
755
+
756
+ .finish-block {
757
+ padding: 18px 24px 24px 24px;
758
+
759
+ .add-hosts-ready-to-complete-mt-12 {
760
+ margin-top: 12px;
761
+
762
+ .add-hosts-ready-to-complete-bold {
763
+ line-height: 18px;
764
+ font-weight: 700;
765
+ }
766
+ }
767
+ }
768
+
769
+ .vm-hardware-version {
770
+ align-self: flex-end;
771
+ margin-top: auto;
772
+ }
773
+ }
774
+
775
+ :deep(.modal .modal-dialog .modal-content .modal-footer) {
776
+ flex: unset;
777
+ height: unset;
778
+ min-height: unset;
779
+ }
780
+ :deep(.wizard-modal-titlebar h3) {
781
+ color: #000;
782
+ font-size: 24px;
783
+ font-weight: 200;
784
+ line-height: 27px;
785
+ margin: 0;
786
+ padding: 0;
787
+ }
788
+ :deep(.clr-wizard-stepnav-item) {
789
+ padding-left: 0;
790
+ }
791
+ :deep(.clr-wizard-stepnav
792
+ .clr-wizard-stepnav-item
793
+ button
794
+ .clr-wizard-stepnav-link-title) {
795
+ width: 189px;
796
+ font-weight: 700;
797
+ font-size: 13px;
798
+ }
799
+
800
+ #vm-wizard-notification {
801
+ h3 {
802
+ color: var(--global-font-color7);
803
+ margin-top: 6px;
804
+ }
805
+ p {
806
+ color: var(--global-font-color6);
807
+ line-height: 16px;
808
+ }
809
+ }
810
+
811
+ .power-on-by-default-wrap {
812
+ display: flex;
813
+ align-items: center;
814
+
815
+ input {
816
+ margin-right: 6px;
817
+ }
818
+ }
819
+
820
+ .new-task-form {
821
+ padding: 0 25px 0 5px;
822
+ }
823
+ </style>