bfg-common 1.5.773 → 1.5.775

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 (322) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/assets/img/icons/icons-sprite-dark-1.svg +3 -2
  3. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  4. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  5. package/assets/img/icons/icons-sprite-light-1.svg +4 -3
  6. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  7. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  8. package/assets/localization/local_be.json +27 -165
  9. package/assets/localization/local_en.json +27 -165
  10. package/assets/localization/local_hy.json +26 -164
  11. package/assets/localization/local_kk.json +26 -164
  12. package/assets/localization/local_ru.json +33 -171
  13. package/assets/localization/local_zh.json +26 -164
  14. package/assets/scss/common/global.scss +5 -5
  15. package/assets/scss/common/icons/icons-1.scss +1 -1
  16. package/assets/scss/common/icons/icons-2.scss +0 -18
  17. package/assets/scss/common/theme.scss +0 -2
  18. package/assets/scss/components/auth.scss +5 -32
  19. package/components/atoms/TheIcon3.vue +50 -50
  20. package/components/atoms/collapse/CollapseNav.vue +170 -170
  21. package/components/atoms/dropdown/tree/Tree.vue +0 -2
  22. package/components/atoms/nav/NavBar.vue +0 -1
  23. package/components/atoms/perPage/PerPage.vue +58 -58
  24. package/components/atoms/switch/Switch.vue +1 -7
  25. package/components/atoms/table/dataGrid/DataGrid.vue +16 -17
  26. package/components/atoms/table/dataGrid/DataGridPagination.vue +97 -97
  27. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  28. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  29. package/components/atoms/wizard/Wizard.vue +1 -1
  30. package/components/common/backup/storage/actions/add/Old.vue +1 -22
  31. package/components/common/backup/storage/actions/add/lib/config/createDatastore.ts +1 -1
  32. package/components/common/backup/storage/actions/add/lib/utils.ts +51 -51
  33. package/components/common/backup/storage/actions/add/steps/typeMode/TypeModeOld.vue +48 -1
  34. package/components/common/backup/storage/actions/add/steps/typeMode/lib/config/typeOptions.ts +20 -20
  35. package/components/common/backup/storage/actions/delete/Delete.vue +15 -37
  36. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  37. package/components/common/diagramMain/Header.vue +0 -4
  38. package/components/common/diagramMain/lib/models/interfaces.ts +0 -2
  39. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  40. package/components/common/diagramMain/modals/viewSettings/info/Info.vue +1 -5
  41. package/components/common/diagramMain/modals/viewSettings/info/InfoOld.vue +0 -16
  42. package/components/common/diagramMain/port/Port.vue +580 -580
  43. package/components/common/graph/graphNew/EmptyBlock.vue +1 -2
  44. package/components/common/help/navbar/left/lib/utils/constructAccordion.ts +1 -2
  45. package/components/common/help/navbar/right/Right.vue +23 -86
  46. package/components/common/layout/theHeader/TheHeader.vue +81 -44
  47. package/components/common/layout/theHeader/{New.vue → TheHeaderNew.vue} +26 -14
  48. package/components/common/layout/theHeader/{Old.vue → TheHeaderOld.vue} +21 -13
  49. package/components/common/layout/theHeader/ThemeSwitch.vue +18 -8
  50. package/components/common/layout/theHeader/feedback/new/email/Email.vue +2 -2
  51. package/components/common/layout/theHeader/helpMenu/{about/About.vue → About.vue} +22 -12
  52. package/components/common/layout/theHeader/helpMenu/HelpMenu.vue +8 -6
  53. package/components/common/layout/theHeader/helpMenu/{about/New.vue → aboutNew/AboutNew.vue} +4 -5
  54. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -0
  55. package/components/common/layout/theHeader/helpMenu/{new/New.vue → helpMenuNew/HelpMenuNew.vue} +1 -1
  56. package/components/common/layout/theHeader/helpMenu/{new → helpMenuNew}/lib/config/dropMenu.ts +1 -1
  57. package/components/common/layout/theHeader/helpMenu/{old/Old.vue → helpMenuOld/HelpMenuOld.vue} +2 -2
  58. package/components/common/layout/theHeader/helpMenu/{old → helpMenuOld}/lib/config/dropMenu.ts +1 -1
  59. package/components/common/layout/theHeader/modals/reconnect/Reconnect.vue +11 -11
  60. package/components/common/layout/theHeader/modals/reconnect/{New.vue → ReconnectNew.vue} +1 -1
  61. package/components/common/layout/theHeader/modals/reconnect/{Old.vue → ReconnectOld.vue} +0 -2
  62. package/components/common/layout/theHeader/userMenu/UserMenu.vue +28 -21
  63. package/components/common/layout/theHeader/userMenu/modals/changePassword/ChangePassword.vue +21 -12
  64. package/components/common/layout/theHeader/userMenu/modals/changePassword/New.vue +43 -36
  65. package/components/common/layout/theHeader/userMenu/modals/changePassword/Old.vue +2 -0
  66. package/components/common/layout/theHeader/userMenu/modals/changePassword/lib/utils.ts +3 -3
  67. package/components/common/layout/theHeader/userMenu/modals/preferences/Preferences.vue +44 -19
  68. package/components/common/layout/theHeader/userMenu/modals/preferences/{New.vue → PreferencesNew.vue} +16 -24
  69. package/components/common/layout/theHeader/userMenu/modals/preferences/{Old.vue → PreferencesOld.vue} +18 -10
  70. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/ChangeLanguage.vue +18 -17
  71. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/{New.vue → ChangeLanguageNew.vue} +30 -6
  72. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/{Old.vue → ChangeLanguageOld.vue} +30 -5
  73. package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/DefaultConsole.vue +20 -8
  74. package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/{New.vue → DefaultConsoleNew.vue} +3 -3
  75. package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/{Old.vue → DefaultConsoleOld.vue} +2 -2
  76. package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/Inventory.vue +21 -7
  77. package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/{New.vue → InventoryNew.vue} +2 -3
  78. package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/{Old.vue → InventoryOld.vue} +2 -2
  79. package/components/common/layout/theHeader/userMenu/modals/preferences/lib/models/types.ts +7 -7
  80. package/components/common/layout/theHeader/userMenu/modals/preferences/security/New.vue +12 -277
  81. package/components/common/layout/theHeader/userMenu/modals/preferences/security/Old.vue +56 -30
  82. package/components/common/layout/theHeader/userMenu/modals/preferences/security/Security.vue +6 -65
  83. package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/TimeFormat.vue +22 -9
  84. package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/{New.vue → TimeFormatNew.vue} +3 -3
  85. package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/{Old.vue → TimeFormatOld.vue} +2 -2
  86. package/components/common/layout/theHeader/userMenu/modals/preferences/view/View.vue +22 -13
  87. package/components/common/layout/theHeader/userMenu/modals/preferences/view/{New.vue → ViewNew.vue} +3 -29
  88. package/components/common/layout/theHeader/userMenu/modals/preferences/view/{Old.vue → ViewOld.vue} +2 -21
  89. package/components/common/layout/theHeader/userMenu/{new/New.vue → userMenuNew/UserMenuNew.vue} +1 -1
  90. package/components/common/layout/theHeader/userMenu/{old/Old.vue → userMenuOld/UserMenuOld.vue} +2 -2
  91. package/components/common/layout/theHeader/userMenu/{old → userMenuOld}/lib/config/dropMenu.ts +1 -1
  92. package/components/common/monitor/advanced/graphView/GraphView.vue +0 -8
  93. package/components/common/monitor/advanced/tools/Tools.vue +1 -5
  94. package/components/common/monitor/overview/OverviewNew.vue +1 -1
  95. package/components/common/pages/backups/DetailView.vue +52 -52
  96. package/components/common/pages/backups/backupsNew/BackupsNew.vue +19 -107
  97. package/components/common/pages/backups/backupsNew/contextMenuView/ContextMenuView.vue +10 -16
  98. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  99. package/components/common/pages/backups/modals/Modals.vue +243 -243
  100. package/components/common/pages/backups/modals/createBackup/CreateBackup.vue +10 -6
  101. package/components/common/pages/backups/modals/createBackup/New.vue +9 -22
  102. package/components/common/pages/backups/modals/createBackup/Old.vue +10 -8
  103. package/components/common/pages/backups/modals/createBackup/configuration/ConfigurationNew.vue +3 -17
  104. package/components/common/pages/backups/modals/createBackup/configuration/backupWindow/BackupWindow.vue +29 -29
  105. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/MaxBandwidth.vue +69 -69
  106. package/components/common/pages/backups/modals/createBackup/configuration/strategy/Strategy.vue +38 -38
  107. package/components/common/pages/backups/modals/createBackup/datastores/Datastores.vue +0 -6
  108. package/components/common/pages/backups/modals/createBackup/datastores/DatastoresOld.vue +2 -22
  109. package/components/common/pages/backups/modals/createBackup/datastores/tableView/new/lib/config/table.ts +8 -8
  110. package/components/common/pages/backups/modals/createBackup/disks/Disks.vue +0 -6
  111. package/components/common/pages/backups/modals/createBackup/disks/DisksOld.vue +1 -22
  112. package/components/common/pages/backups/modals/createBackup/disks/tableView/new/TableView.vue +1 -1
  113. package/components/common/pages/backups/modals/createBackup/disks/tableView/new/lib/config/table.ts +7 -7
  114. package/components/common/pages/backups/modals/createBackup/general/General.vue +1 -7
  115. package/components/common/pages/backups/modals/createBackup/general/GeneralNew.vue +1 -1
  116. package/components/common/pages/backups/modals/createBackup/general/GeneralOld.vue +0 -17
  117. package/components/common/pages/backups/modals/createBackup/lib/config/readyToCompleteOptions.ts +5 -5
  118. package/components/common/pages/backups/modals/createBackup/lib/config/steps.ts +1 -1
  119. package/components/common/pages/backups/modals/createBackup/lib/config/strategyOptions.ts +2 -11
  120. package/components/common/pages/backups/modals/createBackup/lib/models/interfaces.ts +8 -8
  121. package/components/common/pages/backups/modals/createBackup/lib/validation/validations.ts +14 -6
  122. package/components/common/pages/backups/modals/deleteBackup/DeleteBackup.vue +0 -1
  123. package/components/common/pages/backups/modals/lib/config/restore.ts +0 -1
  124. package/components/common/pages/backups/modals/lib/models/interfaces.ts +1 -2
  125. package/components/common/pages/backups/modals/restore/Restore.vue +26 -25
  126. package/components/common/pages/backups/modals/restore/{Old.vue → RestoreOld.vue} +0 -5
  127. package/components/common/pages/backups/modals/restore/disks/Disks.vue +8 -26
  128. package/components/common/pages/backups/modals/restore/disks/DisksNew.vue +2 -2
  129. package/components/common/pages/backups/modals/restore/disks/DisksOld.vue +2 -2
  130. package/components/common/pages/backups/modals/restore/lib/config/readyToCompleteOptions.ts +14 -46
  131. package/components/common/pages/backups/modals/restore/lib/config/restoreCodes.ts +1 -1
  132. package/components/common/pages/backups/modals/restore/lib/config/steps.ts +20 -42
  133. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  134. package/components/common/pages/backups/modals/restore/types/Types.vue +3 -15
  135. package/components/common/pages/backups/modals/restore/types/{New.vue → TypesNew.vue} +11 -11
  136. package/components/common/pages/backups/modals/restore/types/{Old.vue → TypesOld.vue} +6 -7
  137. package/components/common/pages/backups/modals/restore/types/lib/config/descriptions.ts +0 -1
  138. package/components/common/pages/hardwareHealth/historyTestimony/tools/Tools.vue +2 -7
  139. package/components/common/pages/hardwareHealth/tableView/TableView.vue +0 -8
  140. package/components/common/pages/hardwareHealth/tableView/lib/config/sensorTable.ts +1 -13
  141. package/components/common/pages/hardwareHealth/toolsPanel/lib/config/actionsPanel.ts +4 -4
  142. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  143. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  144. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  145. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  146. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  147. package/components/common/pages/home/widgets/warnings/lib/config/config.ts +2 -2
  148. package/components/common/pages/home/widgets/warnings/table/lib/config/config.ts +2 -2
  149. package/components/common/pages/home/widgets/warnings/table/lib/models/enums.ts +12 -0
  150. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  151. package/components/common/pages/tasks/Tasks.vue +0 -3
  152. package/components/common/pages/tasks/table/Table.vue +1 -4
  153. package/components/common/pages/tasks/table/expandDetails/ExpandDetails.vue +1 -1
  154. package/components/common/pages/tasks/table/lib/config/config.ts +13 -22
  155. package/components/common/qrcode/Qrcode.vue +56 -0
  156. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  157. package/components/common/select/radio/RadioGroup.vue +137 -137
  158. package/components/common/selectLanguage/SelectLanguage.vue +5 -5
  159. package/components/common/spiceConsole/Drawer.vue +420 -420
  160. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  161. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  162. package/components/common/split/horizontal/New.vue +2 -0
  163. package/components/common/split/vertical/New.vue +1 -2
  164. package/components/common/tools/Actions.vue +207 -207
  165. package/components/common/treeView/TreeView.vue +52 -52
  166. package/components/common/vm/actions/add/New.vue +11 -13
  167. package/components/common/vm/actions/add/Old.vue +1 -1
  168. package/components/common/vm/actions/clone/lib/config/steps.ts +295 -295
  169. package/components/common/vm/actions/clone/new/New.vue +438 -438
  170. package/components/common/vm/actions/clone/old/Old.vue +0 -1
  171. package/components/common/vm/actions/common/customizeHardware/virtualHardware/New.vue +36 -12
  172. package/components/common/vm/actions/common/customizeHardware/virtualHardware/Old.vue +37 -15
  173. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +50 -50
  174. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/coresPerSocket/CoresPerSocket.vue +3 -3
  175. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  176. package/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces.ts +1 -3
  177. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +283 -283
  178. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +7 -13
  179. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/New.vue +4 -7
  180. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +45 -52
  181. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/Old.vue +8 -5
  182. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIo.vue +3 -1
  183. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/New.vue +2 -2
  184. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/Old.vue +2 -2
  185. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +1 -1
  186. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/New.vue +2 -1
  187. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/Old.vue +2 -1
  188. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/New.vue +1 -1
  189. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGrid.vue +1 -1
  190. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/Old.vue +1 -1
  191. package/components/common/vm/actions/common/customizeHardware/vmoptions/New.vue +2 -2
  192. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +156 -156
  193. package/components/common/vm/actions/common/select/compatibility/New.vue +1 -0
  194. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  195. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  196. package/components/common/vm/actions/common/select/options/New.vue +264 -264
  197. package/components/common/vm/actions/common/select/options/Old.vue +2 -1
  198. package/components/common/vm/actions/common/select/options/Options.vue +58 -58
  199. package/components/common/vm/actions/common/select/storage/Old.vue +125 -125
  200. package/components/common/vm/actions/common/select/storage/new/New.vue +1 -1
  201. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  202. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  203. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  204. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  205. package/components/common/wizards/common/compatibility/Compatibility.vue +35 -35
  206. package/components/common/wizards/common/compatibility/New.vue +1 -1
  207. package/components/common/wizards/common/compatibility/Old.vue +1 -1
  208. package/components/common/wizards/common/steps/computeResource/New.vue +1 -9
  209. package/components/common/wizards/common/steps/name/Name.vue +178 -178
  210. package/components/common/wizards/common/steps/name/New.vue +221 -221
  211. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  212. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  213. package/components/common/wizards/common/steps/name/location/New.vue +40 -40
  214. package/components/common/wizards/datastore/add/Add.vue +1 -0
  215. package/components/common/wizards/datastore/add/Old.vue +0 -16
  216. package/components/common/wizards/datastore/add/lib/config/createDatastore.ts +0 -1
  217. package/components/common/wizards/datastore/add/lib/models/interfaces.ts +0 -1
  218. package/components/common/wizards/datastore/add/lib/utils.ts +85 -85
  219. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceNew.vue +0 -5
  220. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceOld.vue +0 -5
  221. package/components/common/wizards/datastore/add/steps/nameAndDevice/table/old/Old.vue +3 -2
  222. package/components/common/wizards/datastore/add/steps/readyComplete/lib/config/propertiesDetails.ts +1 -8
  223. package/components/common/wizards/datastore/add/steps/typeMode/TypeModeOld.vue +48 -1
  224. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  225. package/components/common/wizards/network/add/Add.vue +5 -28
  226. package/components/common/wizards/network/add/lib/config/config.ts +1 -1
  227. package/components/common/wizards/network/add/lib/config/initialData.ts +3 -6
  228. package/components/common/wizards/network/add/lib/config/selectConnectionTypeStep.ts +0 -1
  229. package/components/common/wizards/network/add/steps/portProperties/PortProperties.vue +192 -192
  230. package/components/common/wizards/network/add/steps/selectTargetDevice/SelectTargetDeviceNew.vue +1 -2
  231. package/components/common/wizards/network/add/steps/selectTargetDevice/SelectTargetDeviceOld.vue +6 -18
  232. package/components/common/wizards/vm/migrate/lib/models/enums.ts +2 -2
  233. package/components/common/wizards/vm/migrate/steps/computeResource/tableView/old/lib/config/hostTable.ts +1 -1
  234. package/components/common/wizards/vm/migrate/steps/selectStorage/SelectStorage.vue +4 -4
  235. package/components/common/wizards/vm/migrate/steps/selectStorage/configure/disk/table/new/lib/config/diskTable.ts +2 -6
  236. package/components/common/wizards/vm/migrate/steps/selectStorage/configure/disk/table/old/lib/config/diskTable.ts +13 -29
  237. package/composables/deepCopy.ts +21 -0
  238. package/composables/useAppVersion.ts +21 -21
  239. package/composables/useEnvLanguage.ts +8 -7
  240. package/composables/useLocal.ts +6 -6
  241. package/composables/useLocalCommon.ts +39 -39
  242. package/composables/useUniqueId.ts +5 -0
  243. package/lib/config/regExp.ts +1 -1
  244. package/lib/models/enums.ts +0 -28
  245. package/lib/models/interfaces.ts +0 -2
  246. package/lib/models/types.ts +21 -20
  247. package/lib/utils/localizationMapper.ts +2 -1
  248. package/package.json +4 -3
  249. package/plugins/console.ts +21 -21
  250. package/plugins/date.ts +37 -14
  251. package/plugins/mouse.ts +21 -21
  252. package/plugins/panelStates.ts +70 -70
  253. package/plugins/text.ts +59 -59
  254. package/plugins/validation.ts +6 -6
  255. package/public/spice-console/application/clientgui.js +854 -854
  256. package/public/spice-console/application/packetfactory.js +211 -211
  257. package/public/spice-console/application/virtualmouse.js +147 -147
  258. package/public/spice-console/lib/images/bitmap.js +203 -203
  259. package/public/spice-console/network/spicechannel.js +440 -440
  260. package/public/spice-console/process/cursorprocess.js +128 -128
  261. package/public/spice-console/process/inputprocess.js +227 -227
  262. package/public/spice-console/process/mainprocess.js +212 -212
  263. package/public/spice-console/run.js +210 -210
  264. package/store/main/getters.ts +2 -2
  265. package/store/main/mutations.ts +7 -7
  266. package/store/main/state.ts +7 -7
  267. package/store/tasks/actions.ts +1 -1
  268. package/store/tasks/mappers/recentTasks.ts +123 -123
  269. package/store/tasks/mappers/tasks.ts +1 -8
  270. package/store/tasks/mutations.ts +82 -82
  271. package/components/common/backup/storage/actions/add/steps/typeMode/tooltip/Tooltip.vue +0 -33
  272. package/components/common/certificate/Certificate.vue +0 -27
  273. package/components/common/certificate/CertificateInfo.vue +0 -139
  274. package/components/common/certificate/Tools.vue +0 -59
  275. package/components/common/certificate/lib/config/tabsPannel.ts +0 -22
  276. package/components/common/certificate/lib/models/interfaces.ts +0 -9
  277. package/components/common/certificate/lib/models/types.ts +0 -1
  278. package/components/common/certificate/modals/renew/New.vue +0 -64
  279. package/components/common/certificate/modals/renew/Old.vue +0 -122
  280. package/components/common/certificate/modals/renew/Renew.vue +0 -67
  281. package/components/common/layout/console/Console.vue +0 -70
  282. package/components/common/layout/console/lib/models/interfaces.ts +0 -10
  283. package/components/common/layout/theHeader/helpMenu/about/Old.vue +0 -78
  284. package/components/common/pages/auth/TheFooter.vue +0 -104
  285. package/components/common/pages/backups/backupsNew/Skeleton.vue +0 -136
  286. package/components/common/pages/files/lib/models/enums.ts +0 -36
  287. package/components/common/pages/tasks/table/lib/models/interfaces.ts +0 -9
  288. package/components/common/qr/Qr.vue +0 -69
  289. package/components/common/vm/snapshots/DetailView.vue +0 -90
  290. package/components/common/vm/snapshots/Old.vue +0 -71
  291. package/components/common/vm/snapshots/Snapshots.vue +0 -82
  292. package/components/common/vm/snapshots/lib/models/interfaces.ts +0 -5
  293. package/components/common/vm/snapshots/lib/models/types.ts +0 -11
  294. package/components/common/vm/snapshots/modals/confirm/Confirm.vue +0 -48
  295. package/components/common/vm/snapshots/modals/confirm/New.vue +0 -128
  296. package/components/common/vm/snapshots/modals/confirm/Old.vue +0 -140
  297. package/components/common/vm/snapshots/modals/confirm/lib/models/enums.ts +0 -19
  298. package/components/common/vm/snapshots/modals/lib/config/modalTexts.ts +0 -30
  299. package/components/common/vm/snapshots/modals/takeOrEdit/Old.vue +0 -220
  300. package/components/common/vm/snapshots/modals/takeOrEdit/TakeOrEdit.vue +0 -51
  301. package/components/common/vm/snapshots/modals/takeOrEdit/new/New.vue +0 -184
  302. package/components/common/vm/snapshots/modals/takeOrEdit/new/lib/utils/getSnapshotsName.ts +0 -15
  303. package/components/common/vm/snapshots/new/New.vue +0 -471
  304. package/components/common/vm/snapshots/new/Skeleton.vue +0 -136
  305. package/components/common/vm/snapshots/new/contextMenuView/ContextMenuView.vue +0 -103
  306. package/components/common/vm/snapshots/new/contextMenuView/lib/config/contextMenuItems.ts +0 -34
  307. package/components/common/vm/snapshots/new/lib/models/interfaces.ts +0 -12
  308. package/components/common/vm/snapshots/new/lib/utils/contextMenu.ts +0 -29
  309. package/components/common/vm/snapshots/new/lib/utils/details.ts +0 -48
  310. package/components/common/vm/snapshots/tools/Tools.vue +0 -56
  311. package/components/common/vm/snapshots/tools/lib/config/tabsPannel.ts +0 -39
  312. package/components/common/wizards/datastore/add/steps/nameAndDevice/advancedOptions/AdvancedOptions.vue +0 -43
  313. package/components/common/wizards/datastore/add/steps/nameAndDevice/advancedOptions/New.vue +0 -114
  314. package/components/common/wizards/datastore/add/steps/nameAndDevice/advancedOptions/Old.vue +0 -114
  315. package/components/common/wizards/datastore/add/steps/typeMode/tooltip/Tooltip.vue +0 -33
  316. package/composables/useBrowse.ts +0 -24
  317. package/lib/models/composables/useBrowse/interfaces.ts +0 -4
  318. package/store/inventory/modules/snapshots/lib/models/interfaces.ts +0 -45
  319. /package/components/common/layout/theHeader/helpMenu/{old → helpMenuOld}/lib/models/types.ts +0 -0
  320. /package/components/common/layout/theHeader/userMenu/{new → userMenuNew}/lib/config/dropMenu.ts +0 -0
  321. /package/components/common/layout/theHeader/userMenu/{old → userMenuOld}/lib/models/types.ts +0 -0
  322. /package/components/common/pages/backups/modals/restore/{New.vue → RestoreNew.vue} +0 -0
@@ -1,438 +1,438 @@
1
- <template>
2
- <ui-wizard
3
- :steps="props.wizard.steps"
4
- :selected-scheme="props.selectedScheme"
5
- :is-loading="props.wizard.wizardLoader.status"
6
- :title="props.title"
7
- :texts="texts"
8
- test-id="clone-exist-vm"
9
- show
10
- @change-steps="onChangeSteps"
11
- @hide="onHideModal"
12
- @submit="onClone"
13
- >
14
- <template #content="{ selectedStep }">
15
- <ui-wizard-block
16
- v-if="selectedStep.id === props.dynamicSteps.scheduledTasks"
17
- :sub-title-height="height0"
18
- >
19
- <template #subTitle>
20
- <div ref="subTitleBlock0">
21
- <div class="subtitle-block flex flex-col">
22
- <ui-wizard-subtitle :sub-title="selectedStep.subTitle" />
23
- </div>
24
- </div>
25
- </template>
26
- <template #content>
27
- <common-pages-scheduled-tasks-modals-common-new-task-form
28
- v-model="schedulerTaskForm"
29
- :target="props.selectedVirtualMachine"
30
- class="new-task-form"
31
- />
32
- </template>
33
- </ui-wizard-block>
34
-
35
- <ui-wizard-block
36
- v-if="
37
- selectedStep.id === props.dynamicSteps.selectName ||
38
- selectedStep.id === props.dynamicSteps.selectNameFolder
39
- "
40
- :sub-title-height="height1"
41
- >
42
- <template #subTitle>
43
- <div ref="subTitleBlock1">
44
- <div class="subtitle-block flex flex-col">
45
- <div
46
- id="name-alert-wrapper"
47
- :class="[{ 'mb-4': !isNameAlertWrapperEmpty }]"
48
- ></div>
49
- <ui-wizard-subtitle :sub-title="selectNameStepSubtitle" />
50
- </div>
51
- </div>
52
- </template>
53
- <template #content>
54
- <common-wizards-common-steps-name
55
- v-model:name="model.name"
56
- v-model:location="location"
57
- :show="
58
- selectedStep.id === props.dynamicSteps.selectName ||
59
- selectedStep.id === props.dynamicSteps.selectNameFolder
60
- "
61
- :name-form-submit="props.nameFormSubmit"
62
- :name-request-url="props.nameRequestUrl"
63
- :has-location="props.project === 'sphere'"
64
- :location-nodes="props.locationNodes"
65
- :allowed-location-kinds="props.allowedLocationKinds"
66
- :location-description="props.locationDescription"
67
- :validation-description="
68
- localization.common.enterValidLocationVirtualMachine
69
- "
70
- :name-exist-validation-description="
71
- localization.common.vmNameExistInSelectedLocation
72
- "
73
- :test-ids="props.nameTestIds"
74
- @submit="emits('change-name', $event)"
75
- @has-errors="isNameAlertWrapperEmpty = $event"
76
- />
77
- </template>
78
- </ui-wizard-block>
79
-
80
- <ui-wizard-block
81
- v-if="selectedStep.id === props.dynamicSteps.selectStorage"
82
- :sub-title-height="height2"
83
- >
84
- <template #subTitle>
85
- <div ref="subTitleBlock2">
86
- <div class="subtitle-block flex flex-col">
87
- <ui-wizard-subtitle
88
- :sub-title="
89
- localization.common.selectStorageConfigurationDiskFiles2
90
- "
91
- />
92
- </div>
93
- </div>
94
- </template>
95
- <template #content>
96
- <common-vm-actions-common-select-storage
97
- :storage-submit="props.storageSubmit"
98
- :datastore="props.datastore"
99
- :is-datastore-loading="props.isDatastoreLoading"
100
- :storage="model.storage"
101
- :get-datastore-table-func="props.getDatastoreTableFunc"
102
- hide-alert
103
- @change-storage="emits('change-storage', $event)"
104
- />
105
- </template>
106
- </ui-wizard-block>
107
-
108
- <ui-wizard-block
109
- v-if="selectedStep.id === props.dynamicSteps.selectOptions"
110
- :sub-title-height="height3"
111
- >
112
- <template #subTitle>
113
- <div ref="subTitleBlock3">
114
- <div class="subtitle-block flex flex-col">
115
- <ui-wizard-subtitle
116
- :sub-title="localization.vmWizard.selectAdvancedOptionsCloning"
117
- />
118
- </div>
119
- </div>
120
- </template>
121
- <template #content>
122
- <common-vm-actions-common-select-options
123
- :is-new-vm-from-template="props.isNewVmFromTemplate"
124
- :project="props.project"
125
- @change="emits('change-select-options', $event)"
126
- @change-count="emits('change-clone-count', $event)"
127
- />
128
- </template>
129
- </ui-wizard-block>
130
-
131
- <ui-wizard-block
132
- v-if="selectedStep.id === props.dynamicSteps.selectGuestOSMachineType"
133
- :sub-title-height="height4"
134
- >
135
- <template #subTitle>
136
- <div ref="subTitleBlock4">
137
- <div class="subtitle-block flex flex-col">
138
- <ui-wizard-subtitle
139
- :sub-title="
140
- localization.common
141
- .chooseGuestOSInstalledVmAndMachineTypeUsedCreateVm
142
- "
143
- />
144
- </div>
145
- </div>
146
- </template>
147
- <template #content>
148
- <common-vm-actions-common-select-os
149
- v-model:guest-os-family="model.guest_os_family"
150
- v-model:guest-os-version="model.guest_os_version"
151
- v-model:machine-type="model.machine_type"
152
- :families-options="props.guestOsFamilies"
153
- :versions-options="props.guestOsVersions"
154
- :machine-types-options="props.machineTypes"
155
- :error-validation-fields="props.errorValidationFields"
156
- @remove-error-by-title="emits('remove-error-by-title', $event)"
157
- />
158
- </template>
159
- </ui-wizard-block>
160
-
161
- <ui-wizard-block
162
- v-if="selectedStep.id === props.dynamicSteps.customizeHardware"
163
- >
164
- <template #content>
165
- <common-vm-actions-common-customize-hardware
166
- v-model="model"
167
- :storage="model.storage"
168
- :customize-hardware-submit="props.customizeHardwareSubmit"
169
- :max-memory="props.maxMemory"
170
- :cpu-models="props.cpuModels"
171
- :selected-nav-item="props.selectedNavItem"
172
- :nodes="props.nodes"
173
- :files="props.files"
174
- :networks-table="props.networksTable"
175
- :error-validation-fields="props.errorValidationFields"
176
- :vm-cpu-help-text-second="props.vmCpuHelpTextSecond"
177
- :passthrough-devices="props.passthroughDevices"
178
- :mediated-devices="props.mediatedDevices"
179
- :get-datastore-table-func="props.getDatastoreTableFunc"
180
- :datastore="props.datastore"
181
- :is-datastore-loading="props.isDatastoreLoading"
182
- :project="props.project"
183
- is-clone
184
- @get-storage="emits('get-storage', $event)"
185
- @get-folders-or-files="emits('get-folders-or-files', $event)"
186
- @get-active-device-child="emits('get-active-device-child', $event)"
187
- @show-datastore-child="emits('show-datastore-child', $event)"
188
- @get-networks-table="emits('get-networks-table', $event)"
189
- @get-pci-devices="emits('get-pci-devices')"
190
- />
191
- </template>
192
- </ui-wizard-block>
193
-
194
- <ui-wizard-block
195
- v-if="selectedStep.id === props.dynamicSteps.selectComputeResource"
196
- :sub-title-height="height5"
197
- >
198
- <template #subTitle>
199
- <div ref="subTitleBlock5">
200
- <div class="subtitle-block">
201
- <ui-alert
202
- v-if="props.computeResourceAlert.length"
203
- :messages="props.computeResourceAlert"
204
- test-id="computed-resource-alert"
205
- type="error"
206
- size="md"
207
- class="subtitle-block__alert"
208
- />
209
- <ui-wizard-subtitle
210
- :sub-title="
211
- localization.vmWizard
212
- .selectDestinationComputeResourceForThisOperation
213
- "
214
- />
215
- </div>
216
- </div>
217
- </template>
218
- <template #content>
219
- <common-wizards-common-steps-compute-resource
220
- v-if="props.isSphere"
221
- v-show="
222
- selectedStep.id === props.dynamicSteps.selectComputeResource
223
- "
224
- v-model="computeResource"
225
- :nodes="computeResourceTreeLocal"
226
- :alert-messages="props.computeResourceAlert"
227
- :is-loading="props.isLoadingComputeTree"
228
- :compatibility-text="props.compatibilityText"
229
- />
230
- </template>
231
- </ui-wizard-block>
232
-
233
- <ui-wizard-block
234
- v-if="selectedStep.id === props.dynamicSteps.readyComplete"
235
- :sub-title-height="heightReadyComplete"
236
- >
237
- <template #subTitle>
238
- <div ref="subTitleBlockReadyComplete">
239
- <div class="subtitle-block">
240
- <ui-wizard-subtitle
241
- :sub-title="localization.vmWizard.lastCreateSubtitle"
242
- />
243
- </div>
244
- </div>
245
- </template>
246
- <template #content>
247
- <div class="select-block-wrap h-full flex flex-col mt-3">
248
- <common-ready-to-complete :data="props.readyCompleteTableInfo" />
249
- <div
250
- class="vm-hardware-version-wrap justify-end flex flex-1 mt-4 pb-4"
251
- >
252
- <span class="vm-hardware-version">{{
253
- props.compatibilityInfo
254
- }}</span>
255
- </div>
256
- </div>
257
- </template>
258
- </ui-wizard-block>
259
- </template>
260
- </ui-wizard>
261
- </template>
262
-
263
- <script setup lang="ts">
264
- import { useElementSize } from '@vueuse/core'
265
- import type {
266
- UI_I_WizardStep,
267
- UI_I_WizardTexts,
268
- } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/interfaces'
269
- import type Wizard from '~/node_modules/bfg-uikit/components/ui/wizard/lib/utils/utils'
270
- import type {
271
- UI_I_ArbitraryObject,
272
- UI_I_Localization,
273
- } from '~/lib/models/interfaces'
274
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
275
- import type { UI_I_ScheduleNewTasksForm } from '~/components/common/pages/scheduledTasks/modals/lib/models/interfaces'
276
- import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
277
- import type { UI_I_NameTestIds } from '~/components/common/wizards/common/steps/name/lib/models/interfaces'
278
- import type { UI_T_Project } from '~/lib/models/types'
279
- import type { UI_I_CreateVmData } from '~/components/common/vm/actions/common/lib/models/interfaces'
280
- import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
281
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
282
- import type { UI_T_SelectedNavItem } from '~/components/common/vm/actions/common/lib/models/types'
283
- import type { UI_I_FileTreeNode } from '~/components/lib/models/interfaces'
284
- import type { UI_I_NetworkTableItem } from '~/lib/models/store/network/interfaces'
285
- import type {
286
- UI_I_MediatedDevice,
287
- UI_I_PciDevice,
288
- } from '~/lib/models/store/vm/interfaces'
289
- import type {
290
- UI_I_DatastoreTableItem,
291
- UI_I_FolderOrFileTreePayload,
292
- } from '~/lib/models/store/storage/interfaces'
293
- import type { UI_I_TableInfoItem } from '~/components/atoms/table/info/lib/models/interfaces'
294
- import type { UI_T_CompatibilityStatus } from '~/components/common/wizards/common/compatibility/lib/models/types'
295
-
296
- const model = defineModel<UI_I_CreateVmData>({ required: true })
297
-
298
- const schedulerTaskForm = defineModel<UI_I_ScheduleNewTasksForm>(
299
- 'scheduler-task-form'
300
- )
301
- const computeResource = defineModel<UI_I_TreeNode | undefined>(
302
- 'compute-resource'
303
- )
304
- const location = defineModel<UI_I_TreeNode | null>('location')
305
- const props = withDefaults(
306
- defineProps<{
307
- project: UI_T_Project
308
- nodes: UI_I_FileTreeNode[]
309
- files: UI_I_FileTreeNode[]
310
- networksTable: UI_I_NetworkTableItem[]
311
- datastore: UI_I_DatastoreTableItem[]
312
- isDatastoreLoading: boolean
313
- errorValidationFields: UI_I_ErrorValidationField[]
314
- readyCompleteTableInfo: UI_I_TableInfoItem[]
315
- vmCpuHelpTextSecond: string
316
- getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
317
- passthroughDevices: UI_I_PciDevice[]
318
- mediatedDevices: UI_I_MediatedDevice[]
319
- nameRequestUrl: string
320
- wizard: Wizard
321
- selectedScheme: number[]
322
- selectedVirtualMachine: string
323
- isNewVmFromTemplate: boolean | undefined
324
- computeResourceTree: UI_I_TreeNode[] | undefined // для сферы
325
- locationNodes: UI_I_TreeNode[] | undefined // для сферы
326
- title: string
327
- nameFormSubmit: null | Function
328
- storageSubmit: null | Function
329
- customizeHardwareSubmit: null | Function
330
- selectedNavItem: UI_T_SelectedNavItem
331
- allowedLocationKinds: number[]
332
- isSphere: boolean
333
- locationDescription: string
334
- nameTestIds: UI_I_NameTestIds
335
- guestOsFamilies: UI_I_OptionItem[]
336
- guestOsVersions: UI_I_ArbitraryObject<UI_I_OptionItem[]>
337
- machineTypes: UI_I_OptionItem[]
338
- maxMemory: number
339
- cpuModels: UI_I_OptionItem[]
340
- dynamicSteps: UI_I_ArbitraryObject<number>
341
- isLoadingComputeTree?: boolean // для сферы
342
- computeResourceAlert?: string[] // для сферы
343
- compatibilityText?: [UI_T_CompatibilityStatus, string] // для сферы
344
- }>(),
345
- {
346
- isLoadingComputeTree: false,
347
- computeResourceAlert: () => [],
348
- compatibilityText: () => ['none', ''],
349
- }
350
- )
351
-
352
- const emits = defineEmits<{
353
- (event: 'get-storage', value: UI_I_TablePayload): void
354
- (event: 'get-folders-or-files', value: UI_I_FolderOrFileTreePayload): void
355
- (event: 'get-active-device-child', value: UI_I_FileTreeNode): void
356
- (event: 'show-datastore-child', value: UI_I_FileTreeNode): void
357
- (event: 'remove-error-by-title', value: string): void
358
- (event: 'get-networks-table', value: UI_I_TablePayload): void
359
- (event: 'get-pci-devices'): void
360
- (event: 'change-steps', value: UI_I_WizardStep[]): void
361
- (event: 'change-name', value: [string, UI_I_TreeNode | null]): void
362
- (event: 'change-storage', value: UI_I_DatastoreTableItem | null): void
363
- (event: 'change-select-options', value: string[]): void
364
- (event: 'change-clone-count', value: number): void
365
- (event: 'hide'): void
366
- (event: 'finish'): void
367
- }>()
368
-
369
- const localization = computed<UI_I_Localization>(() => useLocal())
370
-
371
- const computeResourceTreeLocal = computed<UI_I_TreeNode[]>(() => {
372
- // для сферы
373
- return props.computeResourceTree || []
374
- })
375
-
376
- const texts = computed<UI_I_WizardTexts>(() => ({
377
- cancel: localization.value.common.cancel,
378
- back: localization.value.common.backCap,
379
- processing: localization.value.common.processing,
380
- next: localization.value.common.next,
381
- finish: props.isNewVmFromTemplate
382
- ? localization.value.common.create
383
- : localization.value.common.clone,
384
- incompleteTitle: localization.value.common.incompleteProcess,
385
- incompleteMessage: localization.value.common.incompleteProcessMessage,
386
- incompleteCancel: localization.value.common.cancel,
387
- incompleteLeave: localization.value.common.leave,
388
- step: localization.value.common.step,
389
- of: localization.value.common.of2,
390
- }))
391
-
392
- const subTitleBlock0 = ref<HTMLElement | null>(null)
393
- const { height: height0 } = useElementSize(subTitleBlock0)
394
-
395
- const subTitleBlock1 = ref<HTMLElement | null>(null)
396
- const { height: height1 } = useElementSize(subTitleBlock1)
397
-
398
- const subTitleBlock2 = ref<HTMLElement | null>(null)
399
- const { height: height2 } = useElementSize(subTitleBlock2)
400
-
401
- const subTitleBlock3 = ref<HTMLElement | null>(null)
402
- const { height: height3 } = useElementSize(subTitleBlock3)
403
-
404
- const subTitleBlock4 = ref<HTMLElement | null>(null)
405
- const { height: height4 } = useElementSize(subTitleBlock4)
406
-
407
- const subTitleBlock5 = ref<HTMLElement | null>(null)
408
- const { height: height5 } = useElementSize(subTitleBlock5)
409
-
410
- const subTitleBlockReadyComplete = ref<HTMLElement | null>(null)
411
- const { height: heightReadyComplete } = useElementSize(
412
- subTitleBlockReadyComplete
413
- )
414
-
415
- const isNameAlertWrapperEmpty = ref<boolean>(false)
416
-
417
- const selectNameStepSubtitle = computed<string>(() =>
418
- props.project === 'sphere'
419
- ? localization.value.vmWizard.specifyUniqueNameAndTargetLocationForVm
420
- : localization.value.common.specifyUniqueNameForVm
421
- )
422
-
423
- const onChangeSteps = async (value: UI_I_WizardStep[]): Promise<void> =>
424
- emits('change-steps', value)
425
-
426
- const onHideModal = (): void => emits('hide')
427
- const onClone = (): void => emits('finish')
428
- </script>
429
-
430
- <style scoped lang="scss">
431
- .subtitle-block {
432
- display: flex;
433
- flex-direction: column;
434
- row-gap: 16px;
435
- border-bottom: 1px solid var(--wizard-line);
436
- padding-bottom: 12px;
437
- }
438
- </style>
1
+ <template>
2
+ <ui-wizard
3
+ :steps="props.wizard.steps"
4
+ :selected-scheme="props.selectedScheme"
5
+ :is-loading="props.wizard.wizardLoader.status"
6
+ :title="props.title"
7
+ :texts="texts"
8
+ test-id="clone-exist-vm"
9
+ show
10
+ @change-steps="onChangeSteps"
11
+ @hide="onHideModal"
12
+ @submit="onClone"
13
+ >
14
+ <template #content="{ selectedStep }">
15
+ <ui-wizard-block
16
+ v-if="selectedStep.id === props.dynamicSteps.scheduledTasks"
17
+ :sub-title-height="height0"
18
+ >
19
+ <template #subTitle>
20
+ <div ref="subTitleBlock0">
21
+ <div class="subtitle-block flex flex-col">
22
+ <ui-wizard-subtitle :sub-title="selectedStep.subTitle" />
23
+ </div>
24
+ </div>
25
+ </template>
26
+ <template #content>
27
+ <common-pages-scheduled-tasks-modals-common-new-task-form
28
+ v-model="schedulerTaskForm"
29
+ :target="props.selectedVirtualMachine"
30
+ class="new-task-form"
31
+ />
32
+ </template>
33
+ </ui-wizard-block>
34
+
35
+ <ui-wizard-block
36
+ v-if="
37
+ selectedStep.id === props.dynamicSteps.selectName ||
38
+ selectedStep.id === props.dynamicSteps.selectNameFolder
39
+ "
40
+ :sub-title-height="height1"
41
+ >
42
+ <template #subTitle>
43
+ <div ref="subTitleBlock1">
44
+ <div class="subtitle-block flex flex-col">
45
+ <div
46
+ id="name-alert-wrapper"
47
+ :class="[{ 'mb-4': !isNameAlertWrapperEmpty }]"
48
+ ></div>
49
+ <ui-wizard-subtitle :sub-title="selectNameStepSubtitle" />
50
+ </div>
51
+ </div>
52
+ </template>
53
+ <template #content>
54
+ <common-wizards-common-steps-name
55
+ v-model:name="model.name"
56
+ v-model:location="location"
57
+ :show="
58
+ selectedStep.id === props.dynamicSteps.selectName ||
59
+ selectedStep.id === props.dynamicSteps.selectNameFolder
60
+ "
61
+ :name-form-submit="props.nameFormSubmit"
62
+ :name-request-url="props.nameRequestUrl"
63
+ :has-location="props.project === 'sphere'"
64
+ :location-nodes="props.locationNodes"
65
+ :allowed-location-kinds="props.allowedLocationKinds"
66
+ :location-description="props.locationDescription"
67
+ :validation-description="
68
+ localization.common.enterValidLocationVirtualMachine
69
+ "
70
+ :name-exist-validation-description="
71
+ localization.common.vmNameExistInSelectedLocation
72
+ "
73
+ :test-ids="props.nameTestIds"
74
+ @submit="emits('change-name', $event)"
75
+ @has-errors="isNameAlertWrapperEmpty = $event"
76
+ />
77
+ </template>
78
+ </ui-wizard-block>
79
+
80
+ <ui-wizard-block
81
+ v-if="selectedStep.id === props.dynamicSteps.selectStorage"
82
+ :sub-title-height="height2"
83
+ >
84
+ <template #subTitle>
85
+ <div ref="subTitleBlock2">
86
+ <div class="subtitle-block flex flex-col">
87
+ <ui-wizard-subtitle
88
+ :sub-title="
89
+ localization.common.selectStorageConfigurationDiskFiles2
90
+ "
91
+ />
92
+ </div>
93
+ </div>
94
+ </template>
95
+ <template #content>
96
+ <common-vm-actions-common-select-storage
97
+ :storage-submit="props.storageSubmit"
98
+ :datastore="props.datastore"
99
+ :is-datastore-loading="props.isDatastoreLoading"
100
+ :storage="model.storage"
101
+ :get-datastore-table-func="props.getDatastoreTableFunc"
102
+ hide-alert
103
+ @change-storage="emits('change-storage', $event)"
104
+ />
105
+ </template>
106
+ </ui-wizard-block>
107
+
108
+ <ui-wizard-block
109
+ v-if="selectedStep.id === props.dynamicSteps.selectOptions"
110
+ :sub-title-height="height3"
111
+ >
112
+ <template #subTitle>
113
+ <div ref="subTitleBlock3">
114
+ <div class="subtitle-block flex flex-col">
115
+ <ui-wizard-subtitle
116
+ :sub-title="localization.vmWizard.selectAdvancedOptionsCloning"
117
+ />
118
+ </div>
119
+ </div>
120
+ </template>
121
+ <template #content>
122
+ <common-vm-actions-common-select-options
123
+ :is-new-vm-from-template="props.isNewVmFromTemplate"
124
+ :project="props.project"
125
+ @change="emits('change-select-options', $event)"
126
+ @change-count="emits('change-clone-count', $event)"
127
+ />
128
+ </template>
129
+ </ui-wizard-block>
130
+
131
+ <ui-wizard-block
132
+ v-if="selectedStep.id === props.dynamicSteps.selectGuestOSMachineType"
133
+ :sub-title-height="height4"
134
+ >
135
+ <template #subTitle>
136
+ <div ref="subTitleBlock4">
137
+ <div class="subtitle-block flex flex-col">
138
+ <ui-wizard-subtitle
139
+ :sub-title="
140
+ localization.common
141
+ .chooseGuestOSInstalledVmAndMachineTypeUsedCreateVm
142
+ "
143
+ />
144
+ </div>
145
+ </div>
146
+ </template>
147
+ <template #content>
148
+ <common-vm-actions-common-select-os
149
+ v-model:guest-os-family="model.guest_os_family"
150
+ v-model:guest-os-version="model.guest_os_version"
151
+ v-model:machine-type="model.machine_type"
152
+ :families-options="props.guestOsFamilies"
153
+ :versions-options="props.guestOsVersions"
154
+ :machine-types-options="props.machineTypes"
155
+ :error-validation-fields="props.errorValidationFields"
156
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
157
+ />
158
+ </template>
159
+ </ui-wizard-block>
160
+
161
+ <ui-wizard-block
162
+ v-if="selectedStep.id === props.dynamicSteps.customizeHardware"
163
+ >
164
+ <template #content>
165
+ <common-vm-actions-common-customize-hardware
166
+ v-model="model"
167
+ :storage="model.storage"
168
+ :customize-hardware-submit="props.customizeHardwareSubmit"
169
+ :max-memory="props.maxMemory"
170
+ :cpu-models="props.cpuModels"
171
+ :selected-nav-item="props.selectedNavItem"
172
+ :nodes="props.nodes"
173
+ :files="props.files"
174
+ :networks-table="props.networksTable"
175
+ :error-validation-fields="props.errorValidationFields"
176
+ :vm-cpu-help-text-second="props.vmCpuHelpTextSecond"
177
+ :passthrough-devices="props.passthroughDevices"
178
+ :mediated-devices="props.mediatedDevices"
179
+ :get-datastore-table-func="props.getDatastoreTableFunc"
180
+ :datastore="props.datastore"
181
+ :is-datastore-loading="props.isDatastoreLoading"
182
+ :project="props.project"
183
+ is-clone
184
+ @get-storage="emits('get-storage', $event)"
185
+ @get-folders-or-files="emits('get-folders-or-files', $event)"
186
+ @get-active-device-child="emits('get-active-device-child', $event)"
187
+ @show-datastore-child="emits('show-datastore-child', $event)"
188
+ @get-networks-table="emits('get-networks-table', $event)"
189
+ @get-pci-devices="emits('get-pci-devices')"
190
+ />
191
+ </template>
192
+ </ui-wizard-block>
193
+
194
+ <ui-wizard-block
195
+ v-if="selectedStep.id === props.dynamicSteps.selectComputeResource"
196
+ :sub-title-height="height5"
197
+ >
198
+ <template #subTitle>
199
+ <div ref="subTitleBlock5">
200
+ <div class="subtitle-block">
201
+ <ui-alert
202
+ v-if="props.computeResourceAlert.length"
203
+ :messages="props.computeResourceAlert"
204
+ test-id="computed-resource-alert"
205
+ type="error"
206
+ size="md"
207
+ class="subtitle-block__alert"
208
+ />
209
+ <ui-wizard-subtitle
210
+ :sub-title="
211
+ localization.vmWizard
212
+ .selectDestinationComputeResourceForThisOperation
213
+ "
214
+ />
215
+ </div>
216
+ </div>
217
+ </template>
218
+ <template #content>
219
+ <common-wizards-common-steps-compute-resource
220
+ v-if="props.isSphere"
221
+ v-show="
222
+ selectedStep.id === props.dynamicSteps.selectComputeResource
223
+ "
224
+ v-model="computeResource"
225
+ :nodes="computeResourceTreeLocal"
226
+ :alert-messages="props.computeResourceAlert"
227
+ :is-loading="props.isLoadingComputeTree"
228
+ :compatibility-text="props.compatibilityText"
229
+ />
230
+ </template>
231
+ </ui-wizard-block>
232
+
233
+ <ui-wizard-block
234
+ v-if="selectedStep.id === props.dynamicSteps.readyComplete"
235
+ :sub-title-height="heightReadyComplete"
236
+ >
237
+ <template #subTitle>
238
+ <div ref="subTitleBlockReadyComplete">
239
+ <div class="subtitle-block">
240
+ <ui-wizard-subtitle
241
+ :sub-title="localization.vmWizard.lastCreateSubtitle"
242
+ />
243
+ </div>
244
+ </div>
245
+ </template>
246
+ <template #content>
247
+ <div class="select-block-wrap h-full flex flex-col mt-3">
248
+ <common-ready-to-complete :data="props.readyCompleteTableInfo" />
249
+ <div
250
+ class="vm-hardware-version-wrap justify-end flex flex-1 mt-4 pb-4"
251
+ >
252
+ <span class="vm-hardware-version">{{
253
+ props.compatibilityInfo
254
+ }}</span>
255
+ </div>
256
+ </div>
257
+ </template>
258
+ </ui-wizard-block>
259
+ </template>
260
+ </ui-wizard>
261
+ </template>
262
+
263
+ <script setup lang="ts">
264
+ import { useElementSize } from '@vueuse/core'
265
+ import type {
266
+ UI_I_WizardStep,
267
+ UI_I_WizardTexts,
268
+ } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/interfaces'
269
+ import type Wizard from '~/node_modules/bfg-uikit/components/ui/wizard/lib/utils/utils'
270
+ import type {
271
+ UI_I_ArbitraryObject,
272
+ UI_I_Localization,
273
+ } from '~/lib/models/interfaces'
274
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
275
+ import type { UI_I_ScheduleNewTasksForm } from '~/components/common/pages/scheduledTasks/modals/lib/models/interfaces'
276
+ import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
277
+ import type { UI_I_NameTestIds } from '~/components/common/wizards/common/steps/name/lib/models/interfaces'
278
+ import type { UI_T_Project } from '~/lib/models/types'
279
+ import type { UI_I_CreateVmData } from '~/components/common/vm/actions/common/lib/models/interfaces'
280
+ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
281
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
282
+ import type { UI_T_SelectedNavItem } from '~/components/common/vm/actions/common/lib/models/types'
283
+ import type { UI_I_FileTreeNode } from '~/components/lib/models/interfaces'
284
+ import type { UI_I_NetworkTableItem } from '~/lib/models/store/network/interfaces'
285
+ import type {
286
+ UI_I_MediatedDevice,
287
+ UI_I_PciDevice,
288
+ } from '~/lib/models/store/vm/interfaces'
289
+ import type {
290
+ UI_I_DatastoreTableItem,
291
+ UI_I_FolderOrFileTreePayload,
292
+ } from '~/lib/models/store/storage/interfaces'
293
+ import type { UI_I_TableInfoItem } from '~/components/atoms/table/info/lib/models/interfaces'
294
+ import type { UI_T_CompatibilityStatus } from '~/components/common/wizards/common/compatibility/lib/models/types'
295
+
296
+ const model = defineModel<UI_I_CreateVmData>({ required: true })
297
+
298
+ const schedulerTaskForm = defineModel<UI_I_ScheduleNewTasksForm>(
299
+ 'scheduler-task-form'
300
+ )
301
+ const computeResource = defineModel<UI_I_TreeNode | undefined>(
302
+ 'compute-resource'
303
+ )
304
+ const location = defineModel<UI_I_TreeNode | null>('location')
305
+ const props = withDefaults(
306
+ defineProps<{
307
+ project: UI_T_Project
308
+ nodes: UI_I_FileTreeNode[]
309
+ files: UI_I_FileTreeNode[]
310
+ networksTable: UI_I_NetworkTableItem[]
311
+ datastore: UI_I_DatastoreTableItem[]
312
+ isDatastoreLoading: boolean
313
+ errorValidationFields: UI_I_ErrorValidationField[]
314
+ readyCompleteTableInfo: UI_I_TableInfoItem[]
315
+ vmCpuHelpTextSecond: string
316
+ getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
317
+ passthroughDevices: UI_I_PciDevice[]
318
+ mediatedDevices: UI_I_MediatedDevice[]
319
+ nameRequestUrl: string
320
+ wizard: Wizard
321
+ selectedScheme: number[]
322
+ selectedVirtualMachine: string
323
+ isNewVmFromTemplate: boolean | undefined
324
+ computeResourceTree: UI_I_TreeNode[] | undefined // для сферы
325
+ locationNodes: UI_I_TreeNode[] | undefined // для сферы
326
+ title: string
327
+ nameFormSubmit: null | Function
328
+ storageSubmit: null | Function
329
+ customizeHardwareSubmit: null | Function
330
+ selectedNavItem: UI_T_SelectedNavItem
331
+ allowedLocationKinds: number[]
332
+ isSphere: boolean
333
+ locationDescription: string
334
+ nameTestIds: UI_I_NameTestIds
335
+ guestOsFamilies: UI_I_OptionItem[]
336
+ guestOsVersions: UI_I_ArbitraryObject<UI_I_OptionItem[]>
337
+ machineTypes: UI_I_OptionItem[]
338
+ maxMemory: number
339
+ cpuModels: UI_I_OptionItem[]
340
+ dynamicSteps: UI_I_ArbitraryObject<number>
341
+ isLoadingComputeTree?: boolean // для сферы
342
+ computeResourceAlert?: string[] // для сферы
343
+ compatibilityText?: [UI_T_CompatibilityStatus, string] // для сферы
344
+ }>(),
345
+ {
346
+ isLoadingComputeTree: false,
347
+ computeResourceAlert: () => [],
348
+ compatibilityText: () => ['none', ''],
349
+ }
350
+ )
351
+
352
+ const emits = defineEmits<{
353
+ (event: 'get-storage', value: UI_I_TablePayload): void
354
+ (event: 'get-folders-or-files', value: UI_I_FolderOrFileTreePayload): void
355
+ (event: 'get-active-device-child', value: UI_I_FileTreeNode): void
356
+ (event: 'show-datastore-child', value: UI_I_FileTreeNode): void
357
+ (event: 'remove-error-by-title', value: string): void
358
+ (event: 'get-networks-table', value: UI_I_TablePayload): void
359
+ (event: 'get-pci-devices'): void
360
+ (event: 'change-steps', value: UI_I_WizardStep[]): void
361
+ (event: 'change-name', value: [string, UI_I_TreeNode | null]): void
362
+ (event: 'change-storage', value: UI_I_DatastoreTableItem | null): void
363
+ (event: 'change-select-options', value: string[]): void
364
+ (event: 'change-clone-count', value: number): void
365
+ (event: 'hide'): void
366
+ (event: 'finish'): void
367
+ }>()
368
+
369
+ const localization = computed<UI_I_Localization>(() => useLocal())
370
+
371
+ const computeResourceTreeLocal = computed<UI_I_TreeNode[]>(() => {
372
+ // для сферы
373
+ return props.computeResourceTree || []
374
+ })
375
+
376
+ const texts = computed<UI_I_WizardTexts>(() => ({
377
+ cancel: localization.value.common.cancel,
378
+ back: localization.value.common.backCap,
379
+ processing: localization.value.common.processing,
380
+ next: localization.value.common.next,
381
+ finish: props.isNewVmFromTemplate
382
+ ? localization.value.common.create
383
+ : localization.value.common.clone,
384
+ incompleteTitle: localization.value.common.incompleteProcess,
385
+ incompleteMessage: localization.value.common.incompleteProcessMessage,
386
+ incompleteCancel: localization.value.common.cancel,
387
+ incompleteLeave: localization.value.common.leave,
388
+ step: localization.value.common.step,
389
+ of: localization.value.common.of2,
390
+ }))
391
+
392
+ const subTitleBlock0 = ref<HTMLElement | null>(null)
393
+ const { height: height0 } = useElementSize(subTitleBlock0)
394
+
395
+ const subTitleBlock1 = ref<HTMLElement | null>(null)
396
+ const { height: height1 } = useElementSize(subTitleBlock1)
397
+
398
+ const subTitleBlock2 = ref<HTMLElement | null>(null)
399
+ const { height: height2 } = useElementSize(subTitleBlock2)
400
+
401
+ const subTitleBlock3 = ref<HTMLElement | null>(null)
402
+ const { height: height3 } = useElementSize(subTitleBlock3)
403
+
404
+ const subTitleBlock4 = ref<HTMLElement | null>(null)
405
+ const { height: height4 } = useElementSize(subTitleBlock4)
406
+
407
+ const subTitleBlock5 = ref<HTMLElement | null>(null)
408
+ const { height: height5 } = useElementSize(subTitleBlock5)
409
+
410
+ const subTitleBlockReadyComplete = ref<HTMLElement | null>(null)
411
+ const { height: heightReadyComplete } = useElementSize(
412
+ subTitleBlockReadyComplete
413
+ )
414
+
415
+ const isNameAlertWrapperEmpty = ref<boolean>(false)
416
+
417
+ const selectNameStepSubtitle = computed<string>(() =>
418
+ props.project === 'sphere'
419
+ ? localization.value.vmWizard.specifyUniqueNameAndTargetLocationForVm
420
+ : localization.value.common.specifyUniqueNameForVm
421
+ )
422
+
423
+ const onChangeSteps = async (value: UI_I_WizardStep[]): Promise<void> =>
424
+ emits('change-steps', value)
425
+
426
+ const onHideModal = (): void => emits('hide')
427
+ const onClone = (): void => emits('finish')
428
+ </script>
429
+
430
+ <style scoped lang="scss">
431
+ .subtitle-block {
432
+ display: flex;
433
+ flex-direction: column;
434
+ row-gap: 16px;
435
+ border-bottom: 1px solid var(--wizard-line);
436
+ padding-bottom: 12px;
437
+ }
438
+ </style>