bfg-common 1.5.573 → 1.5.575

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 (187) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  3. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  4. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  5. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  6. package/assets/localization/local_be.json +29 -6
  7. package/assets/localization/local_en.json +29 -6
  8. package/assets/localization/local_hy.json +29 -6
  9. package/assets/localization/local_kk.json +29 -6
  10. package/assets/localization/local_ru.json +29 -6
  11. package/assets/localization/local_zh.json +30 -7
  12. package/components/atoms/TheIcon3.vue +50 -50
  13. package/components/atoms/collapse/CollapseNav.vue +170 -170
  14. package/components/atoms/perPage/PerPage.vue +58 -58
  15. package/components/atoms/table/dataGrid/DataGrid.vue +1718 -1718
  16. package/components/atoms/table/dataGrid/DataGridPagination.vue +97 -97
  17. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  18. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  19. package/components/common/backup/storage/actions/add/Add.vue +3 -2
  20. package/components/common/backup/storage/actions/add/New.vue +3 -2
  21. package/components/common/backup/storage/actions/add/Old.vue +5 -4
  22. package/components/common/backup/storage/actions/add/lib/utils.ts +51 -51
  23. package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyComplete.vue +45 -45
  24. package/components/common/backup/storage/actions/add/steps/readyComplete/lib/config/propertiesDetails.ts +7 -7
  25. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  26. package/components/common/diagramMain/DiagramMain.vue +1 -1
  27. package/components/common/diagramMain/modals/lib/config/portModal.ts +251 -251
  28. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  29. package/components/common/diagramMain/port/Port.vue +580 -580
  30. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  31. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  32. package/components/common/modals/confirmByInput/ConfirmByInput.vue +9 -1
  33. package/components/common/modals/confirmByInput/ConfirmByInputNew.vue +7 -2
  34. package/components/common/monitor/overview/filters/lib/config/filterOptions.ts +1 -0
  35. package/components/common/pages/backups/DetailView.vue +52 -52
  36. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  37. package/components/common/pages/backups/modals/Modals.vue +243 -243
  38. package/components/common/pages/backups/modals/createBackup/CreateBackup.vue +1 -1
  39. package/components/common/pages/backups/modals/createBackup/New.vue +8 -2
  40. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  41. package/components/common/pages/backups/modals/createBackup/lib/config/readyToCompleteOptions.ts +69 -69
  42. package/components/common/pages/backups/modals/createBackup/lib/config/steps.ts +2 -1
  43. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  44. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  45. package/components/common/pages/backups/modals/restore/Restore.vue +9 -5
  46. package/components/common/pages/backups/modals/restore/RestoreNew.vue +13 -3
  47. package/components/common/pages/backups/modals/restore/RestoreOld.vue +6 -18
  48. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  49. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  50. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  51. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  52. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  53. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  54. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  55. package/components/common/pages/scheduledTasks/table/Table.vue +1 -1
  56. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  57. package/components/common/select/radio/RadioGroup.vue +137 -137
  58. package/components/common/spiceConsole/Drawer.vue +420 -420
  59. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  60. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  61. package/components/common/tools/Actions.vue +207 -207
  62. package/components/common/treeView/TreeView.vue +52 -52
  63. package/components/common/vm/actions/add/Add.vue +127 -52
  64. package/components/common/vm/actions/add/New.vue +54 -16
  65. package/components/common/vm/actions/add/Old.vue +55 -16
  66. package/components/common/vm/actions/add/lib/config/steps.ts +347 -347
  67. package/components/common/vm/actions/clone/Clone.vue +121 -48
  68. package/components/common/vm/actions/clone/new/New.vue +50 -14
  69. package/components/common/vm/actions/clone/old/Old.vue +52 -16
  70. package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +81 -14
  71. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +56 -7
  72. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +56 -8
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +206 -208
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +120 -223
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +118 -218
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +53 -66
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/lib/config/options.ts +1 -1
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +159 -139
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuNew.vue +15 -8
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuOld.vue +13 -8
  81. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  82. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  83. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +75 -62
  84. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryNew.vue +158 -158
  85. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryOld.vue +155 -155
  86. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +149 -241
  87. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskNew.vue +4 -3
  88. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskOld.vue +3 -2
  89. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  90. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +96 -58
  91. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  92. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  93. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbController.vue +17 -6
  94. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerNew.vue +3 -6
  95. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerOld.vue +3 -6
  96. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCard.vue +39 -17
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +5 -6
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardOld.vue +5 -6
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/lib/config/options.ts +4 -4
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  102. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +93 -6
  103. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +62 -8
  104. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsOld.vue +60 -8
  105. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptions.vue +69 -5
  106. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +32 -12
  107. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsOld.vue +33 -12
  108. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  109. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  110. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +132 -114
  111. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +6 -41
  112. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderOld.vue +6 -44
  113. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptions.vue +23 -8
  114. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +31 -21
  115. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsOld.vue +34 -26
  116. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +34 -28
  117. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/Old.vue +30 -24
  118. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/RemoteConsoleOptions.vue +112 -8
  119. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +3 -3
  120. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/{New.vue → KeymapNew.vue} +6 -6
  121. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/{Old.vue → KeymapOld.vue} +5 -5
  122. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +7 -6
  123. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  124. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/Tools.vue +38 -4
  125. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/ToolsNew.vue +26 -7
  126. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/ToolsOld.vue +50 -24
  127. package/components/common/vm/actions/common/lib/models/interfaces.ts +25 -57
  128. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  129. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  130. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  131. package/components/common/vm/actions/common/select/os/New.vue +19 -0
  132. package/components/common/vm/actions/common/select/os/Old.vue +34 -0
  133. package/components/common/vm/actions/common/select/os/Os.vue +25 -0
  134. package/components/common/vm/actions/common/select/storage/Old.vue +125 -125
  135. package/components/common/vm/actions/common/select/storage/Storage.vue +178 -178
  136. package/components/common/vm/actions/common/select/storage/new/New.vue +311 -311
  137. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  138. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  139. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  140. package/components/common/vm/actions/editSettings/EditSettings.vue +90 -32
  141. package/components/common/vm/actions/editSettings/EditSettingsOld.vue +41 -14
  142. package/components/common/vm/actions/editSettings/new/New.vue +41 -14
  143. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  144. package/components/common/vm/actions/lib/models/interfaces.ts +29 -4
  145. package/components/common/vm/actions/lib/utils.ts +36 -64
  146. package/components/common/vm/actions/register/Register.vue +352 -352
  147. package/components/common/vm/actions/register/lib/config/steps.ts +86 -86
  148. package/components/common/wizards/common/compatibility/Compatibility.vue +35 -35
  149. package/components/common/wizards/common/compatibility/New.vue +99 -99
  150. package/components/common/wizards/common/compatibility/Old.vue +53 -53
  151. package/components/common/wizards/common/steps/computeResource/ComputeResource.vue +86 -86
  152. package/components/common/wizards/common/steps/computeResource/New.vue +93 -93
  153. package/components/common/wizards/common/steps/computeResource/Old.vue +103 -103
  154. package/components/common/wizards/common/steps/name/Name.vue +178 -178
  155. package/components/common/wizards/common/steps/name/New.vue +221 -221
  156. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  157. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  158. package/components/common/wizards/common/steps/name/location/Location.vue +85 -85
  159. package/components/common/wizards/common/steps/name/location/New.vue +40 -40
  160. package/components/common/wizards/datastore/add/Add.vue +228 -228
  161. package/components/common/wizards/datastore/add/lib/utils.ts +85 -85
  162. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  163. package/components/common/wizards/vm/migrate/select/computeResource/ComputeResource.vue +205 -205
  164. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  165. package/composables/useAppVersion.ts +21 -21
  166. package/composables/useLocal.ts +6 -6
  167. package/composables/useLocalCommon.ts +39 -39
  168. package/package.json +3 -1
  169. package/plugins/console.ts +21 -21
  170. package/plugins/date.ts +233 -233
  171. package/plugins/mouse.ts +21 -21
  172. package/plugins/panelStates.ts +70 -70
  173. package/plugins/text.ts +59 -59
  174. package/public/spice-console/application/clientgui.js +854 -854
  175. package/public/spice-console/application/packetfactory.js +211 -211
  176. package/public/spice-console/application/virtualmouse.js +147 -147
  177. package/public/spice-console/lib/images/bitmap.js +203 -203
  178. package/public/spice-console/network/spicechannel.js +440 -440
  179. package/public/spice-console/process/cursorprocess.js +121 -121
  180. package/public/spice-console/process/inputprocess.js +227 -227
  181. package/public/spice-console/process/mainprocess.js +210 -210
  182. package/public/spice-console/run.js +210 -210
  183. package/store/main/mutations.ts +7 -7
  184. package/store/main/state.ts +7 -7
  185. package/store/tasks/mappers/recentTasks.ts +4 -0
  186. /package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/{New.vue → PasswordNew.vue} +0 -0
  187. /package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/{Old.vue → PasswordOld.vue} +0 -0
@@ -1,34 +1,33 @@
1
1
  <template>
2
2
  <ui-stack-block
3
- :has-children="false"
4
- test-id="boot-options-order-stack-block"
3
+ :has-children="false"
4
+ test-id="boot-options-order-stack-block"
5
5
  >
6
6
  <template #stackBlockKey>
7
7
  {{ localization.common.bootOrder }}
8
8
  </template>
9
9
  <template #stackBlockContent>
10
10
  <ui-drag-drop-list
11
- :items="localBootList"
11
+ :items="props.bootList"
12
12
  :disabled="props.isDisabled"
13
13
  grab-item-key="text"
14
14
  @drop="emits('change-order', $event)"
15
15
  @grab="onGrab"
16
16
  >
17
17
  <template
18
- v-for="(item, index) in localBootList"
18
+ v-for="(item, index) in props.bootList"
19
19
  :key="index"
20
20
  #[`leftSide${index}`]
21
21
  >
22
22
  <ui-checkbox
23
- :model-value="item.isChecked"
23
+ v-model="item.isChecked"
24
24
  :test-id="item.testId"
25
25
  :disabled="props.isDisabled"
26
26
  size="md"
27
- @update:model-value="onCheckboxChange(index, $event)"
28
27
  />
29
28
  </template>
30
29
  <template
31
- v-for="(item, index) in localBootList"
30
+ v-for="(item, index) in props.bootList"
32
31
  :key="props.bootList.length + index"
33
32
  #[`rightSide${index}`]
34
33
  >
@@ -54,48 +53,14 @@ const props = defineProps<{
54
53
  bootList: UI_I_BootItem[]
55
54
  isDisabled: boolean
56
55
  }>()
57
-
58
56
  const emits = defineEmits<{
59
57
  (event: 'change-order', value: UI_I_DropEvent): void
60
- (event: 'update:boot-list', value: UI_I_BootItem[]): void
61
58
  }>()
62
59
 
63
60
  const grabedItem = ref<any>(null)
64
- const localBootList = ref<UI_I_BootItem[]>([])
65
-
66
- // Синхронизируем с props
67
- watch(
68
- () => props.bootList,
69
- (newBootList) => {
70
- localBootList.value = newBootList.map((item) => ({ ...item }))
71
- },
72
- { deep: true, immediate: true }
73
- )
74
-
75
61
  const onGrab = (item: any): void => {
76
62
  grabedItem.value = item
77
63
  }
78
-
79
- // Обработчик изменения чекбокса
80
- const onCheckboxChange = (index: number, isChecked: boolean): void => {
81
- localBootList.value[index].isChecked = isChecked
82
-
83
- // Сохраняем порядок при изменении чекбокса
84
- let currentOrder = 1
85
- localBootList.value.forEach((item) => {
86
- if (item.isChecked) {
87
- item.order = currentOrder++
88
- } else {
89
- item.order = 0
90
- }
91
- })
92
-
93
- // Сортируем список
94
- localBootList.value.sort((a, b) => a.order - b.order)
95
-
96
- // Отправляем обновленный список родителю
97
- emits('update:boot-list', localBootList.value)
98
- }
99
64
  </script>
100
65
 
101
66
  <style scoped lang="scss">
@@ -1,36 +1,34 @@
1
1
  <template>
2
2
  <div class="boot-orders">
3
3
  <atoms-stack-block
4
- :has-children="false"
5
- test-id="boot-options-order-stack-block"
4
+ :has-children="false"
5
+ test-id="boot-options-order-stack-block"
6
6
  >
7
7
  <template #stackBlockKey>
8
8
  {{ localization.common.bootOrder }}
9
9
  </template>
10
10
  <template #stackBlockContent>
11
11
  <atoms-list-drag-drop-list
12
- :items="localBootList"
12
+ :items="props.bootList"
13
13
  :disabled="props.isDisabled"
14
14
  grab-item-key="text"
15
15
  @drop="emits('change-order', $event)"
16
16
  >
17
17
  <template
18
- v-for="(item, index) in localBootList"
18
+ v-for="(item, index) in props.bootList"
19
19
  :key="index"
20
20
  #[`leftSide${index}`]
21
21
  >
22
22
  <input
23
23
  :id="`boot-order-${index}`"
24
- :key="item.name"
25
- :checked="item.isChecked"
24
+ v-model="item.isChecked"
26
25
  :data-id="item.testId"
27
26
  :disabled="props.isDisabled"
28
27
  type="checkbox"
29
- @change="onCheckboxChange(index, $event)"
30
28
  />
31
29
  </template>
32
30
  <template
33
- v-for="(item, index) in localBootList"
31
+ v-for="(item, index) in props.bootList"
34
32
  :key="props.bootList.length + index"
35
33
  #[`rightSide${index}`]
36
34
  >
@@ -54,45 +52,9 @@ const props = defineProps<{
54
52
  bootList: UI_I_BootItem[]
55
53
  isDisabled: boolean
56
54
  }>()
57
-
58
55
  const emits = defineEmits<{
59
56
  (event: 'change-order', value: UI_I_DropEvent): void
60
- (event: 'update:boot-list', value: UI_I_BootItem[]): void
61
57
  }>()
62
-
63
- // Локальная копия для реактивных изменений
64
- const localBootList = ref<UI_I_BootItem[]>([])
65
-
66
- // Синхронизируем с props
67
- watch(
68
- () => props.bootList,
69
- (newBootList) => {
70
- localBootList.value = newBootList.map((item) => ({ ...item }))
71
- },
72
- { deep: true, immediate: true }
73
- )
74
-
75
- // Обработчик изменения чекбокса
76
- const onCheckboxChange = (index: number, event: Event): void => {
77
- const target = event.target as HTMLInputElement
78
- localBootList.value[index].isChecked = target.checked
79
-
80
- // Сохраняем порядок при изменении чекбокса
81
- let currentOrder = 1
82
- localBootList.value.forEach((item) => {
83
- if (item.isChecked) {
84
- item.order = currentOrder++
85
- } else {
86
- item.order = 0
87
- }
88
- })
89
-
90
- // Сортируем список
91
- localBootList.value.sort((a, b) => a.order - b.order)
92
-
93
- // Отправляем обновленный список родителю
94
- emits('update:boot-list', localBootList.value)
95
- }
96
58
  </script>
97
59
 
98
60
  <style scoped lang="scss">
@@ -1,7 +1,10 @@
1
1
  <template>
2
2
  <common-vm-actions-common-customize-hardware-vmoptions-general-options-new
3
3
  v-if="isNewView"
4
- v-model="model"
4
+ v-model:vm-name="vmName"
5
+ v-model:guest-machine-type="guestMachineType"
6
+ v-model:guest-os-family="guestOsFamily"
7
+ v-model:guest-os-version="guestOsVersion"
5
8
  v-model:block-is-open="blockIsOpen"
6
9
  :name-label="nameLabel"
7
10
  :is-disabled="isDisabled"
@@ -12,7 +15,10 @@
12
15
  />
13
16
  <common-vm-actions-common-customize-hardware-vmoptions-general-options-old
14
17
  v-else
15
- v-model="model"
18
+ v-model:vm-name="vmName"
19
+ v-model:guest-machine-type="guestMachineType"
20
+ v-model:guest-os-family="guestOsFamily"
21
+ v-model:guest-os-version="guestOsVersion"
16
22
  v-model:block-is-open="blockIsOpen"
17
23
  :name-label="nameLabel"
18
24
  :is-disabled="isDisabled"
@@ -26,10 +32,19 @@
26
32
  <script setup lang="ts">
27
33
  import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
28
34
  import type { UI_I_Localization } from '~/lib/models/interfaces'
29
- import type { UI_I_CreateVmData } from '~/components/common/vm/actions/common/lib/models/interfaces'
30
35
  import { capabilities } from '~/components/common/vm/actions/common/lib/config/capabilities'
31
36
 
32
- const model = defineModel<UI_I_CreateVmData>({ required: true })
37
+ const vmName = defineModel<string>('vmName', { required: true })
38
+ const guestMachineType = defineModel<UI_I_OptionItem | null>(
39
+ 'guestMachineType',
40
+ { required: true }
41
+ )
42
+ const guestOsFamily = defineModel<UI_I_OptionItem | null>('guestOsFamily', {
43
+ required: true,
44
+ })
45
+ const guestOsVersion = defineModel<UI_I_OptionItem | null>('guestOsVersion', {
46
+ required: true,
47
+ })
33
48
 
34
49
  const props = withDefaults(
35
50
  defineProps<{
@@ -56,18 +71,18 @@ const machineTypeOptions = ref<UI_I_OptionItem[]>(
56
71
 
57
72
  const osOptions = ref<UI_I_OptionItem[]>(capabilities.value.guestOsFamilies)
58
73
  const onChangeOS = (): void => {
59
- model.value.guest_os_version = versionsOptions.value[0].value
74
+ guestOsVersion.value = versionsOptions.value[0]
60
75
  }
61
76
 
62
77
  const versionsOptions = computed<UI_I_OptionItem[]>(() => {
63
- if (!model.value.guest_os_family) return []
78
+ if (!guestOsFamily.value) return []
64
79
 
65
- return capabilities.value.guestOsVersions[model.value.guest_os_family.value] || []
80
+ return capabilities.value.guestOsVersions[guestOsFamily.value.value] || []
66
81
  })
67
82
  watch(
68
83
  versionsOptions,
69
84
  () => {
70
- model.value.guest_os_version = versionsOptions.value[0].value
85
+ guestOsVersion.value = versionsOptions.value[0]
71
86
  }
72
87
  // { immediate: true }
73
88
  )
@@ -19,13 +19,13 @@
19
19
  <template #stackBlockContent>
20
20
  <div v-show="!blockIsOpen" class="vm-name-wrap">
21
21
  <span class="vsphere-icon-vm"></span>
22
- <span data-id="header-vm-name">{{ model.name || '--' }}</span>
22
+ <span data-id="header-vm-name">{{ vmName || '--' }}</span>
23
23
  </div>
24
24
  </template>
25
25
  <template #stackChildren>
26
26
  <ui-stack-block
27
- :has-children="false"
28
- test-id="general-options-vm-name-stack-block"
27
+ :has-children="false"
28
+ test-id="general-options-vm-name-stack-block"
29
29
  >
30
30
  <template #stackBlockKey>
31
31
  {{ props.nameLabel }}
@@ -33,30 +33,30 @@
33
33
  <template #stackBlockContent>
34
34
  <div class="vm-name-wrap">
35
35
  <span class="vsphere-icon-vm"></span>
36
- <span data-id="new-vm-name">{{ model.name || '--' }}</span>
36
+ <span data-id="new-vm-name">{{ vmName || '--' }}</span>
37
37
  </div>
38
- <!-- <span v-if="!props.isEdit">{{ model.name }}</span>-->
38
+ <!-- <span v-if="!props.isEdit">{{ vmName }}</span>-->
39
39
  <!-- <input-->
40
40
  <!-- v-else-->
41
41
  <!-- id="general-option-vm-name"-->
42
- <!-- v-models="model.name"-->
42
+ <!-- v-models="vmName"-->
43
43
  <!-- type="text"-->
44
44
  <!-- />-->
45
45
  </template>
46
46
  </ui-stack-block>
47
47
 
48
48
  <ui-stack-block
49
- :has-children="false"
50
- test-id="general-options-machine-type-stack-block"
49
+ :has-children="false"
50
+ test-id="general-options-machine-type-stack-block"
51
51
  >
52
52
  <template #stackBlockKey>
53
53
  <span class="mt-2">{{ localization.common.machineType }}</span>
54
54
  </template>
55
55
  <template #stackBlockContent>
56
56
  <ui-select
57
- v-if="model.machine_type"
57
+ v-if="guestMachineType"
58
58
  id="guest-machine-type-select"
59
- v-model="model.machine_type"
59
+ v-model="guestMachineType"
60
60
  :items="props.machineTypeOptions"
61
61
  :disabled="props.isDisabled"
62
62
  width="auto"
@@ -68,17 +68,17 @@
68
68
  </ui-stack-block>
69
69
 
70
70
  <ui-stack-block
71
- :has-children="false"
72
- test-id="general-options-guest-os-family-stack-block"
71
+ :has-children="false"
72
+ test-id="general-options-guest-os-family-stack-block"
73
73
  >
74
74
  <template #stackBlockKey>
75
75
  <span class="mt-2">{{ localization.common.guestOsFamily }}</span>
76
76
  </template>
77
77
  <template #stackBlockContent>
78
78
  <ui-select
79
- v-if="model.guest_os_family"
79
+ v-if="guestOsFamily"
80
80
  id="guest-os-family-select"
81
- v-model="model.guest_os_family"
81
+ v-model="guestOsFamily"
82
82
  :items="props.osOptions"
83
83
  :disabled="props.isDisabled"
84
84
  width="auto"
@@ -91,17 +91,17 @@
91
91
  </ui-stack-block>
92
92
 
93
93
  <ui-stack-block
94
- :has-children="false"
95
- test-id="general-options-guest-os-version-stack-block"
94
+ :has-children="false"
95
+ test-id="general-options-guest-os-version-stack-block"
96
96
  >
97
97
  <template #stackBlockKey>
98
98
  <span class="mt-2">{{ localization.common.guestOsVersion }}</span>
99
99
  </template>
100
100
  <template #stackBlockContent>
101
101
  <ui-select
102
- v-if="model.guest_os_version"
102
+ v-if="guestOsVersion"
103
103
  id="guest-os-version-select"
104
- v-model="model.guest_os_version"
104
+ v-model="guestOsVersion"
105
105
  :items="props.versionsOptions"
106
106
  :disabled="props.isDisabled"
107
107
  width="auto"
@@ -118,11 +118,21 @@
118
118
  <script setup lang="ts">
119
119
  import type { UI_I_Localization } from '~/lib/models/interfaces'
120
120
  import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
121
- import type { UI_I_CreateVmData } from '~/components/common/vm/actions/common/lib/models/interfaces'
122
-
123
- const model = defineModel<UI_I_CreateVmData>({ required: true })
124
121
 
125
122
  const blockIsOpen = defineModel<boolean>('blockIsOpen', { required: true })
123
+ const vmName = defineModel<string>('vmName', { required: true })
124
+ const guestMachineType = defineModel<UI_I_OptionItem | null>(
125
+ 'guestMachineType',
126
+ {
127
+ required: true,
128
+ }
129
+ )
130
+ const guestOsFamily = defineModel<UI_I_OptionItem | null>('guestOsFamily', {
131
+ required: true,
132
+ })
133
+ const guestOsVersion = defineModel<UI_I_OptionItem | null>('guestOsVersion', {
134
+ required: true,
135
+ })
126
136
 
127
137
  const props = defineProps<{
128
138
  isDisabled: boolean
@@ -15,44 +15,42 @@
15
15
  </div>
16
16
  </template>
17
17
  <template #stackBlockContent>
18
- <div v-show="!blockIsOpen" data-id="header-vm-name">
19
- {{ props.nameLabel }}: {{ model.name }}
20
- </div>
18
+ <div v-show="!blockIsOpen" data-id="header-vm-name">{{ props.nameLabel }}: {{ vmName }}</div>
21
19
  </template>
22
20
  <template #stackChildren>
23
21
  <atoms-stack-block
24
- :has-children="false"
25
- test-id="general-options-vm-name-stack-block"
22
+ :has-children="false"
23
+ test-id="general-options-vm-name-stack-block"
26
24
  >
27
25
  <template #stackBlockKey>
28
26
  {{ props.nameLabel }}
29
27
  </template>
30
28
  <template #stackBlockContent>
31
- <span data-id="vm-name">{{ model.name }}</span>
32
- <!-- <span v-if="!props.isEdit">{{ model.name }}</span>-->
29
+ <span data-id="vm-name">{{ vmName }}</span>
30
+ <!-- <span v-if="!props.isEdit">{{ vmName }}</span>-->
33
31
  <!-- <input-->
34
32
  <!-- v-else-->
35
33
  <!-- id="general-option-vm-name"-->
36
- <!-- v-models="model.name"-->
34
+ <!-- v-models="vmName"-->
37
35
  <!-- type="text"-->
38
36
  <!-- />-->
39
37
  </template>
40
38
  </atoms-stack-block>
41
39
 
42
40
  <atoms-stack-block
43
- :has-children="false"
44
- test-id="general-options-machine-type-stack-block"
41
+ :has-children="false"
42
+ test-id="general-options-machine-type-stack-block"
45
43
  >
46
44
  <template #stackBlockKey>
47
45
  {{ localization.common.machineType }}
48
46
  </template>
49
47
  <template #stackBlockContent>
50
48
  <select
51
- v-if="model.machine_type"
49
+ v-if="guestMachineType"
52
50
  id="guest-machine-type-select"
53
- v-model="model.machine_type"
51
+ v-model="guestMachineType"
54
52
  :disabled="props.isDisabled"
55
- :data-value="model.machine_type"
53
+ :data-value="guestMachineType?.value"
56
54
  data-id="guest-machine-type-select"
57
55
  >
58
56
  <option
@@ -68,19 +66,19 @@
68
66
  </atoms-stack-block>
69
67
 
70
68
  <atoms-stack-block
71
- :has-children="false"
72
- test-id="general-options-guest-os-family-stack-block"
69
+ :has-children="false"
70
+ test-id="general-options-guest-os-family-stack-block"
73
71
  >
74
72
  <template #stackBlockKey>
75
73
  {{ localization.common.guestOsFamily }}
76
74
  </template>
77
75
  <template #stackBlockContent>
78
76
  <select
79
- v-if="model.guest_os_family"
77
+ v-if="guestOsFamily"
80
78
  id="guest-os-family-select"
81
- v-model="model.guest_os_family"
79
+ v-model="guestOsFamily"
82
80
  :disabled="props.isDisabled"
83
- :data-value="model.guest_os_family"
81
+ :data-value="guestOsFamily?.value"
84
82
  data-id="guest-os-family-select"
85
83
  @change="emits('change-os')"
86
84
  >
@@ -97,19 +95,19 @@
97
95
  </atoms-stack-block>
98
96
 
99
97
  <atoms-stack-block
100
- :has-children="false"
101
- test-id="general-options-guest-os-version-stack-block"
98
+ :has-children="false"
99
+ test-id="general-options-guest-os-version-stack-block"
102
100
  >
103
101
  <template #stackBlockKey>
104
102
  {{ localization.common.guestOsVersion }}
105
103
  </template>
106
104
  <template #stackBlockContent>
107
105
  <select
108
- v-if="model.guest_os_version"
106
+ v-if="guestOsVersion"
109
107
  id="guest-os-version-select"
110
- v-model="model.guest_os_version"
108
+ v-model="guestOsVersion"
111
109
  :disabled="props.isDisabled"
112
- :data-value="model.guest_os_version"
110
+ :data-value="guestOsVersion?.value"
113
111
  data-id="guest-os-version-select"
114
112
  >
115
113
  <option
@@ -131,11 +129,21 @@
131
129
  <script setup lang="ts">
132
130
  import type { UI_I_Localization } from '~/lib/models/interfaces'
133
131
  import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
134
- import type { UI_I_CreateVmData } from '~/components/common/vm/actions/common/lib/models/interfaces'
135
-
136
- const model = defineModel<UI_I_CreateVmData>({ required: true })
137
132
 
138
133
  const blockIsOpen = defineModel<boolean>('blockIsOpen', { required: true })
134
+ const vmName = defineModel<string>('vmName', { required: true })
135
+ const guestMachineType = defineModel<UI_I_OptionItem | null>(
136
+ 'guestMachineType',
137
+ {
138
+ required: true,
139
+ }
140
+ )
141
+ const guestOsFamily = defineModel<UI_I_OptionItem | null>('guestOsFamily', {
142
+ required: true,
143
+ })
144
+ const guestOsVersion = defineModel<UI_I_OptionItem | null>('guestOsVersion', {
145
+ required: true,
146
+ })
139
147
 
140
148
  const props = withDefaults(
141
149
  defineProps<{
@@ -25,105 +25,111 @@
25
25
  <!-- TODO возможно вернем, НЕ УДАЛЯТЬ-->
26
26
 
27
27
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-type-->
28
- <!-- v-models:remote-console-type="model.type"-->
28
+ <!-- v-models:remote-console-type="remoteConsoleType"-->
29
29
  <!-- :error-validation-fields="props.errorValidationFields"-->
30
30
  <!-- :disabled="isDisabled"-->
31
31
  <!-- @input="changeRemoteConsoleType"-->
32
32
  <!-- @remove-error-by-title="emits('remove-error-by-title', $event)"-->
33
33
  <!-- />-->
34
34
  <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-keymap
35
- v-model="model.keymap"
35
+ v-model:keymap="keymap"
36
36
  :disabled="props.isDisabled"
37
37
  />
38
38
  <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-password
39
- v-model="model.password"
39
+ v-model:password="password"
40
40
  :disabled="props.isDisabled"
41
41
  @valid="passwordIsValid = $event"
42
42
  />
43
43
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-power-control-->
44
- <!-- v-if="model.type === 'vnc'"-->
44
+ <!-- v-if="remoteConsoleType === 'vnc'"-->
45
45
  <!-- v-models:power-control="powerControl"-->
46
46
  <!-- />-->
47
47
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-share-policy-->
48
- <!-- v-if="model.type === 'vnc'"-->
48
+ <!-- v-if="remoteConsoleType === 'vnc'"-->
49
49
  <!-- v-models:share-policy="sharePolicy"-->
50
50
  <!-- />-->
51
51
  <!-- TODO возможно вернем, НЕ УДАЛЯТЬ-->
52
52
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-img-compression-->
53
- <!-- v-if="model.type === 'spice'"-->
53
+ <!-- v-if="remoteConsoleType === 'spice'"-->
54
54
  <!-- v-models:img-compression="imgCompression"-->
55
55
  <!-- :error-validation-fields="props.errorValidationFields"-->
56
56
  <!-- :disabled="isDisabled"-->
57
57
  <!-- @remove-error-by-title="emits('remove-error-by-title', $event)"-->
58
58
  <!-- />-->
59
59
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-jpeg-compression-->
60
- <!-- v-if="model.type === 'spice'"-->
60
+ <!-- v-if="remoteConsoleType === 'spice'"-->
61
61
  <!-- v-models:jpeg-compression="jpegCompression"-->
62
62
  <!-- :error-validation-fields="props.errorValidationFields"-->
63
63
  <!-- :disabled="isDisabled"-->
64
64
  <!-- @remove-error-by-title="emits('remove-error-by-title', $event)"-->
65
65
  <!-- />-->
66
66
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-zlib-compression-->
67
- <!-- v-if="model.type === 'spice'"-->
67
+ <!-- v-if="remoteConsoleType === 'spice'"-->
68
68
  <!-- v-models:zlib-compression="zlibCompression"-->
69
69
  <!-- :error-validation-fields="props.errorValidationFields"-->
70
70
  <!-- :disabled="isDisabled"-->
71
71
  <!-- @remove-error-by-title="emits('remove-error-by-title', $event)"-->
72
72
  <!-- />-->
73
73
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-playback-compression-->
74
- <!-- v-if="model.type === 'spice'"-->
74
+ <!-- v-if="remoteConsoleType === 'spice'"-->
75
75
  <!-- :disabled="isDisabled"-->
76
76
  <!-- v-models:playback-compression="playbackCompression"-->
77
77
  <!-- />-->
78
78
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-streaming-mode-->
79
- <!-- v-if="model.type === 'spice'"-->
79
+ <!-- v-if="remoteConsoleType === 'spice'"-->
80
80
  <!-- v-models:streaming-mode="streamingMode"-->
81
81
  <!-- :error-validation-fields="props.errorValidationFields"-->
82
82
  <!-- :disabled="isDisabled"-->
83
83
  <!-- @remove-error-by-title="emits('remove-error-by-title', $event)"-->
84
84
  <!-- />-->
85
85
  <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-copy-paste
86
- v-if="model.type === 'spice'"
87
- v-model:copy-paste="model.spice.clipboard"
86
+ v-if="remoteConsoleType === 'spice'"
87
+ v-model:copy-paste="copyPaste"
88
88
  :disabled="props.isDisabled"
89
89
  />
90
90
  <!-- TODO возможно вернем, НЕ УДАЛЯТЬ-->
91
91
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-mouse-mode-->
92
- <!-- v-if="model.type === 'spice'"-->
92
+ <!-- v-if="remoteConsoleType === 'spice'"-->
93
93
  <!-- v-models:mouse-mode="mouseMode"-->
94
94
  <!-- />-->
95
95
  <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-file-transfer
96
- v-if="model.type === 'spice'"
97
- v-model:file-transfer="model.spice.file_transfer"
96
+ v-if="remoteConsoleType === 'spice'"
97
+ v-model:file-transfer="fileTransfer"
98
98
  :disabled="props.isDisabled"
99
99
  />
100
100
  <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-usb-redirection
101
- v-if="model.type === 'spice'"
101
+ v-if="remoteConsoleType === 'spice'"
102
102
  v-model:usb-redirection="usbRedirection"
103
103
  :disabled="props.isDisabled"
104
104
  />
105
- <!-- TODO 700-->
106
- <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-folder-sharing-->
107
- <!-- v-if="model.type === 'spice'"-->
108
- <!-- v-model:folder-sharing="model.spice.folder_sharing"-->
109
- <!-- :disabled="props.isDisabled"-->
110
- <!-- />-->
105
+ <!-- TODO 700-->
106
+ <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-folder-sharing-->
107
+ <!-- v-if="remoteConsoleType === 'spice'"-->
108
+ <!-- v-model:folder-sharing="folderSharing"-->
109
+ <!-- :disabled="props.isDisabled"-->
110
+ <!-- />-->
111
111
  </template>
112
112
  </ui-stack-block>
113
113
  </template>
114
114
 
115
115
  <script setup lang="ts">
116
116
  import type { UI_I_Localization } from '~/lib/models/interfaces'
117
- import type { UI_I_CreateVmData } from '~/components/common/vm/actions/common/lib/models/interfaces'
118
-
119
- const model = defineModel<UI_I_CreateVmData['options']['remote_console']>({ required: true })
120
117
 
118
+ const keymap = defineModel<string>('keymap', { required: true })
119
+ const password = defineModel<string>('password', { required: true })
121
120
  const passwordIsValid = defineModel<boolean>('passwordIsValid', {
122
121
  required: true,
123
122
  })
124
-
125
- // TODO use from model
126
- const usbRedirection = ref<number>(3)
123
+ const remoteConsoleType = defineModel<string>('remoteConsoleType', {
124
+ required: true,
125
+ })
126
+ const copyPaste = defineModel<boolean>('copyPaste', { required: true })
127
+ const fileTransfer = defineModel<boolean>('fileTransfer', { required: true })
128
+ const usbRedirection = defineModel<number>('usbRedirection', {
129
+ required: true,
130
+ })
131
+ // TODO 700
132
+ // const folderSharing = defineModel<boolean>('folderSharing', { required: true })
127
133
 
128
134
  const props = defineProps<{
129
135
  // TODO возможно вернем, НЕ УДАЛЯТЬ