bfg-common 1.5.294 → 1.5.295

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 (124) 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/components/atoms/TheIcon3.vue +50 -50
  7. package/components/atoms/perPage/PerPage.vue +58 -58
  8. package/components/atoms/table/dataGrid/DataGrid.vue +1717 -1717
  9. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  10. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  11. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  12. package/components/common/backup/storage/actions/add/lib/config/steps.ts +168 -168
  13. package/components/common/backup/storage/actions/add/steps/hostAccessibility/HostAccessibility.vue +52 -52
  14. package/components/common/backup/storage/actions/add/steps/nameAndConfigure/NameAndConfigure.vue +42 -42
  15. package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyComplete.vue +45 -45
  16. package/components/common/backup/storage/actions/add/steps/readyComplete/lib/config/propertiesDetails.ts +243 -243
  17. package/components/common/backup/storage/actions/delete/Delete.vue +65 -65
  18. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  19. package/components/common/context/lib/models/interfaces.ts +31 -31
  20. package/components/common/diagramMain/DiagramMain.vue +897 -897
  21. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  22. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  23. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  24. package/components/common/pages/home/headline/Headline.vue +45 -45
  25. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  26. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  27. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  28. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  29. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  30. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  31. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  32. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  33. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  34. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  35. package/components/common/pages/packages/Packages.vue +208 -208
  36. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  37. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  38. package/components/common/recursionTree/RecursionTree.vue +223 -223
  39. package/components/common/select/button/ButtonDropdown.vue +108 -108
  40. package/components/common/spiceConsole/Drawer.vue +377 -377
  41. package/components/common/spiceConsole/SpiceConsole.vue +127 -127
  42. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  43. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  44. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  45. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  46. package/components/common/vm/actions/clone/Clone.vue +817 -817
  47. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  48. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  49. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +321 -321
  50. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +227 -227
  51. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +100 -100
  52. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  53. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  54. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  55. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +78 -78
  56. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  57. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/model/ModelNew.vue +1 -0
  58. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  59. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  60. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipNew.vue +154 -154
  61. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  62. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +307 -307
  63. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +385 -385
  64. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +85 -85
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -288
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCard.vue +154 -154
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  81. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +152 -147
  82. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +128 -122
  83. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsOld.vue +111 -97
  84. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  85. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  86. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  87. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptions.vue +83 -77
  88. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +8 -3
  89. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsOld.vue +154 -143
  90. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  91. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapOld.vue +44 -43
  92. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  93. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  94. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  95. package/components/common/vm/actions/common/lib/utils/capabilities.ts +52 -52
  96. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  97. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +118 -118
  98. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  99. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  100. package/components/common/vm/actions/common/select/name/Name.vue +174 -174
  101. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  102. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  103. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  104. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  105. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  106. package/components/common/vmt/actions/add/Add.vue +641 -641
  107. package/components/common/vmt/actions/add/lib/config/steps.ts +107 -107
  108. package/components/common/vmt/actions/add/lib/models/interfaces.ts +23 -23
  109. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  110. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  111. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  112. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  113. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  114. package/composables/productNameLocal.ts +30 -30
  115. package/composables/useAppVersion.ts +21 -21
  116. package/package.json +1 -1
  117. package/plugins/date.ts +233 -233
  118. package/plugins/panelStates.ts +70 -70
  119. package/plugins/text.ts +59 -59
  120. package/public/spice-console/lib/images/bitmap.js +203 -203
  121. package/public/spice-console/network/spicechannel.js +387 -387
  122. package/store/main/mutations.ts +7 -7
  123. package/store/main/state.ts +7 -7
  124. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,147 +1,152 @@
1
- <template>
2
- <common-vm-actions-common-customize-hardware-vmoptions-new
3
- v-if="isNewView"
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"
8
- v-model:remote-console-options-invalid="remoteConsoleOptionsInvalid"
9
- :hard-disks="props.hardDisks"
10
- :cd-dvd-drives="props.cdDvdDrives"
11
- :networks="props.networks"
12
- :is-edit="props.isEdit"
13
- :is-clone="props.isClone"
14
- :error-validation-fields="props.errorValidationFields"
15
- :options="props.options"
16
- :state="props.state"
17
- :compatibility-info="props.compatibilityInfo"
18
- @change-boot-order="emits('change-boot-order', $event)"
19
- @send-data-remote-console-options="sendDataRemoteConsoleOptionsMethod"
20
- @send-data-tools="sendDataToolsMethod"
21
- @send-data-boot-options="sendDataBootOptionsMethod"
22
- @remove-error-by-title="emits('remove-error-by-title', $event)"
23
- />
24
- <common-vm-actions-common-customize-hardware-vmoptions-old
25
- v-else
26
- v-model:vm-name="vmName"
27
- v-model:guest-machine-type="guestMachineType"
28
- v-model:guest-os-family="guestOsFamily"
29
- v-model:guest-os-version="guestOsVersion"
30
- v-model:remote-console-options-invalid="remoteConsoleOptionsInvalid"
31
- :hard-disks="props.hardDisks"
32
- :cd-dvd-drives="props.cdDvdDrives"
33
- :networks="props.networks"
34
- :is-edit="props.isEdit"
35
- :is-clone="props.isClone"
36
- :error-validation-fields="props.errorValidationFields"
37
- :options="props.options"
38
- :state="props.state"
39
- @change-boot-order="emits('change-boot-order', $event)"
40
- @send-data-remote-console-options="sendDataRemoteConsoleOptionsMethod"
41
- @send-data-tools="sendDataToolsMethod"
42
- @send-data-boot-options="sendDataBootOptionsMethod"
43
- @remove-error-by-title="emits('remove-error-by-title', $event)"
44
- />
45
- </template>
46
-
47
- <script setup lang="ts">
48
- import type {
49
- UI_I_SendDataRemoteConsoleOptions,
50
- UI_I_SendDataTools,
51
- UI_I_SendDataBootOptions,
52
- UI_I_SendDataVmoptions,
53
- } from '~/components/common/vm/actions/common/customizeHardware/vmoptions/lib/models/interfaces'
54
- import type {
55
- UI_I_SendDataNewCdDvdDrive,
56
- UI_I_SendDataNewHardDisk,
57
- UI_I_SendDataNewNetwork,
58
- } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
59
- import type { UI_I_Localization } from '~/lib/models/interfaces'
60
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
61
-
62
- const vmName = defineModel<string>('vmName', { required: true })
63
- const guestMachineType = defineModel<string>('guestMachineType', {
64
- required: true,
65
- })
66
- const guestOsFamily = defineModel<string>('guestOsFamily', { required: true })
67
- const guestOsVersion = defineModel<string>('guestOsVersion', {
68
- required: true,
69
- })
70
- const remoteConsoleOptionsInvalid = defineModel<boolean>(
71
- 'remoteConsoleOptionsInvalid',
72
- { required: true }
73
- )
74
-
75
- const props = defineProps<{
76
- hardDisks: UI_I_SendDataNewHardDisk[] | null
77
- cdDvdDrives: UI_I_SendDataNewCdDvdDrive[] | null
78
- networks: UI_I_SendDataNewNetwork[] | null
79
- isEdit: boolean
80
- isClone: boolean
81
- errorValidationFields: UI_I_ErrorValidationField[]
82
- options?: UI_I_SendDataVmoptions
83
- state?: string | number
84
- compatibilityInfo?: string
85
- }>()
86
- const emits = defineEmits<{
87
- (
88
- event: 'change-boot-order',
89
- value: [
90
- UI_I_SendDataNewHardDisk[],
91
- UI_I_SendDataNewCdDvdDrive[],
92
- UI_I_SendDataNewNetwork[]
93
- ]
94
- ): void
95
- (event: 'send-data', value: UI_I_SendDataVmoptions): void
96
- (event: 'invalid', value: string[]): void
97
- (event: 'remove-error-by-title', value: string): void
98
- }>()
99
-
100
- const { $store }: any = useNuxtApp()
101
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
102
-
103
- const localization = computed<UI_I_Localization>(() => useLocal())
104
-
105
- const sendDataRemoteConsoleOptions =
106
- ref<UI_I_SendDataRemoteConsoleOptions | null>(null)
107
- const sendDataRemoteConsoleOptionsMethod = (
108
- data: UI_I_SendDataRemoteConsoleOptions
109
- ): void => {
110
- sendDataRemoteConsoleOptions.value = data
111
- sendData()
112
- }
113
-
114
- const sendDataTools = ref<UI_I_SendDataTools | null>(null)
115
- const sendDataToolsMethod = (data: UI_I_SendDataTools): void => {
116
- sendDataTools.value = data
117
- sendData()
118
- }
119
-
120
- const sendDataBootOptions = ref<UI_I_SendDataBootOptions | null>(null)
121
- const sendDataBootOptionsMethod = (data: UI_I_SendDataBootOptions): void => {
122
- sendDataBootOptions.value = data
123
- sendData()
124
- }
125
-
126
- const sendData = (): void => {
127
- emits('send-data', {
128
- remote_console: sendDataRemoteConsoleOptions.value,
129
- guest_tools: sendDataTools.value,
130
- boot_options: sendDataBootOptions.value,
131
- })
132
- }
133
-
134
- watch(
135
- remoteConsoleOptionsInvalid,
136
- (newValue) => {
137
- const remoteConsoleOptions = newValue
138
- ? localization.value.common.remoteConsoleOptions
139
- : ''
140
- emits('invalid', [remoteConsoleOptions])
141
- },
142
- { immediate: true }
143
- )
144
- </script>
145
-
146
- <style scoped lang="scss">
147
- </style>
1
+ <template>
2
+ <common-vm-actions-common-customize-hardware-vmoptions-new
3
+ v-if="isNewView"
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"
8
+ v-model:remote-console-options-invalid="remoteConsoleOptionsInvalid"
9
+ :hard-disks="props.hardDisks"
10
+ :cd-dvd-drives="props.cdDvdDrives"
11
+ :networks="props.networks"
12
+ :is-edit="props.isEdit"
13
+ :is-clone="props.isClone"
14
+ :error-validation-fields="props.errorValidationFields"
15
+ :options="props.options"
16
+ :state="props.state"
17
+ :compatibility-info="props.compatibilityInfo"
18
+ @change-boot-order="emits('change-boot-order', $event)"
19
+ @send-data-remote-console-options="sendDataRemoteConsoleOptionsMethod"
20
+ @send-data-tools="sendDataToolsMethod"
21
+ @send-data-boot-options="sendDataBootOptionsMethod"
22
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
23
+ />
24
+ <common-vm-actions-common-customize-hardware-vmoptions-old
25
+ v-else
26
+ v-model:vm-name="vmName"
27
+ v-model:guest-machine-type="guestMachineType"
28
+ v-model:guest-os-family="guestOsFamily"
29
+ v-model:guest-os-version="guestOsVersion"
30
+ v-model:remote-console-options-invalid="remoteConsoleOptionsInvalid"
31
+ :hard-disks="props.hardDisks"
32
+ :cd-dvd-drives="props.cdDvdDrives"
33
+ :networks="props.networks"
34
+ :is-edit="props.isEdit"
35
+ :is-clone="props.isClone"
36
+ :error-validation-fields="props.errorValidationFields"
37
+ :options="props.options"
38
+ :state="props.state"
39
+ @change-boot-order="emits('change-boot-order', $event)"
40
+ @send-data-remote-console-options="sendDataRemoteConsoleOptionsMethod"
41
+ @send-data-tools="sendDataToolsMethod"
42
+ @send-data-boot-options="sendDataBootOptionsMethod"
43
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
44
+ />
45
+ </template>
46
+
47
+ <script setup lang="ts">
48
+ import type {
49
+ UI_I_SendDataRemoteConsoleOptions,
50
+ UI_I_SendDataTools,
51
+ UI_I_SendDataBootOptions,
52
+ UI_I_SendDataVmoptions,
53
+ } from '~/components/common/vm/actions/common/customizeHardware/vmoptions/lib/models/interfaces'
54
+ import type {
55
+ UI_I_SendDataNewCdDvdDrive,
56
+ UI_I_SendDataNewHardDisk,
57
+ UI_I_SendDataNewNetwork,
58
+ } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
59
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
60
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
61
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
62
+
63
+ const vmName = defineModel<string>('vmName', { required: true })
64
+ const guestMachineType = defineModel<UI_I_OptionItem | null>(
65
+ 'guestMachineType',
66
+ {
67
+ required: true,
68
+ }
69
+ )
70
+ const guestOsFamily = defineModel<UI_I_OptionItem | null>('guestOsFamily', {
71
+ required: true,
72
+ })
73
+ const guestOsVersion = defineModel<UI_I_OptionItem | null>('guestOsVersion', {
74
+ required: true,
75
+ })
76
+ const remoteConsoleOptionsInvalid = defineModel<boolean>(
77
+ 'remoteConsoleOptionsInvalid',
78
+ { required: true }
79
+ )
80
+
81
+ const props = defineProps<{
82
+ hardDisks: UI_I_SendDataNewHardDisk[] | null
83
+ cdDvdDrives: UI_I_SendDataNewCdDvdDrive[] | null
84
+ networks: UI_I_SendDataNewNetwork[] | null
85
+ isEdit: boolean
86
+ isClone: boolean
87
+ errorValidationFields: UI_I_ErrorValidationField[]
88
+ options?: UI_I_SendDataVmoptions
89
+ state?: string | number
90
+ compatibilityInfo?: string
91
+ }>()
92
+ const emits = defineEmits<{
93
+ (
94
+ event: 'change-boot-order',
95
+ value: [
96
+ UI_I_SendDataNewHardDisk[],
97
+ UI_I_SendDataNewCdDvdDrive[],
98
+ UI_I_SendDataNewNetwork[]
99
+ ]
100
+ ): void
101
+ (event: 'send-data', value: UI_I_SendDataVmoptions): void
102
+ (event: 'invalid', value: string[]): void
103
+ (event: 'remove-error-by-title', value: string): void
104
+ }>()
105
+
106
+ const { $store }: any = useNuxtApp()
107
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
108
+
109
+ const localization = computed<UI_I_Localization>(() => useLocal())
110
+
111
+ const sendDataRemoteConsoleOptions =
112
+ ref<UI_I_SendDataRemoteConsoleOptions | null>(null)
113
+ const sendDataRemoteConsoleOptionsMethod = (
114
+ data: UI_I_SendDataRemoteConsoleOptions
115
+ ): void => {
116
+ sendDataRemoteConsoleOptions.value = data
117
+ sendData()
118
+ }
119
+
120
+ const sendDataTools = ref<UI_I_SendDataTools | null>(null)
121
+ const sendDataToolsMethod = (data: UI_I_SendDataTools): void => {
122
+ sendDataTools.value = data
123
+ sendData()
124
+ }
125
+
126
+ const sendDataBootOptions = ref<UI_I_SendDataBootOptions | null>(null)
127
+ const sendDataBootOptionsMethod = (data: UI_I_SendDataBootOptions): void => {
128
+ sendDataBootOptions.value = data
129
+ sendData()
130
+ }
131
+
132
+ const sendData = (): void => {
133
+ emits('send-data', {
134
+ remote_console: sendDataRemoteConsoleOptions.value,
135
+ guest_tools: sendDataTools.value,
136
+ boot_options: sendDataBootOptions.value,
137
+ })
138
+ }
139
+
140
+ watch(
141
+ remoteConsoleOptionsInvalid,
142
+ (newValue) => {
143
+ const remoteConsoleOptions = newValue
144
+ ? localization.value.common.remoteConsoleOptions
145
+ : ''
146
+ emits('invalid', [remoteConsoleOptions])
147
+ },
148
+ { immediate: true }
149
+ )
150
+ </script>
151
+
152
+ <style scoped lang="scss"></style>
@@ -1,122 +1,128 @@
1
- <template>
2
- <div class="vm-options">
3
- <common-vm-actions-common-customize-hardware-vmoptions-general-options
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"
8
- :is-edit="props.isEdit"
9
- :is-clone="props.isClone"
10
- :state="props.state"
11
- />
12
- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options
13
- :error-validation-fields="props.errorValidationFields"
14
- :remote-console-options="props.options?.remote_console"
15
- :is-edit="props.isEdit"
16
- :state="props.state"
17
- @send-data="emits('send-data-remote-console-options', $event)"
18
- @invalid="remoteConsoleOptionsInvalid = $event"
19
- @remove-error-by-title="emits('remove-error-by-title', $event)"
20
- />
21
- <common-vm-actions-common-customize-hardware-vmoptions-tools
22
- :tools="props.options?.guest_tools?.enabled"
23
- @send-data="emits('send-data-tools', $event)"
24
- />
25
- <common-vm-actions-common-customize-hardware-vmoptions-boot-options
26
- :error-validation-fields="props.errorValidationFields"
27
- :hard-disks="props.hardDisks"
28
- :cd-dvd-drives="props.cdDvdDrives"
29
- :networks="props.networks"
30
- :boot-options="props.options?.boot_options"
31
- :is-edit="props.isEdit"
32
- :state="props.state"
33
- @change-boot-order="emits('change-boot-order', $event)"
34
- @send-data="emits('send-data-boot-options', $event)"
35
- @remove-error-by-title="emits('remove-error-by-title', $event)"
36
- />
37
- <div class="vm-hardware-version-wrap justify-end flex flex-1 mt-4">
38
- <span class="vm-hardware-version">
39
- {{ props.compatibilityInfo }}
40
- </span>
41
- </div>
42
- </div>
43
- </template>
44
-
45
- <script setup lang="ts">
46
- import type {
47
- UI_I_SendDataRemoteConsoleOptions,
48
- UI_I_SendDataTools,
49
- UI_I_SendDataBootOptions,
50
- UI_I_SendDataVmoptions,
51
- } from '~/components/common/vm/actions/common/customizeHardware/vmoptions/lib/models/interfaces'
52
- import type {
53
- UI_I_SendDataNewCdDvdDrive,
54
- UI_I_SendDataNewHardDisk,
55
- UI_I_SendDataNewNetwork,
56
- } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
57
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
58
-
59
- const vmName = defineModel<string>('vmName', { required: true })
60
- const guestMachineType = defineModel<string>('guestMachineType', {
61
- required: true,
62
- })
63
- const guestOsFamily = defineModel<string>('guestOsFamily', { required: true })
64
- const guestOsVersion = defineModel<string>('guestOsVersion', {
65
- required: true,
66
- })
67
- const remoteConsoleOptionsInvalid = defineModel<boolean>(
68
- 'remoteConsoleOptionsInvalid',
69
- { required: true }
70
- )
71
-
72
- const props = defineProps<{
73
- hardDisks: UI_I_SendDataNewHardDisk[] | null
74
- cdDvdDrives: UI_I_SendDataNewCdDvdDrive[] | null
75
- networks: UI_I_SendDataNewNetwork[] | null
76
- isEdit: boolean
77
- isClone: boolean
78
- errorValidationFields: UI_I_ErrorValidationField[]
79
- options?: UI_I_SendDataVmoptions
80
- state?: string | number
81
- compatibilityInfo?: string
82
- }>()
83
- const emits = defineEmits<{
84
- (
85
- event: 'change-boot-order',
86
- value: [
87
- UI_I_SendDataNewHardDisk[],
88
- UI_I_SendDataNewCdDvdDrive[],
89
- UI_I_SendDataNewNetwork[]
90
- ]
91
- ): void
92
- (
93
- event: 'send-data-remote-console-options',
94
- value: UI_I_SendDataRemoteConsoleOptions
95
- ): void
96
- (event: 'send-data-tools', value: UI_I_SendDataTools): void
97
- (event: 'send-data-boot-options', value: UI_I_SendDataBootOptions): void
98
- (event: 'remove-error-by-title', value: string): void
99
- }>()
100
- </script>
101
-
102
- <style scoped lang="scss">
103
- .vm-options {
104
- height: calc(100% - 20px);
105
- display: flex;
106
- flex-direction: column;
107
- gap: 12px;
108
- margin-top: 20px;
109
- padding: 0 0 12px;
110
- overflow: auto;
111
-
112
- .vm-hardware-version-wrap {
113
- align-items: flex-end;
114
- text-align: right;
115
-
116
- .vm-hardware-version {
117
- font-size: 13px;
118
- color: #9da6ad; // for light and dark
119
- }
120
- }
121
- }
122
- </style>
1
+ <template>
2
+ <div class="vm-options">
3
+ <common-vm-actions-common-customize-hardware-vmoptions-general-options
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"
8
+ :is-edit="props.isEdit"
9
+ :is-clone="props.isClone"
10
+ :state="props.state"
11
+ />
12
+ <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options
13
+ :error-validation-fields="props.errorValidationFields"
14
+ :remote-console-options="props.options?.remote_console"
15
+ :is-edit="props.isEdit"
16
+ :state="props.state"
17
+ @send-data="emits('send-data-remote-console-options', $event)"
18
+ @invalid="remoteConsoleOptionsInvalid = $event"
19
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
20
+ />
21
+ <common-vm-actions-common-customize-hardware-vmoptions-tools
22
+ :tools="props.options?.guest_tools?.enabled"
23
+ @send-data="emits('send-data-tools', $event)"
24
+ />
25
+ <common-vm-actions-common-customize-hardware-vmoptions-boot-options
26
+ :error-validation-fields="props.errorValidationFields"
27
+ :hard-disks="props.hardDisks"
28
+ :cd-dvd-drives="props.cdDvdDrives"
29
+ :networks="props.networks"
30
+ :boot-options="props.options?.boot_options"
31
+ :is-edit="props.isEdit"
32
+ :state="props.state"
33
+ @change-boot-order="emits('change-boot-order', $event)"
34
+ @send-data="emits('send-data-boot-options', $event)"
35
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
36
+ />
37
+ <div class="vm-hardware-version-wrap justify-end flex flex-1 mt-4">
38
+ <span class="vm-hardware-version">
39
+ {{ props.compatibilityInfo }}
40
+ </span>
41
+ </div>
42
+ </div>
43
+ </template>
44
+
45
+ <script setup lang="ts">
46
+ import type {
47
+ UI_I_SendDataRemoteConsoleOptions,
48
+ UI_I_SendDataTools,
49
+ UI_I_SendDataBootOptions,
50
+ UI_I_SendDataVmoptions,
51
+ } from '~/components/common/vm/actions/common/customizeHardware/vmoptions/lib/models/interfaces'
52
+ import type {
53
+ UI_I_SendDataNewCdDvdDrive,
54
+ UI_I_SendDataNewHardDisk,
55
+ UI_I_SendDataNewNetwork,
56
+ } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
57
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
58
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
59
+
60
+ const vmName = defineModel<string>('vmName', { required: true })
61
+ const guestMachineType = defineModel<UI_I_OptionItem | null>(
62
+ 'guestMachineType',
63
+ {
64
+ required: true,
65
+ }
66
+ )
67
+ const guestOsFamily = defineModel<UI_I_OptionItem | null>('guestOsFamily', {
68
+ required: true,
69
+ })
70
+ const guestOsVersion = defineModel<UI_I_OptionItem | null>('guestOsVersion', {
71
+ required: true,
72
+ })
73
+ const remoteConsoleOptionsInvalid = defineModel<boolean>(
74
+ 'remoteConsoleOptionsInvalid',
75
+ { required: true }
76
+ )
77
+
78
+ const props = defineProps<{
79
+ hardDisks: UI_I_SendDataNewHardDisk[] | null
80
+ cdDvdDrives: UI_I_SendDataNewCdDvdDrive[] | null
81
+ networks: UI_I_SendDataNewNetwork[] | null
82
+ isEdit: boolean
83
+ isClone: boolean
84
+ errorValidationFields: UI_I_ErrorValidationField[]
85
+ options?: UI_I_SendDataVmoptions
86
+ state?: string | number
87
+ compatibilityInfo?: string
88
+ }>()
89
+ const emits = defineEmits<{
90
+ (
91
+ event: 'change-boot-order',
92
+ value: [
93
+ UI_I_SendDataNewHardDisk[],
94
+ UI_I_SendDataNewCdDvdDrive[],
95
+ UI_I_SendDataNewNetwork[]
96
+ ]
97
+ ): void
98
+ (
99
+ event: 'send-data-remote-console-options',
100
+ value: UI_I_SendDataRemoteConsoleOptions
101
+ ): void
102
+ (event: 'send-data-tools', value: UI_I_SendDataTools): void
103
+ (event: 'send-data-boot-options', value: UI_I_SendDataBootOptions): void
104
+ (event: 'remove-error-by-title', value: string): void
105
+ }>()
106
+ </script>
107
+
108
+ <style scoped lang="scss">
109
+ .vm-options {
110
+ height: calc(100% - 20px);
111
+ display: flex;
112
+ flex-direction: column;
113
+ gap: 12px;
114
+ margin-top: 20px;
115
+ padding: 0 0 12px;
116
+ overflow: auto;
117
+
118
+ .vm-hardware-version-wrap {
119
+ align-items: flex-end;
120
+ text-align: right;
121
+
122
+ .vm-hardware-version {
123
+ font-size: 13px;
124
+ color: #9da6ad; // for light and dark
125
+ }
126
+ }
127
+ }
128
+ </style>