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,10 +1,10 @@
1
1
  <template>
2
2
  <ui-stack-block
3
- :has-children="true"
4
3
  :is-roll-back="props.type === 'removed'"
5
4
  :removable="props.isRemovable"
6
5
  :test-id="`hard-disk-stack-block-${props.index}`"
7
6
  :class="props.type"
7
+ has-children
8
8
  is-toggle-on-stack-view-key
9
9
  @remove="emits('remove')"
10
10
  @roll-back="emits('roll-back')"
@@ -152,9 +152,9 @@
152
152
  :disabled="!props.isNewHardDisk && props.isRunning"
153
153
  :help-text="localization.common.busVirtioHelpDesc"
154
154
  :test-id="`vm-wizard-disk-bus-field-${props.index}`"
155
- component-type="disk_devices"
156
155
  :guest-machine-type="props.guestMachineType"
157
156
  :compute-resource="props.computeResource"
157
+ component-type="disk_devices"
158
158
  @remove-error-by-title="emits('remove-error-by-title', $event)"
159
159
  />
160
160
  </template>
@@ -190,31 +190,38 @@ const diskMode = defineModel<string>('diskMode', { required: true })
190
190
  const cache = defineModel<string>('cache', { required: true })
191
191
  const bus = defineModel<string>('bus', { required: true })
192
192
 
193
- const props = defineProps<{
194
- isRemovable: boolean
195
- label: string
196
- hardDiskInvalid: boolean
197
- disabled: boolean
198
- errorText: string
199
- hardDiskTypeErrorLocalText: string
200
- isDisabledSize: boolean
201
- hardDiskTypeOptions: UI_I_OptionItem[]
202
- maxHardDisk: number
203
- location: UI_I_DatastoreTableItem | null
204
- isRunning: boolean
205
- isNewHardDisk: boolean
206
- isEdit: boolean
207
- datastore: UI_I_DatastoreTableItem[]
208
- isDatastoreLoading: boolean
209
- getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
210
- errorValidationFields: UI_I_ErrorValidationField<string>[]
211
- index: number
212
- type: UI_T_HardDiskType
213
- hardDisk: UI_I_SendDataNewHardDisk
214
- guestMachineType?: UI_I_OptionItem | null
215
- isNewType?: boolean
216
- computeResource?: UI_I_TreeNode | null
217
- }>()
193
+ const props = withDefaults(
194
+ defineProps<{
195
+ isRemovable: boolean
196
+ label: string
197
+ hardDiskInvalid: boolean
198
+ disabled: boolean
199
+ errorText: string
200
+ hardDiskTypeErrorLocalText: string
201
+ isDisabledSize: boolean
202
+ hardDiskTypeOptions: UI_I_OptionItem[]
203
+ maxHardDisk: number
204
+ location: UI_I_DatastoreTableItem | null
205
+ isRunning: boolean
206
+ isNewHardDisk: boolean
207
+ isEdit: boolean
208
+ datastore: UI_I_DatastoreTableItem[]
209
+ isDatastoreLoading: boolean
210
+ getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
211
+ errorValidationFields: UI_I_ErrorValidationField<string>[]
212
+ index: number
213
+ type: UI_T_HardDiskType
214
+ hardDisk: UI_I_SendDataNewHardDisk
215
+ guestMachineType?: UI_I_OptionItem | null
216
+ isNewType?: boolean
217
+ computeResource?: UI_I_TreeNode | null
218
+ }>(),
219
+ {
220
+ guestMachineType: undefined,
221
+ isNewType: undefined,
222
+ computeResource: undefined,
223
+ }
224
+ )
218
225
  const emits = defineEmits<{
219
226
  (event: 'remove'): void
220
227
  (event: 'roll-back'): void
@@ -227,20 +234,8 @@ const localization = computed<UI_I_Localization>(() => useLocal())
227
234
  </script>
228
235
 
229
236
  <style>
230
- :root {
231
- --device-will-removed-color: #9da6ad;
232
- --device-will-removed-border-color: #e9ebeda3;
233
- }
234
- :root.dark-theme {
235
- --device-will-removed-color: #9da6ad;
236
- --device-will-removed-border-color: #e9ebed1f;
237
- }
238
-
239
237
  .light-theme {
240
238
  .stack-block-expanded {
241
- --device-will-removed-color: #9da6ad;
242
- --device-will-removed-border-color: #e9ebed1f;
243
-
244
239
  .ui-custom-checkbox {
245
240
  background-color: transparent;
246
241
  }
@@ -248,9 +243,6 @@ const localization = computed<UI_I_Localization>(() => useLocal())
248
243
  }
249
244
  .dark-theme {
250
245
  .stack-block-expanded {
251
- --device-will-removed-color: #9da6ad;
252
- --device-will-removed-border-color: #d3d6da66;
253
-
254
246
  .ui-custom-checkbox {
255
247
  background-color: transparent;
256
248
  }
@@ -32,21 +32,21 @@
32
32
  <span>{{ localization.common.deviceWillRemoved }}</span>
33
33
  <div class="flex-align-center" @click.stop>
34
34
  <input
35
- :id="`hard-disk-delete-files-from-datastore-${props.index}`"
36
- v-model="deleteFilesFromDatastore"
37
- :data-id="`hard-disk-delete-files-from-datastore-${props.index}`"
38
- :disabled="props.disabled"
39
- type="checkbox"
40
- class="cursor-pointer"
41
- @click.stop
35
+ :id="`hard-disk-delete-files-from-datastore-${props.index}`"
36
+ v-model="deleteFilesFromDatastore"
37
+ :data-id="`hard-disk-delete-files-from-datastore-${props.index}`"
38
+ :disabled="props.disabled"
39
+ type="checkbox"
40
+ class="cursor-pointer"
41
+ @click.stop
42
42
  />
43
43
  <label
44
- :for="`hard-disk-delete-files-from-datastore-${props.index}`"
45
- :class="[
46
- 'label-text-normal cursor-pointer',
47
- props.disabled && 'div-disabled',
48
- ]"
49
- >{{ localization.common.deleteFilesFromDatastore }}</label
44
+ :for="`hard-disk-delete-files-from-datastore-${props.index}`"
45
+ :class="[
46
+ 'label-text-normal cursor-pointer',
47
+ props.disabled && 'div-disabled',
48
+ ]"
49
+ >{{ localization.common.deleteFilesFromDatastore }}</label
50
50
  >
51
51
  </div>
52
52
  </div>
@@ -71,7 +71,10 @@
71
71
  'spinfree edit-setting-input input-text-color',
72
72
  { 'has-error': props.hardDiskTypeErrorLocalText },
73
73
  ]"
74
- :disabled="props.isDisabledSize || props.isRunning && diskProvisioning === 'thick'"
74
+ :disabled="
75
+ props.isDisabledSize ||
76
+ (props.isRunning && diskProvisioning === 'thick')
77
+ "
75
78
  type="number"
76
79
  @blur="emits('validate-size')"
77
80
  @click.stop
@@ -166,9 +169,9 @@
166
169
  :disabled="!props.isNewHardDisk && props.isRunning"
167
170
  :help-text="localization.common.busVirtioHelpDesc"
168
171
  :test-id="`vm-wizard-disk-bus-field-${props.index}`"
169
- component-type="disk_devices"
170
172
  :guest-machine-type="props.guestMachineType"
171
173
  :compute-resource="props.computeResource"
174
+ component-type="disk_devices"
172
175
  @remove-error-by-title="emits('remove-error-by-title', $event)"
173
176
  />
174
177
  </template>
@@ -205,31 +208,38 @@ const diskMode = defineModel<string>('diskMode', { required: true })
205
208
  const cache = defineModel<string>('cache', { required: true })
206
209
  const bus = defineModel<string>('bus', { required: true })
207
210
 
208
- const props = defineProps<{
209
- isRemovable: boolean
210
- label: string
211
- hardDiskInvalid: boolean
212
- disabled: boolean
213
- errorText: string
214
- hardDiskTypeErrorLocalText: string
215
- isDisabledSize: boolean
216
- hardDiskTypeOptions: UI_I_OptionItem[]
217
- maxHardDisk: number
218
- location: UI_I_DatastoreTableItem | null
219
- isRunning: boolean
220
- isNewHardDisk: boolean
221
- isEdit: boolean
222
- datastore: UI_I_DatastoreTableItem[]
223
- isDatastoreLoading: boolean
224
- getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
225
- errorValidationFields: UI_I_ErrorValidationField<string>[]
226
- index: number
227
- type: UI_T_HardDiskType
228
- hardDisk: UI_I_SendDataNewHardDisk
229
- guestMachineType?: UI_I_OptionItem | null
230
- isNewType?: boolean
231
- computeResource?: UI_I_TreeNode | null
232
- }>()
211
+ const props = withDefaults(
212
+ defineProps<{
213
+ isRemovable: boolean
214
+ label: string
215
+ hardDiskInvalid: boolean
216
+ disabled: boolean
217
+ errorText: string
218
+ hardDiskTypeErrorLocalText: string
219
+ isDisabledSize: boolean
220
+ hardDiskTypeOptions: UI_I_OptionItem[]
221
+ maxHardDisk: number
222
+ location: UI_I_DatastoreTableItem | null
223
+ isRunning: boolean
224
+ isNewHardDisk: boolean
225
+ isEdit: boolean
226
+ datastore: UI_I_DatastoreTableItem[]
227
+ isDatastoreLoading: boolean
228
+ getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
229
+ errorValidationFields: UI_I_ErrorValidationField<string>[]
230
+ index: number
231
+ type: UI_T_HardDiskType
232
+ hardDisk: UI_I_SendDataNewHardDisk
233
+ guestMachineType?: UI_I_OptionItem | null
234
+ isNewType?: boolean
235
+ computeResource?: UI_I_TreeNode | null
236
+ }>(),
237
+ {
238
+ guestMachineType: undefined,
239
+ isNewType: undefined,
240
+ computeResource: undefined,
241
+ }
242
+ )
233
243
  const emits = defineEmits<{
234
244
  (event: 'remove'): void
235
245
  (event: 'roll-back'): void
@@ -21,11 +21,9 @@
21
21
 
22
22
  <script setup lang="ts">
23
23
  import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
24
- import type {UI_I_Localization} from "~/lib/models/interfaces";
25
- import {
26
- cacheOptionsFunc
27
- } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/cache/lib/config/options'
28
- import type {UI_I_OptionItem} from "~/components/atoms/lib/models/interfaces";
24
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
25
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
26
+ import { cacheOptionsFunc } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/cache/lib/config/options'
29
27
 
30
28
  const cache = defineModel<string>('cache')
31
29
 
@@ -53,7 +51,9 @@ const apiError = computed<string>(() => {
53
51
  )
54
52
  })
55
53
 
56
- const cacheOptions = computed<UI_I_OptionItem[]>(() => cacheOptionsFunc(localization.value))
54
+ const cacheOptions = computed<UI_I_OptionItem[]>(() =>
55
+ cacheOptionsFunc(localization.value)
56
+ )
57
57
 
58
58
  const onRemoveValidationError = (): void => {
59
59
  emits('remove-error-by-title', typeError.value)
@@ -21,14 +21,6 @@ const props = defineProps<{
21
21
  }>()
22
22
  </script>
23
23
 
24
- <style>
25
- :root {
26
- --vm-wizard-file-path-color: #182531;
27
- }
28
- :root.dark-theme {
29
- --vm-wizard-file-path-color: #e9eaec;
30
- }
31
- </style>
32
24
  <style scoped>
33
25
  .limit-title {
34
26
  margin-right: 12px;
@@ -14,11 +14,11 @@
14
14
  <script setup lang="ts">
15
15
  import type { UI_I_Localization } from '~/lib/models/interfaces'
16
16
 
17
- const localization = computed<UI_I_Localization>(() => useLocal())
18
-
19
17
  const props = defineProps<{
20
18
  path: string
21
19
  }>()
20
+
21
+ const localization = computed<UI_I_Localization>(() => useLocal())
22
22
  </script>
23
23
 
24
24
  <style scoped></style>
@@ -32,6 +32,8 @@ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
32
32
  import {
33
33
  limitIopsOptionsFunc,
34
34
  limitIopsTypeOptionsFunc,
35
+ maxLimitIops,
36
+ minLimitIops,
35
37
  } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/limitIops/lib/config/options'
36
38
 
37
39
  const limitIops = defineModel<number>('limitIops')
@@ -56,8 +58,6 @@ const limitIopsTypeOptions = ref<UI_I_OptionItem[]>(
56
58
  limitIopsTypeOptionsFunc(localization.value)
57
59
  )
58
60
 
59
- const minLimitIops = 16
60
- const maxLimitIops = 2_147_483_647
61
61
  const limitIopsOptions = ref<UI_I_OptionItem[]>(
62
62
  limitIopsOptionsFunc(localization.value, minLimitIops, maxLimitIops)
63
63
  )
@@ -26,3 +26,7 @@ export const limitIopsOptionsFunc = (
26
26
  },
27
27
  ]
28
28
  }
29
+
30
+ export const minLimitIops = 16
31
+
32
+ export const maxLimitIops = 2_147_483_647
@@ -1,154 +1,154 @@
1
- <template>
2
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-location-new
3
- v-if="isNewView"
4
- v-model:selected-location="selectedLocation"
5
- :index="props.index"
6
- :datastore="props.datastore"
7
- :is-datastore-loading="props.isDatastoreLoading"
8
- :get-datastore-table-func="props.getDatastoreTableFunc"
9
- :api-error="apiError"
10
- :location-options="locationOptions"
11
- :storage-modal-is-show="storageModalIsShow"
12
- :storage-submit="storageSubmit"
13
- @change-location="onChangeLocation"
14
- @change-storage="onChangeStorage"
15
- @hide-storage-modal="onHideStorageModal"
16
- @submit-storage-modal="onSubmitStorageModal"
17
- @remove-validation-error="onRemoveValidationError"
18
- />
19
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-location-old
20
- v-else
21
- v-model:selected-location="selectedLocation"
22
- :index="props.index"
23
- :datastore="props.datastore"
24
- :is-datastore-loading="props.isDatastoreLoading"
25
- :get-datastore-table-func="props.getDatastoreTableFunc"
26
- :api-error="apiError"
27
- :location-options="locationOptions"
28
- :storage-modal-is-show="storageModalIsShow"
29
- :storage-submit="storageSubmit"
30
- @change-location="onChangeLocation"
31
- @change-storage="onChangeStorage"
32
- @hide-storage-modal="onHideStorageModal"
33
- @submit-storage-modal="onSubmitStorageModal"
34
- @remove-validation-error="onRemoveValidationError"
35
- />
36
- </template>
37
-
38
- <script setup lang="ts">
39
- import type {
40
- UI_I_HTMLSelectElement,
41
- UI_I_Localization,
42
- } from '~/lib/models/interfaces'
43
- import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
44
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
45
- import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
46
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
47
-
48
- const props = defineProps<{
49
- location: UI_I_DatastoreTableItem | null
50
- index: number
51
- errorValidationFields: UI_I_ErrorValidationField[]
52
- datastore: UI_I_DatastoreTableItem[]
53
- isDatastoreLoading: boolean
54
- getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
55
- }>()
56
- const emits = defineEmits<{
57
- (event: 'change', value: UI_I_DatastoreTableItem): void
58
- (event: 'remove-error-by-title', value: string): void
59
- }>()
60
-
61
- const { $store }: any = useNuxtApp()
62
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
63
-
64
- const localization = computed<UI_I_Localization>(() => useLocal())
65
-
66
- const selectedLocation = ref<string>(props.location?.id || '')
67
-
68
- const storages = ref<UI_I_DatastoreTableItem[]>([])
69
- const addStorage = (storage: UI_I_DatastoreTableItem): void => {
70
- const hasStorage = storages.value.some((item) => item.id === storage.id)
71
- if (hasStorage) {
72
- return
73
- }
74
-
75
- storages.value.push(storage)
76
- }
77
- const locationOptions = ref<UI_I_OptionItem[]>([])
78
-
79
- watch(
80
- () => props.location,
81
- (newValue) => {
82
- if (locationOptions.value.length || !newValue) {
83
- return
84
- }
85
-
86
- locationOptions.value = [
87
- {
88
- text: localization.value.common.storeWithVirtualMachine,
89
- value: newValue.id,
90
- },
91
- { text: `${localization.value.common.browse}...`, value: -1 },
92
- ]
93
- selectedLocation.value = newValue.id
94
- storages.value.push(newValue)
95
- addStorage(newValue)
96
- },
97
- { immediate: true }
98
- )
99
-
100
- const storageSubmit = ref<null | Function>(null)
101
- const onSubmitStorageModal = (): void => {
102
- storageSubmit.value = (_isValid: boolean): void => {
103
- storageSubmit.value = null
104
- }
105
- }
106
- const storageModalIsShow = ref<boolean>(false)
107
- const onHideStorageModal = (): void => {
108
- storageModalIsShow.value = false
109
- if (selectedLocation.value === -1)
110
- selectedLocation.value = locationOptions.value[0].value
111
- }
112
- const onChangeStorage = (storage: UI_I_DatastoreTableItem): void => {
113
- locationOptions.value = [
114
- locationOptions.value[0],
115
- { text: storage.name, value: storage.id },
116
- // @ts-ignore
117
- locationOptions.value.at(-1),
118
- ]
119
-
120
- selectedLocation.value = storage.id
121
- emits('change', storage)
122
- addStorage(storage)
123
- onHideStorageModal()
124
- }
125
- const onChangeLocation = (event: UI_I_HTMLSelectElement): void => {
126
- const value = +event.target.value
127
- if (value === -1) {
128
- storageModalIsShow.value = true
129
- return
130
- }
131
-
132
- selectedLocation.value = event.target.value
133
- const storage = storages.value.find((item) => item.id === event.target.value)
134
- storage && emits('change', storage)
135
- }
136
-
137
- const typeError = computed<string>(
138
- () => `disk_devices[${props.index}].location`
139
- )
140
-
141
- const apiError = computed<string>(() => {
142
- return (
143
- props.errorValidationFields?.find(
144
- (message) => message.field === typeError.value
145
- )?.error_message || ''
146
- )
147
- })
148
-
149
- const onRemoveValidationError = (): void => {
150
- emits('remove-error-by-title', typeError.value)
151
- }
152
- </script>
153
-
154
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-location-new
3
+ v-if="isNewView"
4
+ v-model:selected-location="selectedLocation"
5
+ :index="props.index"
6
+ :datastore="props.datastore"
7
+ :is-datastore-loading="props.isDatastoreLoading"
8
+ :get-datastore-table-func="props.getDatastoreTableFunc"
9
+ :api-error="apiError"
10
+ :location-options="locationOptions"
11
+ :storage-modal-is-show="storageModalIsShow"
12
+ :storage-submit="storageSubmit"
13
+ @change-location="onChangeLocation"
14
+ @change-storage="onChangeStorage"
15
+ @hide-storage-modal="onHideStorageModal"
16
+ @submit-storage-modal="onSubmitStorageModal"
17
+ @remove-validation-error="onRemoveValidationError"
18
+ />
19
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-location-old
20
+ v-else
21
+ v-model:selected-location="selectedLocation"
22
+ :index="props.index"
23
+ :datastore="props.datastore"
24
+ :is-datastore-loading="props.isDatastoreLoading"
25
+ :get-datastore-table-func="props.getDatastoreTableFunc"
26
+ :api-error="apiError"
27
+ :location-options="locationOptions"
28
+ :storage-modal-is-show="storageModalIsShow"
29
+ :storage-submit="storageSubmit"
30
+ @change-location="onChangeLocation"
31
+ @change-storage="onChangeStorage"
32
+ @hide-storage-modal="onHideStorageModal"
33
+ @submit-storage-modal="onSubmitStorageModal"
34
+ @remove-validation-error="onRemoveValidationError"
35
+ />
36
+ </template>
37
+
38
+ <script setup lang="ts">
39
+ import type {
40
+ UI_I_HTMLSelectElement,
41
+ UI_I_Localization,
42
+ } from '~/lib/models/interfaces'
43
+ import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
44
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
45
+ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
46
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
47
+
48
+ const props = defineProps<{
49
+ location: UI_I_DatastoreTableItem | null
50
+ index: number
51
+ errorValidationFields: UI_I_ErrorValidationField[]
52
+ datastore: UI_I_DatastoreTableItem[]
53
+ isDatastoreLoading: boolean
54
+ getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
55
+ }>()
56
+ const emits = defineEmits<{
57
+ (event: 'change', value: UI_I_DatastoreTableItem): void
58
+ (event: 'remove-error-by-title', value: string): void
59
+ }>()
60
+
61
+ const { $store }: any = useNuxtApp()
62
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
63
+
64
+ const localization = computed<UI_I_Localization>(() => useLocal())
65
+
66
+ const selectedLocation = ref<string>(props.location?.id || '')
67
+
68
+ const storages = ref<UI_I_DatastoreTableItem[]>([])
69
+ const addStorage = (storage: UI_I_DatastoreTableItem): void => {
70
+ const hasStorage = storages.value.some((item) => item.id === storage.id)
71
+ if (hasStorage) {
72
+ return
73
+ }
74
+
75
+ storages.value.push(storage)
76
+ }
77
+ const locationOptions = ref<UI_I_OptionItem[]>([])
78
+
79
+ watch(
80
+ () => props.location,
81
+ (newValue) => {
82
+ if (locationOptions.value.length || !newValue) {
83
+ return
84
+ }
85
+
86
+ locationOptions.value = [
87
+ {
88
+ text: localization.value.common.storeWithVirtualMachine,
89
+ value: newValue.id,
90
+ },
91
+ { text: `${localization.value.common.browse}...`, value: -1 },
92
+ ]
93
+ selectedLocation.value = newValue.id
94
+ storages.value.push(newValue)
95
+ addStorage(newValue)
96
+ },
97
+ { immediate: true }
98
+ )
99
+
100
+ const storageSubmit = ref<null | Function>(null)
101
+ const onSubmitStorageModal = (): void => {
102
+ storageSubmit.value = (_isValid: boolean): void => {
103
+ storageSubmit.value = null
104
+ }
105
+ }
106
+ const storageModalIsShow = ref<boolean>(false)
107
+ const onHideStorageModal = (): void => {
108
+ storageModalIsShow.value = false
109
+ if (selectedLocation.value === -1)
110
+ selectedLocation.value = locationOptions.value[0].value
111
+ }
112
+ const onChangeStorage = (storage: UI_I_DatastoreTableItem): void => {
113
+ locationOptions.value = [
114
+ locationOptions.value[0],
115
+ { text: storage.name, value: storage.id },
116
+ // @ts-ignore
117
+ locationOptions.value.at(-1),
118
+ ]
119
+
120
+ selectedLocation.value = storage.id
121
+ emits('change', storage)
122
+ addStorage(storage)
123
+ onHideStorageModal()
124
+ }
125
+ const onChangeLocation = (event: UI_I_HTMLSelectElement): void => {
126
+ const value = +event.target.value
127
+ if (value === -1) {
128
+ storageModalIsShow.value = true
129
+ return
130
+ }
131
+
132
+ selectedLocation.value = event.target.value
133
+ const storage = storages.value.find((item) => item.id === event.target.value)
134
+ storage && emits('change', storage)
135
+ }
136
+
137
+ const typeError = computed<string>(
138
+ () => `disk_devices[${props.index}].location`
139
+ )
140
+
141
+ const apiError = computed<string>(() => {
142
+ return (
143
+ props.errorValidationFields?.find(
144
+ (message) => message.field === typeError.value
145
+ )?.error_message || ''
146
+ )
147
+ })
148
+
149
+ const onRemoveValidationError = (): void => {
150
+ emits('remove-error-by-title', typeError.value)
151
+ }
152
+ </script>
153
+
154
+ <style scoped lang="scss"></style>