bfg-common 1.5.696 → 1.5.698

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 (102) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  3. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  4. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  5. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  6. package/assets/scss/common/icons/icons-2.scss +12 -0
  7. package/components/atoms/TheIcon3.vue +50 -50
  8. package/components/atoms/collapse/CollapseNav.vue +170 -170
  9. package/components/atoms/perPage/PerPage.vue +58 -58
  10. package/components/atoms/switch/Switch.vue +103 -103
  11. package/components/atoms/table/dataGrid/DataGrid.vue +1718 -1718
  12. package/components/atoms/table/dataGrid/DataGridPagination.vue +97 -97
  13. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  14. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  15. package/components/common/backup/storage/actions/add/lib/utils.ts +51 -51
  16. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  17. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  18. package/components/common/diagramMain/port/Port.vue +580 -580
  19. package/components/common/layout/theHeader/TheHeaderNew.vue +315 -315
  20. package/components/common/layout/theHeader/TheHeaderOld.vue +262 -262
  21. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  22. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  23. package/components/common/layout/theHeader/userMenu/modals/preferences/PreferencesOld.vue +144 -144
  24. package/components/common/layout/theHeader/userMenu/modals/preferences/lib/models/types.ts +7 -7
  25. package/components/common/pages/backups/DetailView.vue +52 -52
  26. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  27. package/components/common/pages/backups/modals/Modals.vue +243 -243
  28. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  29. package/components/common/pages/backups/modals/createBackup/lib/config/readyToCompleteOptions.ts +69 -69
  30. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  31. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  32. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  33. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  34. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  35. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  36. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  37. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  38. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  39. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  40. package/components/common/select/radio/RadioGroup.vue +137 -137
  41. package/components/common/spiceConsole/Drawer.vue +420 -420
  42. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  43. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  44. package/components/common/tools/Actions.vue +207 -207
  45. package/components/common/treeView/TreeView.vue +52 -52
  46. package/components/common/vm/actions/clone/lib/config/steps.ts +295 -295
  47. package/components/common/vm/actions/clone/new/New.vue +438 -438
  48. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +706 -706
  49. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  50. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +283 -283
  51. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +489 -489
  52. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +253 -253
  53. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +156 -156
  54. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  55. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  56. package/components/common/vm/actions/common/select/options/New.vue +264 -264
  57. package/components/common/vm/actions/common/select/options/Old.vue +109 -109
  58. package/components/common/vm/actions/common/select/options/Options.vue +58 -58
  59. package/components/common/vm/actions/common/select/storage/Old.vue +125 -125
  60. package/components/common/vm/actions/common/select/storage/new/New.vue +311 -311
  61. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  62. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  63. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  64. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  65. package/components/common/wizards/common/compatibility/Compatibility.vue +35 -35
  66. package/components/common/wizards/common/steps/computeResource/New.vue +93 -93
  67. package/components/common/wizards/common/steps/name/Name.vue +178 -178
  68. package/components/common/wizards/common/steps/name/New.vue +221 -221
  69. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  70. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  71. package/components/common/wizards/common/steps/name/location/New.vue +40 -40
  72. package/components/common/wizards/datastore/add/Add.vue +228 -228
  73. package/components/common/wizards/datastore/add/lib/utils.ts +85 -85
  74. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceNew.vue +232 -232
  75. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceOld.vue +231 -231
  76. package/components/common/wizards/datastore/add/steps/nameAndDevice/advancedOptions/AdvancedOptions.vue +43 -43
  77. package/components/common/wizards/datastore/add/steps/nameAndDevice/advancedOptions/New.vue +114 -101
  78. package/components/common/wizards/datastore/add/steps/nameAndDevice/advancedOptions/Old.vue +114 -101
  79. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  80. package/composables/useAppVersion.ts +21 -21
  81. package/composables/useEnvLanguage.ts +22 -22
  82. package/composables/useLocal.ts +6 -6
  83. package/composables/useLocalCommon.ts +39 -39
  84. package/package.json +1 -1
  85. package/plugins/console.ts +21 -21
  86. package/plugins/date.ts +375 -375
  87. package/plugins/mouse.ts +21 -21
  88. package/plugins/panelStates.ts +70 -70
  89. package/plugins/text.ts +59 -59
  90. package/public/spice-console/application/clientgui.js +854 -854
  91. package/public/spice-console/application/packetfactory.js +211 -211
  92. package/public/spice-console/application/virtualmouse.js +147 -147
  93. package/public/spice-console/lib/images/bitmap.js +203 -203
  94. package/public/spice-console/network/spicechannel.js +440 -440
  95. package/public/spice-console/process/cursorprocess.js +128 -128
  96. package/public/spice-console/process/inputprocess.js +227 -227
  97. package/public/spice-console/process/mainprocess.js +212 -212
  98. package/public/spice-console/run.js +210 -210
  99. package/store/main/mutations.ts +7 -7
  100. package/store/main/state.ts +7 -7
  101. package/store/tasks/mappers/recentTasks.ts +123 -123
  102. package/store/tasks/mutations.ts +82 -82
@@ -1,253 +1,253 @@
1
- <template>
2
- <component
3
- :is="currentComponent"
4
- v-model:selected-type="selectedType"
5
- v-model:direct-path-io="directPathIo"
6
- v-model:dynamic-direct-path-io="dynamicDirectPathIo"
7
- v-model:nvidia-grid-profile="nvidiaGridProfile"
8
- :index="props.index"
9
- :passthrough-devices="props.passthroughDevices"
10
- :mediated-devices="props.mediatedDevices"
11
- :type="props.type"
12
- :is-removable="isRemovable"
13
- :label="label"
14
- :selected-label="selectedLabel"
15
- :pci-device-type-options="pciDeviceTypeOptions"
16
- @remove="emits('remove')"
17
- />
18
- </template>
19
-
20
- <script setup lang="ts">
21
- import type { UI_I_Localization } from '~/lib/models/interfaces'
22
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
23
- import type { UI_I_SendDataNewPciDevice } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
24
- import type { UI_T_PciDeviceType } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/types'
25
- import type {
26
- UI_I_MediatedDevice,
27
- UI_I_PciDevice,
28
- } from '~/lib/models/store/vm/interfaces'
29
- import type { UI_I_Option } from '~/components/atoms/select/lib/models/interfaces'
30
- import { pciDeviceTypeOptionsFunc } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/lib/config/options'
31
-
32
- const address = defineModel<string>('address')
33
- const vendorName = defineModel<string>('vendorName')
34
- const className = defineModel<string>('className')
35
- const deviceName = defineModel<string>('deviceName')
36
- const mediatedDevice = defineModel<string>('mediatedDevice')
37
- const mediatedDeviceUuid = defineModel<string>('mediatedDeviceUuid')
38
-
39
- const props = withDefaults(
40
- defineProps<{
41
- index: number
42
- passthroughDevices: UI_I_PciDevice[]
43
- mediatedDevices: UI_I_MediatedDevice[]
44
- type: UI_T_PciDeviceType
45
- isEdit: boolean
46
- state?: string | number
47
- // errorValidationFields: UI_I_ErrorValidationField<string>[]
48
- }>(),
49
- {
50
- state: undefined,
51
- }
52
- )
53
- const emits = defineEmits<{
54
- (event: 'remove'): void
55
- }>()
56
-
57
- const { $store }: any = useNuxtApp()
58
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
59
- const currentComponent = computed(() =>
60
- isNewView.value
61
- ? defineAsyncComponent(() => import('./New.vue'))
62
- : defineAsyncComponent(() => import('./Old.vue'))
63
- )
64
-
65
- const localization = computed<UI_I_Localization>(() => useLocal())
66
-
67
- const isRunning = computed<boolean>(() => {
68
- return props.state === 2
69
- })
70
-
71
- const isRemovable = computed<boolean>(() => {
72
- return !props.isEdit || !isRunning.value
73
- })
74
-
75
- const label = computed<string>(() => {
76
- if (props.type === 'edit')
77
- return `${localization.value.common.newPciDevice} ${props.index + 1}`
78
-
79
- return `${localization.value.common.pciDevice} *`
80
- })
81
-
82
- const selectedLabel = computed<string>(() => {
83
- if (address.value) {
84
- return `${address.value} | ${deviceName.value}`
85
- }
86
- switch (selectedType.value.value) {
87
- case 'direct_path_io':
88
- return `${directPathIo.value?.address} | ${directPathIo.value?.device_name}`
89
- case 'dynamic_direct_path_io':
90
- return `${dynamicDirectPathIo.value?.address} | ${dynamicDirectPathIo.value?.device_name}`
91
- default:
92
- return nvidiaGridProfile.value?.text
93
- }
94
- })
95
-
96
- const pciDeviceTypeOptions = ref<UI_I_OptionItem[]>(
97
- pciDeviceTypeOptionsFunc(
98
- !props.passthroughDevices.length,
99
- !props.mediatedDevices.length
100
- )
101
- )
102
- const selectedType = ref<UI_I_OptionItem>(pciDeviceTypeOptions.value[0])
103
- pciDeviceTypeOptions.value.forEach((option) => {
104
- if (!option.disabled) selectedType.value = option
105
- })
106
-
107
- const directPathIo = ref<string>('') /// TODO
108
- const dynamicDirectPathIo = ref<UI_I_PciDevice>(props.passthroughDevices[0])
109
- const nvidiaGridProfile = ref<UI_I_Option | null>(null)
110
-
111
- const set = (): void => {
112
- // const passthroughDevice = props.passthroughDevices.find(
113
- // (item) => item.address === newValue.address
114
- // )
115
- // passthroughDevice && (directPathIo.value = passthroughDevice) // Todo change
116
- // directPathIo.value = newValue1
117
- const passthroughDevice = props.passthroughDevices.find((device) => {
118
- return (
119
- device.class_name + '_' + device.address ===
120
- className.value + '_' + address.value
121
- )
122
- })
123
- if (passthroughDevice) {
124
- dynamicDirectPathIo.value = passthroughDevice
125
- }
126
-
127
- const mediatedDevice = props.mediatedDevices.find((device) => {
128
- return (
129
- device.profile_name + '_' + device.root_device ===
130
- className.value + '_' + address.value
131
- )
132
- })
133
- if (mediatedDevice) {
134
- nvidiaGridProfile.value = {
135
- text: mediatedDevice.human_readable,
136
- value: mediatedDevice.profile_name + '_' + mediatedDevice.root_device,
137
- }
138
-
139
- selectedType.value =
140
- pciDeviceTypeOptions.value.find(
141
- (option) => option.value === 'nvidia_grid'
142
- ) || selectedType.value
143
- }
144
- }
145
- watch(
146
- () => props.mediatedDevices,
147
- () => {
148
- // if (props.isEdit) set()
149
- set() // for edit
150
- },
151
- { immediate: true, deep: true }
152
- )
153
-
154
- // watch(
155
- // [() => props.pciDevice, () => props.mediatedDevices],
156
- // ([newValue1]) => {
157
- // // const passthroughDevice = props.passthroughDevices.find(
158
- // // (item) => item.address === newValue.address
159
- // // )
160
- // // passthroughDevice && (directPathIo.value = passthroughDevice) // Todo change
161
- // if (newValue1) {
162
- // // directPathIo.value = newValue1
163
- // const passthroughDevice = props.passthroughDevices.find((device) => {
164
- // return (
165
- // device.class_name + '_' + device.address ===
166
- // newValue1.class_name + '_' + newValue1.address
167
- // )
168
- // })
169
- // if (passthroughDevice) {
170
- // dynamicDirectPathIo.value = passthroughDevice
171
- // }
172
- //
173
- // const mediatedDevice = props.mediatedDevices.find((device) => {
174
- // return (
175
- // device.profile_name + '_' + device.root_device ===
176
- // newValue1.class_name + '_' + newValue1.address
177
- // )
178
- // })
179
- // if (mediatedDevice) {
180
- // nvidiaGridProfile.value = {
181
- // text: mediatedDevice.human_readable,
182
- // value: mediatedDevice.profile_name + '_' + mediatedDevice.root_device,
183
- // }
184
- //
185
- // selectedType.value =
186
- // pciDeviceTypeOptions.value.find(
187
- // (option) => option.value === 'nvidia_grid'
188
- // ) || selectedType.value
189
- // }
190
- // }
191
- // },
192
- // { immediate: true, deep: true }
193
- // )
194
-
195
- const sendData = computed<UI_I_SendDataNewPciDevice>(() => {
196
- const nvidia = props.mediatedDevices.find(
197
- (device) =>
198
- nvidiaGridProfile.value?.value ===
199
- device.profile_name + '_' + device.root_device
200
- )
201
- switch (selectedType.value.value) {
202
- case 'direct_path_io':
203
- return {
204
- address: '',
205
- vendor_name: '',
206
- class_name: '',
207
- device_name: '',
208
- mediated_device: false,
209
- }
210
- case 'dynamic_direct_path_io':
211
- return {
212
- address: dynamicDirectPathIo.value?.address || '',
213
- vendor_name: dynamicDirectPathIo.value?.vendor_name || '',
214
- class_name: dynamicDirectPathIo.value?.class_name || '',
215
- device_name: dynamicDirectPathIo.value?.device_name || '',
216
- mediated_device: false,
217
- }
218
- case 'nvidia_grid':
219
- return {
220
- address: nvidia?.root_device || '',
221
- vendor_name: '',
222
- class_name: nvidia?.profile_name || '',
223
- device_name: nvidia?.name || '',
224
- mediated_device: true,
225
- mediated_device_uuid: '',
226
- }
227
- default:
228
- return {
229
- address: '',
230
- vendor_name: '',
231
- class_name: '',
232
- device_name: '',
233
- mediated_device: false,
234
- }
235
- }
236
- })
237
-
238
- watch(
239
- sendData,
240
- (newValue) => {
241
- address.value = newValue.address
242
- vendorName.value = newValue.vendor_name
243
- className.value = newValue.class_name
244
- deviceName.value = newValue.device_name
245
- mediatedDevice.value = newValue.mediated_device
246
- mediatedDeviceUuid.value = newValue.mediated_device_uuid || ''
247
- // emits('send-data', props.type === 'edit' ? props.pciDevice : newValue)
248
- },
249
- { immediate: true }
250
- )
251
- </script>
252
-
253
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <component
3
+ :is="currentComponent"
4
+ v-model:selected-type="selectedType"
5
+ v-model:direct-path-io="directPathIo"
6
+ v-model:dynamic-direct-path-io="dynamicDirectPathIo"
7
+ v-model:nvidia-grid-profile="nvidiaGridProfile"
8
+ :index="props.index"
9
+ :passthrough-devices="props.passthroughDevices"
10
+ :mediated-devices="props.mediatedDevices"
11
+ :type="props.type"
12
+ :is-removable="isRemovable"
13
+ :label="label"
14
+ :selected-label="selectedLabel"
15
+ :pci-device-type-options="pciDeviceTypeOptions"
16
+ @remove="emits('remove')"
17
+ />
18
+ </template>
19
+
20
+ <script setup lang="ts">
21
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
22
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
23
+ import type { UI_I_SendDataNewPciDevice } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
24
+ import type { UI_T_PciDeviceType } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/types'
25
+ import type {
26
+ UI_I_MediatedDevice,
27
+ UI_I_PciDevice,
28
+ } from '~/lib/models/store/vm/interfaces'
29
+ import type { UI_I_Option } from '~/components/atoms/select/lib/models/interfaces'
30
+ import { pciDeviceTypeOptionsFunc } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/lib/config/options'
31
+
32
+ const address = defineModel<string>('address')
33
+ const vendorName = defineModel<string>('vendorName')
34
+ const className = defineModel<string>('className')
35
+ const deviceName = defineModel<string>('deviceName')
36
+ const mediatedDevice = defineModel<string>('mediatedDevice')
37
+ const mediatedDeviceUuid = defineModel<string>('mediatedDeviceUuid')
38
+
39
+ const props = withDefaults(
40
+ defineProps<{
41
+ index: number
42
+ passthroughDevices: UI_I_PciDevice[]
43
+ mediatedDevices: UI_I_MediatedDevice[]
44
+ type: UI_T_PciDeviceType
45
+ isEdit: boolean
46
+ state?: string | number
47
+ // errorValidationFields: UI_I_ErrorValidationField<string>[]
48
+ }>(),
49
+ {
50
+ state: undefined,
51
+ }
52
+ )
53
+ const emits = defineEmits<{
54
+ (event: 'remove'): void
55
+ }>()
56
+
57
+ const { $store }: any = useNuxtApp()
58
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
59
+ const currentComponent = computed(() =>
60
+ isNewView.value
61
+ ? defineAsyncComponent(() => import('./New.vue'))
62
+ : defineAsyncComponent(() => import('./Old.vue'))
63
+ )
64
+
65
+ const localization = computed<UI_I_Localization>(() => useLocal())
66
+
67
+ const isRunning = computed<boolean>(() => {
68
+ return props.state === 2
69
+ })
70
+
71
+ const isRemovable = computed<boolean>(() => {
72
+ return !props.isEdit || !isRunning.value
73
+ })
74
+
75
+ const label = computed<string>(() => {
76
+ if (props.type === 'edit')
77
+ return `${localization.value.common.newPciDevice} ${props.index + 1}`
78
+
79
+ return `${localization.value.common.pciDevice} *`
80
+ })
81
+
82
+ const selectedLabel = computed<string>(() => {
83
+ if (address.value) {
84
+ return `${address.value} | ${deviceName.value}`
85
+ }
86
+ switch (selectedType.value.value) {
87
+ case 'direct_path_io':
88
+ return `${directPathIo.value?.address} | ${directPathIo.value?.device_name}`
89
+ case 'dynamic_direct_path_io':
90
+ return `${dynamicDirectPathIo.value?.address} | ${dynamicDirectPathIo.value?.device_name}`
91
+ default:
92
+ return nvidiaGridProfile.value?.text
93
+ }
94
+ })
95
+
96
+ const pciDeviceTypeOptions = ref<UI_I_OptionItem[]>(
97
+ pciDeviceTypeOptionsFunc(
98
+ !props.passthroughDevices.length,
99
+ !props.mediatedDevices.length
100
+ )
101
+ )
102
+ const selectedType = ref<UI_I_OptionItem>(pciDeviceTypeOptions.value[0])
103
+ pciDeviceTypeOptions.value.forEach((option) => {
104
+ if (!option.disabled) selectedType.value = option
105
+ })
106
+
107
+ const directPathIo = ref<string>('') /// TODO
108
+ const dynamicDirectPathIo = ref<UI_I_PciDevice>(props.passthroughDevices[0])
109
+ const nvidiaGridProfile = ref<UI_I_Option | null>(null)
110
+
111
+ const set = (): void => {
112
+ // const passthroughDevice = props.passthroughDevices.find(
113
+ // (item) => item.address === newValue.address
114
+ // )
115
+ // passthroughDevice && (directPathIo.value = passthroughDevice) // Todo change
116
+ // directPathIo.value = newValue1
117
+ const passthroughDevice = props.passthroughDevices.find((device) => {
118
+ return (
119
+ device.class_name + '_' + device.address ===
120
+ className.value + '_' + address.value
121
+ )
122
+ })
123
+ if (passthroughDevice) {
124
+ dynamicDirectPathIo.value = passthroughDevice
125
+ }
126
+
127
+ const mediatedDevice = props.mediatedDevices.find((device) => {
128
+ return (
129
+ device.profile_name + '_' + device.root_device ===
130
+ className.value + '_' + address.value
131
+ )
132
+ })
133
+ if (mediatedDevice) {
134
+ nvidiaGridProfile.value = {
135
+ text: mediatedDevice.human_readable,
136
+ value: mediatedDevice.profile_name + '_' + mediatedDevice.root_device,
137
+ }
138
+
139
+ selectedType.value =
140
+ pciDeviceTypeOptions.value.find(
141
+ (option) => option.value === 'nvidia_grid'
142
+ ) || selectedType.value
143
+ }
144
+ }
145
+ watch(
146
+ () => props.mediatedDevices,
147
+ () => {
148
+ // if (props.isEdit) set()
149
+ set() // for edit
150
+ },
151
+ { immediate: true, deep: true }
152
+ )
153
+
154
+ // watch(
155
+ // [() => props.pciDevice, () => props.mediatedDevices],
156
+ // ([newValue1]) => {
157
+ // // const passthroughDevice = props.passthroughDevices.find(
158
+ // // (item) => item.address === newValue.address
159
+ // // )
160
+ // // passthroughDevice && (directPathIo.value = passthroughDevice) // Todo change
161
+ // if (newValue1) {
162
+ // // directPathIo.value = newValue1
163
+ // const passthroughDevice = props.passthroughDevices.find((device) => {
164
+ // return (
165
+ // device.class_name + '_' + device.address ===
166
+ // newValue1.class_name + '_' + newValue1.address
167
+ // )
168
+ // })
169
+ // if (passthroughDevice) {
170
+ // dynamicDirectPathIo.value = passthroughDevice
171
+ // }
172
+ //
173
+ // const mediatedDevice = props.mediatedDevices.find((device) => {
174
+ // return (
175
+ // device.profile_name + '_' + device.root_device ===
176
+ // newValue1.class_name + '_' + newValue1.address
177
+ // )
178
+ // })
179
+ // if (mediatedDevice) {
180
+ // nvidiaGridProfile.value = {
181
+ // text: mediatedDevice.human_readable,
182
+ // value: mediatedDevice.profile_name + '_' + mediatedDevice.root_device,
183
+ // }
184
+ //
185
+ // selectedType.value =
186
+ // pciDeviceTypeOptions.value.find(
187
+ // (option) => option.value === 'nvidia_grid'
188
+ // ) || selectedType.value
189
+ // }
190
+ // }
191
+ // },
192
+ // { immediate: true, deep: true }
193
+ // )
194
+
195
+ const sendData = computed<UI_I_SendDataNewPciDevice>(() => {
196
+ const nvidia = props.mediatedDevices.find(
197
+ (device) =>
198
+ nvidiaGridProfile.value?.value ===
199
+ device.profile_name + '_' + device.root_device
200
+ )
201
+ switch (selectedType.value.value) {
202
+ case 'direct_path_io':
203
+ return {
204
+ address: '',
205
+ vendor_name: '',
206
+ class_name: '',
207
+ device_name: '',
208
+ mediated_device: false,
209
+ }
210
+ case 'dynamic_direct_path_io':
211
+ return {
212
+ address: dynamicDirectPathIo.value?.address || '',
213
+ vendor_name: dynamicDirectPathIo.value?.vendor_name || '',
214
+ class_name: dynamicDirectPathIo.value?.class_name || '',
215
+ device_name: dynamicDirectPathIo.value?.device_name || '',
216
+ mediated_device: false,
217
+ }
218
+ case 'nvidia_grid':
219
+ return {
220
+ address: nvidia?.root_device || '',
221
+ vendor_name: '',
222
+ class_name: nvidia?.profile_name || '',
223
+ device_name: nvidia?.name || '',
224
+ mediated_device: true,
225
+ mediated_device_uuid: '',
226
+ }
227
+ default:
228
+ return {
229
+ address: '',
230
+ vendor_name: '',
231
+ class_name: '',
232
+ device_name: '',
233
+ mediated_device: false,
234
+ }
235
+ }
236
+ })
237
+
238
+ watch(
239
+ sendData,
240
+ (newValue) => {
241
+ address.value = newValue.address
242
+ vendorName.value = newValue.vendor_name
243
+ className.value = newValue.class_name
244
+ deviceName.value = newValue.device_name
245
+ mediatedDevice.value = newValue.mediated_device
246
+ mediatedDeviceUuid.value = newValue.mediated_device_uuid || ''
247
+ // emits('send-data', props.type === 'edit' ? props.pciDevice : newValue)
248
+ },
249
+ { immediate: true }
250
+ )
251
+ </script>
252
+
253
+ <style scoped lang="scss"></style>