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,385 +1,392 @@
1
- <template>
2
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-new
3
- v-if="isNewView"
4
- v-model:delete-files-from-datastore="deleteFilesFromDatastore"
5
- v-model:size="size"
6
- v-model:hard-disk-type="hardDiskType"
7
- v-model:disk-provisioning="diskProvisioning"
8
- v-model:sharing="sharing"
9
- v-model:limit-iops="limitIops"
10
- v-model:limit-iops-type="limitIopsType"
11
- v-model:limit-iops-invalid="limitIopsInvalid"
12
- v-model:disk-mode="diskMode"
13
- v-model:cache="cache"
14
- v-model:bus="bus"
15
- :is-removable="isRemovable"
16
- :label="label"
17
- :hard-disk-invalid="hardDiskInvalid"
18
- :error-text="hardDiskLocalAndApiErrorsTexts"
19
- :hard-disk-type-error-local-text="hardDiskTypeErrorLocalText"
20
- :is-disabled-size="isDisabledSize"
21
- :hard-disk-type-options="hardDiskTypeOptions"
22
- :max-hard-disk="maxHardDisk"
23
- :location="location"
24
- :is-running="isRunning"
25
- :is-new-hard-disk="!isNotNewHardDisk"
26
- :is-edit="props.isEdit"
27
- :datastore="props.datastore"
28
- :is-datastore-loading="props.isDatastoreLoading"
29
- :get-datastore-table-func="props.getDatastoreTableFunc"
30
- :error-validation-fields="props.errorValidationFields"
31
- :index="props.index"
32
- :type="props.type"
33
- :hard-disk="props.hardDisk"
34
- :guest-machine-type="props.guestMachineType"
35
- :is-new-type="isNewType"
36
- :compute-resource="props.computeResource"
37
- @remove="emits('remove')"
38
- @roll-back="emits('roll-back')"
39
- @validate-size="onValidateSize"
40
- @change-storage="onChangeStorage"
41
- @remove-error-by-title="emits('remove-error-by-title', $event)"
42
- />
43
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-old
44
- v-else
45
- v-model:delete-files-from-datastore="deleteFilesFromDatastore"
46
- v-model:size="size"
47
- v-model:hard-disk-type="hardDiskType"
48
- v-model:disk-provisioning="diskProvisioning"
49
- v-model:sharing="sharing"
50
- v-model:limit-iops="limitIops"
51
- v-model:limit-iops-type="limitIopsType"
52
- v-model:limit-iops-invalid="limitIopsInvalid"
53
- v-model:disk-mode="diskMode"
54
- v-model:cache="cache"
55
- v-model:bus="bus"
56
- :is-removable="isRemovable"
57
- :label="label"
58
- :hard-disk-invalid="hardDiskInvalid"
59
- :error-text="hardDiskLocalAndApiErrorsTexts"
60
- :hard-disk-type-error-local-text="hardDiskTypeErrorLocalText"
61
- :is-disabled-size="isDisabledSize"
62
- :hard-disk-type-options="hardDiskTypeOptions"
63
- :max-hard-disk="maxHardDisk"
64
- :location="location"
65
- :is-running="isRunning"
66
- :is-new-hard-disk="!isNotNewHardDisk"
67
- :is-edit="props.isEdit"
68
- :datastore="props.datastore"
69
- :is-datastore-loading="props.isDatastoreLoading"
70
- :get-datastore-table-func="props.getDatastoreTableFunc"
71
- :error-validation-fields="props.errorValidationFields"
72
- :index="props.index"
73
- :type="props.type"
74
- :hard-disk="props.hardDisk"
75
- :guest-machine-type="props.guestMachineType"
76
- :is-new-type="isNewType"
77
- :compute-resource="props.computeResource"
78
- @remove="emits('remove')"
79
- @roll-back="emits('roll-back')"
80
- @validate-size="onValidateSize"
81
- @change-storage="onChangeStorage"
82
- @remove-error-by-title="emits('remove-error-by-title', $event)"
83
- />
84
- </template>
85
-
86
- <script setup lang="ts">
87
- import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
88
- import type {
89
- UI_I_SendDataNewHardDisk,
90
- UI_I_SendDataNewHardDiskStorage,
91
- } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
92
- import type { UI_T_HardDiskType } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/types'
93
- import type { UI_I_Localization } from '~/lib/models/interfaces'
94
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
95
- import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
96
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
97
- import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
98
- import { binaryOptionsFunc } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/config/binaryOptions'
99
-
100
- const props = defineProps<{
101
- storage: UI_I_DatastoreTableItem | null
102
- hardDisk: UI_I_SendDataNewHardDisk
103
- type: UI_T_HardDiskType
104
- index: number
105
- errorValidationFields: UI_I_ErrorValidationField[]
106
- getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
107
- datastore: UI_I_DatastoreTableItem[]
108
- isDatastoreLoading: boolean
109
- isEdit: boolean
110
- state?: string | number
111
- guestMachineType?: UI_I_OptionItem | null
112
- computeResource?: UI_I_TreeNode | null
113
- }>()
114
- const emits = defineEmits<{
115
- (event: 'send-data', value: UI_I_SendDataNewHardDisk): void
116
- (event: 'invalid', value: boolean): void
117
- (event: 'remove'): void
118
- (event: 'roll-back'): void
119
- (event: 'remove-error-by-title', value: string): void
120
- }>()
121
-
122
- const { $store, $binary }: any = useNuxtApp()
123
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
124
-
125
- const localization = computed<UI_I_Localization>(() => useLocal())
126
-
127
- const isRunning = computed<boolean>(() => {
128
- return props.state === 2
129
- })
130
-
131
- const isRemovable = computed<boolean>(() => {
132
- return (
133
- !props.isEdit ||
134
- !isRunning.value ||
135
- (isRunning.value && bus.value === 'virtio')
136
- )
137
- })
138
-
139
- const isNewType = computed<boolean>(
140
- () => props.type === 'new' || props.type === 'clone'
141
- )
142
-
143
- const typeError = computed<string>(() => `disk_devices[${props.index}].size`)
144
-
145
- const apiErrorLocal = computed<string>(() => {
146
- return (
147
- props.errorValidationFields?.find(
148
- (message) => message.field === typeError.value
149
- )?.error_message || ''
150
- )
151
- })
152
-
153
- // PC-1796
154
- const isNotNewHardDisk = computed<boolean>(
155
- () => props.type === 'edit' || props.type === 'removed'
156
- )
157
- const label = computed<string>(() => {
158
- // if (props.type === 'edit' || props.type === 'removed')
159
- if (isNotNewHardDisk.value)
160
- return `${localization.value.common.hardDisk} ${props.index + 1}`
161
-
162
- return `${localization.value.common.newHardDisk} *`
163
- })
164
-
165
- const maxHardDisk = computed<number>(() => {
166
- const hardDiskSizeMb = $binary.gbToMb(props.hardDisk.size)
167
-
168
- if (props.type === 'exist') return hardDiskSizeMb
169
-
170
- if (!storage.value) return 0
171
- const free = storage.value.capacity.free_mb || storage.value.capacity // TODO fix
172
-
173
- if (props.isEdit) return free + hardDiskSizeMb
174
-
175
- return free
176
- })
177
- const hardDiskTypeErrorLocalText = computed<string>(() => {
178
- if (+sizeInMb.value > maxHardDisk.value) {
179
- return localization.value.common.diskCapacitySpecifiedGreater
180
- }
181
-
182
- if (+sizeInMb.value <= 0) {
183
- return localization.value.common.diskCapacityCannotZero
184
- }
185
-
186
- return ''
187
- })
188
-
189
- const hardDiskLocalAndApiErrorsTexts = computed<string>(() => {
190
- const localError = hardDiskTypeErrorLocalText.value
191
- const apiError = apiErrorLocal.value
192
-
193
- let result = ''
194
- if (localError && !apiError) result = localError
195
- if (!localError && apiError) result = apiError
196
- if (localError && apiError) result = localError + ', ' + apiError
197
- if (!localError && apiError) result = apiError
198
-
199
- return result
200
- })
201
-
202
- const deleteFilesFromDatastore = ref<boolean>(false)
203
-
204
- const hardDiskType = ref<string>('gb')
205
- const hardDiskTypeOptions = ref<UI_I_OptionItem[]>(
206
- binaryOptionsFunc(localization.value)
207
- )
208
-
209
- const size = ref<number>(props.hardDisk.size) // Изначально всегда приходит в gb
210
- const sizeInMb = computed<number>(() => {
211
- if (hardDiskType.value === 'mb') {
212
- return size.value
213
- }
214
-
215
- return $binary.universalFromTo(size.value, hardDiskType.value, 'mb')
216
- })
217
- const onValidateSize = (): void => {
218
- if (props.type !== 'edit') return
219
- if (sizeInMb.value < props.hardDisk.size) {
220
- size.value = $binary.universalFromTo(
221
- props.hardDisk.size,
222
- 'mb',
223
- hardDiskType.value
224
- )
225
- }
226
- }
227
-
228
- const isDisabledSize = computed<boolean>(() => {
229
- return props.type === 'exist' || (props.type === 'edit' && readOnly.value)
230
- })
231
-
232
- const location = ref<UI_I_DatastoreTableItem | null>(props.storage || null)
233
- const storage = ref<UI_I_DatastoreTableItem | null>(props.storage)
234
- watch(
235
- () => props.storage,
236
- (newValue) => {
237
- location.value = newValue
238
- storage.value = newValue
239
- },
240
- {
241
- immediate: true,
242
- deep: true,
243
- }
244
- )
245
- const onChangeStorage = (item: UI_I_DatastoreTableItem): void => {
246
- storage.value = item
247
- }
248
-
249
- const diskProvisioning = ref<string>('thick')
250
- const sharing = ref<string>('')
251
- const shares = ref<number>(0)
252
-
253
- const limitIops = ref<number>(16)
254
- const limitIopsType = ref<string>('unlimited')
255
- const limitIopsInvalid = ref<boolean>(false)
256
-
257
- const diskMode = ref<string>('dependent')
258
-
259
- const cache = ref<string>('none')
260
-
261
- const bus = ref<string>('ide')
262
-
263
- const readOnly = ref<boolean>(false)
264
-
265
- const discard = ref<string>('')
266
-
267
- const io = ref<string>('')
268
-
269
- const target = ref<string>('')
270
-
271
- watch(
272
- [
273
- sizeInMb,
274
- storage,
275
- diskProvisioning,
276
- sharing,
277
- limitIops,
278
- limitIopsType,
279
- diskMode,
280
- cache,
281
- bus,
282
- deleteFilesFromDatastore,
283
- (): void => props.type,
284
- ],
285
- () => {
286
- const limitIopsLocal =
287
- limitIopsType.value === 'unlimited' ? 0 : limitIops.value
288
- const storageLocal: UI_I_SendDataNewHardDiskStorage = {
289
- id: storage.value?.id || '',
290
- name: storage.value?.name || '',
291
- type: storage.value?.type_text || '',
292
- pool: storage.value?.pool_name || '',
293
- user: '',
294
- endpoint: '',
295
- password: '',
296
- protocol: '',
297
- options: '',
298
- }
299
-
300
- emits('send-data', {
301
- create: props.hardDisk.create,
302
- attach: props.hardDisk.attach,
303
- source: props.hardDisk.source,
304
- size: Math.ceil(sizeInMb.value),
305
- bus: bus.value,
306
- target: target.value,
307
- storage: storageLocal,
308
- device_type: 'disk',
309
- provision_type: diskProvisioning.value,
310
- disk_mode: diskMode.value,
311
- sharing: sharing.value === 'yes',
312
- read_only: readOnly.value,
313
- shares: shares.value,
314
- cache: cache.value,
315
- io: io.value,
316
- limit_iops: limitIopsLocal,
317
- discard: discard.value,
318
- capacity: Math.ceil(sizeInMb.value),
319
- boot_order: props.hardDisk.boot_order,
320
- detach: props.type === 'removed',
321
- remove: props.type === 'removed' && deleteFilesFromDatastore.value, // Проверяем если удалили диск и указали Delete files from datastore
322
- })
323
- },
324
- { immediate: true }
325
- )
326
-
327
- // Добавляем данные для редактирования
328
- watch(
329
- () => props.hardDisk,
330
- (newValue) => {
331
- // TODO refactoring
332
- if (props.type === 'exist') {
333
- diskProvisioning.value = newValue.provision_type || 'thick'
334
- return
335
- }
336
- // if (props.type !== 'edit') return
337
- if (props.type !== 'edit' && props.type !== 'clone') return
338
-
339
- const sizeInGb = $binary.mbToGb(newValue.size)
340
- if (sizeInGb < 1) {
341
- size.value = newValue.size
342
- hardDiskType.value = 'mb'
343
- } else {
344
- size.value = sizeInGb
345
- hardDiskType.value = 'gb'
346
- }
347
- diskProvisioning.value = newValue.provision_type || 'thick'
348
- sharing.value = newValue.sharing ? 'yes' : ''
349
- shares.value = newValue.shares || 0
350
- // limitIopsType.value = newValue.io === 'native' ? 'unlimited' : 'custom'
351
- limitIopsType.value = newValue.limit_iops === 0 ? 'unlimited' : 'custom'
352
- limitIops.value = newValue.limit_iops || 16
353
- diskMode.value = newValue.disk_mode || 'dependent'
354
- cache.value = newValue.cache || 'none'
355
- bus.value = newValue.bus || 'ide'
356
- readOnly.value = newValue.read_only || false
357
- discard.value = newValue.discard || ''
358
- io.value = newValue.io || ''
359
- target.value = newValue.target || ''
360
- },
361
- { immediate: true }
362
- )
363
- watch(
364
- isRunning,
365
- (newValue) => {
366
- if (newValue && props.type === 'new') {
367
- bus.value = 'virtio'
368
- }
369
- },
370
- { immediate: true }
371
- )
372
-
373
- const hardDiskInvalid = computed<boolean>(() => {
374
- return !!hardDiskTypeErrorLocalText.value || limitIopsInvalid.value
375
- })
376
- watch(
377
- hardDiskInvalid,
378
- (newValue) => {
379
- emits('invalid', newValue)
380
- },
381
- { immediate: true }
382
- )
383
- </script>
384
-
385
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-new
3
+ v-if="isNewView"
4
+ v-model:delete-files-from-datastore="deleteFilesFromDatastore"
5
+ v-model:size="size"
6
+ v-model:hard-disk-type="hardDiskType"
7
+ v-model:disk-provisioning="diskProvisioning"
8
+ v-model:sharing="sharing"
9
+ v-model:limit-iops="limitIops"
10
+ v-model:limit-iops-type="limitIopsType"
11
+ v-model:limit-iops-invalid="limitIopsInvalid"
12
+ v-model:disk-mode="diskMode"
13
+ v-model:cache="cache"
14
+ v-model:bus="bus"
15
+ :is-removable="isRemovable"
16
+ :label="label"
17
+ :hard-disk-invalid="hardDiskInvalid"
18
+ :error-text="hardDiskLocalAndApiErrorsTexts"
19
+ :hard-disk-type-error-local-text="hardDiskTypeErrorLocalText"
20
+ :is-disabled-size="isDisabledSize"
21
+ :hard-disk-type-options="hardDiskTypeOptions"
22
+ :max-hard-disk="maxHardDisk"
23
+ :location="location"
24
+ :is-running="isRunning"
25
+ :is-new-hard-disk="!isNotNewHardDisk"
26
+ :is-edit="props.isEdit"
27
+ :datastore="props.datastore"
28
+ :is-datastore-loading="props.isDatastoreLoading"
29
+ :get-datastore-table-func="props.getDatastoreTableFunc"
30
+ :error-validation-fields="props.errorValidationFields"
31
+ :index="props.index"
32
+ :type="props.type"
33
+ :hard-disk="props.hardDisk"
34
+ :guest-machine-type="props.guestMachineType"
35
+ :is-new-type="isNewType"
36
+ :compute-resource="props.computeResource"
37
+ @remove="emits('remove')"
38
+ @roll-back="emits('roll-back')"
39
+ @validate-size="onValidateSize"
40
+ @change-storage="onChangeStorage"
41
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
42
+ />
43
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-old
44
+ v-else
45
+ v-model:delete-files-from-datastore="deleteFilesFromDatastore"
46
+ v-model:size="size"
47
+ v-model:hard-disk-type="hardDiskType"
48
+ v-model:disk-provisioning="diskProvisioning"
49
+ v-model:sharing="sharing"
50
+ v-model:limit-iops="limitIops"
51
+ v-model:limit-iops-type="limitIopsType"
52
+ v-model:limit-iops-invalid="limitIopsInvalid"
53
+ v-model:disk-mode="diskMode"
54
+ v-model:cache="cache"
55
+ v-model:bus="bus"
56
+ :is-removable="isRemovable"
57
+ :label="label"
58
+ :hard-disk-invalid="hardDiskInvalid"
59
+ :error-text="hardDiskLocalAndApiErrorsTexts"
60
+ :hard-disk-type-error-local-text="hardDiskTypeErrorLocalText"
61
+ :is-disabled-size="isDisabledSize"
62
+ :hard-disk-type-options="hardDiskTypeOptions"
63
+ :max-hard-disk="maxHardDisk"
64
+ :location="location"
65
+ :is-running="isRunning"
66
+ :is-new-hard-disk="!isNotNewHardDisk"
67
+ :is-edit="props.isEdit"
68
+ :datastore="props.datastore"
69
+ :is-datastore-loading="props.isDatastoreLoading"
70
+ :get-datastore-table-func="props.getDatastoreTableFunc"
71
+ :error-validation-fields="props.errorValidationFields"
72
+ :index="props.index"
73
+ :type="props.type"
74
+ :hard-disk="props.hardDisk"
75
+ :guest-machine-type="props.guestMachineType"
76
+ :is-new-type="isNewType"
77
+ :compute-resource="props.computeResource"
78
+ @remove="emits('remove')"
79
+ @roll-back="emits('roll-back')"
80
+ @validate-size="onValidateSize"
81
+ @change-storage="onChangeStorage"
82
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
83
+ />
84
+ </template>
85
+
86
+ <script setup lang="ts">
87
+ import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
88
+ import type {
89
+ UI_I_SendDataNewHardDisk,
90
+ UI_I_SendDataNewHardDiskStorage,
91
+ } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
92
+ import type { UI_T_HardDiskType } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/types'
93
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
94
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
95
+ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
96
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
97
+ import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
98
+ import { binaryOptionsFunc } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/config/binaryOptions'
99
+
100
+ const props = withDefaults(
101
+ defineProps<{
102
+ storage: UI_I_DatastoreTableItem | null
103
+ hardDisk: UI_I_SendDataNewHardDisk
104
+ type: UI_T_HardDiskType
105
+ index: number
106
+ errorValidationFields: UI_I_ErrorValidationField[]
107
+ getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
108
+ datastore: UI_I_DatastoreTableItem[]
109
+ isDatastoreLoading: boolean
110
+ isEdit: boolean
111
+ state?: string | number
112
+ guestMachineType?: UI_I_OptionItem | null
113
+ computeResource?: UI_I_TreeNode | null
114
+ }>(),
115
+ {
116
+ state: undefined,
117
+ guestMachineType: undefined,
118
+ computeResource: undefined,
119
+ }
120
+ )
121
+ const emits = defineEmits<{
122
+ (event: 'send-data', value: UI_I_SendDataNewHardDisk): void
123
+ (event: 'invalid', value: boolean): void
124
+ (event: 'remove'): void
125
+ (event: 'roll-back'): void
126
+ (event: 'remove-error-by-title', value: string): void
127
+ }>()
128
+
129
+ const { $store, $binary }: any = useNuxtApp()
130
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
131
+
132
+ const localization = computed<UI_I_Localization>(() => useLocal())
133
+
134
+ const isRunning = computed<boolean>(() => {
135
+ return props.state === 2
136
+ })
137
+
138
+ const isRemovable = computed<boolean>(() => {
139
+ return (
140
+ !props.isEdit ||
141
+ !isRunning.value ||
142
+ (isRunning.value && bus.value === 'virtio')
143
+ )
144
+ })
145
+
146
+ const isNewType = computed<boolean>(
147
+ () => props.type === 'new' || props.type === 'clone'
148
+ )
149
+
150
+ const typeError = computed<string>(() => `disk_devices[${props.index}].size`)
151
+
152
+ const apiErrorLocal = computed<string>(() => {
153
+ return (
154
+ props.errorValidationFields?.find(
155
+ (message) => message.field === typeError.value
156
+ )?.error_message || ''
157
+ )
158
+ })
159
+
160
+ // PC-1796
161
+ const isNotNewHardDisk = computed<boolean>(
162
+ () => props.type === 'edit' || props.type === 'removed'
163
+ )
164
+ const label = computed<string>(() => {
165
+ // if (props.type === 'edit' || props.type === 'removed')
166
+ if (isNotNewHardDisk.value)
167
+ return `${localization.value.common.hardDisk} ${props.index + 1}`
168
+
169
+ return `${localization.value.common.newHardDisk} *`
170
+ })
171
+
172
+ const maxHardDisk = computed<number>(() => {
173
+ const hardDiskSizeMb = $binary.gbToMb(props.hardDisk.size)
174
+
175
+ if (props.type === 'exist') return hardDiskSizeMb
176
+
177
+ if (!storage.value) return 0
178
+ const free = storage.value.capacity.free_mb || storage.value.capacity // TODO fix
179
+
180
+ if (props.isEdit) return free + hardDiskSizeMb
181
+
182
+ return free
183
+ })
184
+ const hardDiskTypeErrorLocalText = computed<string>(() => {
185
+ if (+sizeInMb.value > maxHardDisk.value) {
186
+ return localization.value.common.diskCapacitySpecifiedGreater
187
+ }
188
+
189
+ if (+sizeInMb.value <= 0) {
190
+ return localization.value.common.diskCapacityCannotZero
191
+ }
192
+
193
+ return ''
194
+ })
195
+
196
+ const hardDiskLocalAndApiErrorsTexts = computed<string>(() => {
197
+ const localError = hardDiskTypeErrorLocalText.value
198
+ const apiError = apiErrorLocal.value
199
+
200
+ let result = ''
201
+ if (localError && !apiError) result = localError
202
+ if (!localError && apiError) result = apiError
203
+ if (localError && apiError) result = localError + ', ' + apiError
204
+ if (!localError && apiError) result = apiError
205
+
206
+ return result
207
+ })
208
+
209
+ const deleteFilesFromDatastore = ref<boolean>(false)
210
+
211
+ const hardDiskType = ref<string>('gb')
212
+ const hardDiskTypeOptions = ref<UI_I_OptionItem[]>(
213
+ binaryOptionsFunc(localization.value)
214
+ )
215
+
216
+ const size = ref<number>(props.hardDisk.size) // Изначально всегда приходит в gb
217
+ const sizeInMb = computed<number>(() => {
218
+ if (hardDiskType.value === 'mb') {
219
+ return size.value
220
+ }
221
+
222
+ return $binary.universalFromTo(size.value, hardDiskType.value, 'mb')
223
+ })
224
+ const onValidateSize = (): void => {
225
+ if (props.type !== 'edit') return
226
+ if (sizeInMb.value < props.hardDisk.size) {
227
+ size.value = $binary.universalFromTo(
228
+ props.hardDisk.size,
229
+ 'mb',
230
+ hardDiskType.value
231
+ )
232
+ }
233
+ }
234
+
235
+ const isDisabledSize = computed<boolean>(() => {
236
+ return props.type === 'exist' || (props.type === 'edit' && readOnly.value)
237
+ })
238
+
239
+ const location = ref<UI_I_DatastoreTableItem | null>(props.storage || null)
240
+ const storage = ref<UI_I_DatastoreTableItem | null>(props.storage)
241
+ watch(
242
+ () => props.storage,
243
+ (newValue) => {
244
+ location.value = newValue
245
+ storage.value = newValue
246
+ },
247
+ {
248
+ immediate: true,
249
+ deep: true,
250
+ }
251
+ )
252
+ const onChangeStorage = (item: UI_I_DatastoreTableItem): void => {
253
+ storage.value = item
254
+ }
255
+
256
+ const diskProvisioning = ref<string>('thick')
257
+ const sharing = ref<string>('')
258
+ const shares = ref<number>(0)
259
+
260
+ const limitIops = ref<number>(16)
261
+ const limitIopsType = ref<string>('unlimited')
262
+ const limitIopsInvalid = ref<boolean>(false)
263
+
264
+ const diskMode = ref<string>('dependent')
265
+
266
+ const cache = ref<string>('none')
267
+
268
+ const bus = ref<string>('ide')
269
+
270
+ const readOnly = ref<boolean>(false)
271
+
272
+ const discard = ref<string>('')
273
+
274
+ const io = ref<string>('')
275
+
276
+ const target = ref<string>('')
277
+
278
+ watch(
279
+ [
280
+ sizeInMb,
281
+ storage,
282
+ diskProvisioning,
283
+ sharing,
284
+ limitIops,
285
+ limitIopsType,
286
+ diskMode,
287
+ cache,
288
+ bus,
289
+ deleteFilesFromDatastore,
290
+ (): void => props.type,
291
+ ],
292
+ () => {
293
+ const limitIopsLocal =
294
+ limitIopsType.value === 'unlimited' ? 0 : limitIops.value
295
+ const storageLocal: UI_I_SendDataNewHardDiskStorage = {
296
+ id: storage.value?.id || '',
297
+ name: storage.value?.name || '',
298
+ type: storage.value?.type_text || '',
299
+ pool: storage.value?.pool_name || '',
300
+ user: '',
301
+ endpoint: '',
302
+ password: '',
303
+ protocol: '',
304
+ options: '',
305
+ }
306
+
307
+ emits('send-data', {
308
+ create: props.hardDisk.create,
309
+ attach: props.hardDisk.attach,
310
+ source: props.hardDisk.source,
311
+ size: Math.ceil(sizeInMb.value),
312
+ bus: bus.value,
313
+ target: target.value,
314
+ storage: storageLocal,
315
+ device_type: 'disk',
316
+ provision_type: diskProvisioning.value,
317
+ disk_mode: diskMode.value,
318
+ sharing: sharing.value === 'yes',
319
+ read_only: readOnly.value,
320
+ shares: shares.value,
321
+ cache: cache.value,
322
+ io: io.value,
323
+ limit_iops: limitIopsLocal,
324
+ discard: discard.value,
325
+ capacity: Math.ceil(sizeInMb.value),
326
+ boot_order: props.hardDisk.boot_order,
327
+ detach: props.type === 'removed',
328
+ remove: props.type === 'removed' && deleteFilesFromDatastore.value, // Проверяем если удалили диск и указали Delete files from datastore
329
+ })
330
+ },
331
+ { immediate: true }
332
+ )
333
+
334
+ // Добавляем данные для редактирования
335
+ watch(
336
+ () => props.hardDisk,
337
+ (newValue) => {
338
+ // TODO refactoring
339
+ if (props.type === 'exist') {
340
+ diskProvisioning.value = newValue.provision_type || 'thick'
341
+ return
342
+ }
343
+ // if (props.type !== 'edit') return
344
+ if (props.type !== 'edit' && props.type !== 'clone') return
345
+
346
+ const sizeInGb = $binary.mbToGb(newValue.size)
347
+ if (sizeInGb < 1) {
348
+ size.value = newValue.size
349
+ hardDiskType.value = 'mb'
350
+ } else {
351
+ size.value = sizeInGb
352
+ hardDiskType.value = 'gb'
353
+ }
354
+ diskProvisioning.value = newValue.provision_type || 'thick'
355
+ sharing.value = newValue.sharing ? 'yes' : ''
356
+ shares.value = newValue.shares || 0
357
+ // limitIopsType.value = newValue.io === 'native' ? 'unlimited' : 'custom'
358
+ limitIopsType.value = newValue.limit_iops === 0 ? 'unlimited' : 'custom'
359
+ limitIops.value = newValue.limit_iops || 16
360
+ diskMode.value = newValue.disk_mode || 'dependent'
361
+ cache.value = newValue.cache || 'none'
362
+ bus.value = newValue.bus || 'ide'
363
+ readOnly.value = newValue.read_only || false
364
+ discard.value = newValue.discard || ''
365
+ io.value = newValue.io || ''
366
+ target.value = newValue.target || ''
367
+ },
368
+ { immediate: true }
369
+ )
370
+ watch(
371
+ isRunning,
372
+ (newValue) => {
373
+ if (newValue && props.type === 'new') {
374
+ bus.value = 'virtio'
375
+ }
376
+ },
377
+ { immediate: true }
378
+ )
379
+
380
+ const hardDiskInvalid = computed<boolean>(() => {
381
+ return !!hardDiskTypeErrorLocalText.value || limitIopsInvalid.value
382
+ })
383
+ watch(
384
+ hardDiskInvalid,
385
+ (newValue) => {
386
+ emits('invalid', newValue)
387
+ },
388
+ { immediate: true }
389
+ )
390
+ </script>
391
+
392
+ <style scoped lang="scss"></style>