bfg-common 1.5.359 → 1.5.360

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 (141) 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 +1 -0
  7. package/assets/localization/local_en.json +1 -0
  8. package/assets/localization/local_hy.json +1 -0
  9. package/assets/localization/local_kk.json +1 -0
  10. package/assets/localization/local_ru.json +1 -0
  11. package/assets/localization/local_zh.json +1 -0
  12. package/components/atoms/TheIcon3.vue +50 -50
  13. package/components/atoms/collapse/CollapseNav.vue +170 -170
  14. package/components/atoms/collapse/CollapseNavItem.vue +226 -226
  15. package/components/atoms/nav/NavBar.vue +147 -147
  16. package/components/atoms/perPage/PerPage.vue +58 -58
  17. package/components/atoms/table/dataGrid/DataGrid.vue +1717 -1717
  18. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  19. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  20. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  21. package/components/common/backup/storage/actions/add/lib/config/steps.ts +168 -168
  22. package/components/common/backup/storage/actions/add/steps/hostAccessibility/HostAccessibility.vue +52 -52
  23. package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyComplete.vue +45 -45
  24. package/components/common/backup/storage/actions/delete/Delete.vue +65 -65
  25. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  26. package/components/common/context/lib/models/interfaces.ts +33 -33
  27. package/components/common/diagramMain/DiagramMain.vue +897 -897
  28. package/components/common/diagramMain/modals/lib/config/networkModal.ts +398 -398
  29. package/components/common/diagramMain/network/Network.vue +141 -141
  30. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  31. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  32. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  33. package/components/common/pages/home/headline/Headline.vue +45 -45
  34. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  35. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  36. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  37. package/components/common/pages/home/widgets/WidgetsNew.vue +88 -88
  38. package/components/common/pages/home/widgets/WidgetsOld.vue +36 -36
  39. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  40. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  41. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  42. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  43. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  44. package/components/common/pages/packages/Packages.vue +208 -208
  45. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  46. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  47. package/components/common/recursionTree/RecursionTree.vue +223 -223
  48. package/components/common/select/button/ButtonDropdown.vue +112 -112
  49. package/components/common/spiceConsole/Drawer.vue +377 -377
  50. package/components/common/spiceConsole/SpiceConsole.vue +127 -127
  51. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  52. package/components/common/tools/Actions.vue +207 -207
  53. package/components/common/vm/actions/add/Old.vue +388 -388
  54. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  55. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  56. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  57. package/components/common/vm/actions/clone/Clone.vue +823 -823
  58. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  59. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  60. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +321 -321
  61. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +227 -227
  62. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +100 -100
  63. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  64. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +78 -78
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipNew.vue +154 -154
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/config/dropdownItems.ts +155 -155
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +307 -307
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +385 -385
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +85 -85
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -288
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  81. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  82. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  83. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  84. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  85. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  86. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  87. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  88. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  89. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  90. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCard.vue +154 -154
  91. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  92. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +155 -155
  93. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +130 -130
  94. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsOld.vue +113 -113
  95. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  96. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  97. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  98. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptions.vue +95 -95
  99. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsOld.vue +155 -155
  100. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  101. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapOld.vue +44 -44
  102. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  103. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  104. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  105. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  106. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +143 -143
  107. package/components/common/vm/actions/common/select/computeResource/New.vue +184 -184
  108. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +131 -131
  109. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  110. package/components/common/vm/actions/common/select/createType/lib/config/items.ts +48 -48
  111. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  112. package/components/common/vm/actions/common/select/name/Name.vue +174 -174
  113. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  114. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  115. package/components/common/vm/actions/common/select/storage/Storage.vue +155 -155
  116. package/components/common/vm/actions/common/select/storage/new/New.vue +294 -294
  117. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  118. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  119. package/components/common/vm/actions/editSettings/EditSettings.vue +242 -242
  120. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  121. package/components/common/vmt/actions/add/lib/models/interfaces.ts +23 -23
  122. package/components/common/wizards/network/add/steps/SelectConnectionType.vue +104 -104
  123. package/components/common/wizards/network/add/steps/SelectedTargetDevice.vue +467 -467
  124. package/components/common/wizards/vm/migrate/Migrate.vue +349 -349
  125. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  126. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  127. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  128. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  129. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  130. package/components/common/wizards/vm/migrate/select/type/lib/config/typeOptions.ts +45 -45
  131. package/composables/productNameLocal.ts +30 -30
  132. package/composables/useAppVersion.ts +21 -21
  133. package/package.json +1 -1
  134. package/plugins/date.ts +233 -233
  135. package/plugins/panelStates.ts +70 -70
  136. package/plugins/text.ts +59 -59
  137. package/public/spice-console/lib/images/bitmap.js +203 -203
  138. package/public/spice-console/network/spicechannel.js +387 -387
  139. package/store/main/mutations.ts +7 -7
  140. package/store/main/state.ts +7 -7
  141. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,288 +1,288 @@
1
- <template>
2
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-network-new
3
- v-if="isNewView"
4
- v-model:selected-location="selectedLocation"
5
- v-model:adapter-type="adapterType"
6
- v-model:mac-address="macAddress"
7
- v-model:mac-address-type="macAddressType"
8
- v-model:new-network-invalid="newNetworkInvalid"
9
- :index="props.index"
10
- :type="props.type"
11
- :networks-table="props.networksTable"
12
- :error-validation-fields="props.errorValidationFields"
13
- :is-removable="isRemovable"
14
- :label="label"
15
- :error-text="apiError"
16
- :type-error="typeError"
17
- :location-options="locationOptions"
18
- :is-running="isRunning"
19
- :location-modal-is-show="locationModalIsShow"
20
- :state="props.state"
21
- @remove="emits('remove')"
22
- @remove-error-by-title="onRemoveValidationError"
23
- @change-location="changeLocation"
24
- @hide-location-modal="onHideLocationModal"
25
- @select-location="onSelectLocation"
26
- />
27
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-network-old
28
- v-else
29
- v-model:selected-location="selectedLocation"
30
- v-model:adapter-type="adapterType"
31
- v-model:mac-address="macAddress"
32
- v-model:mac-address-type="macAddressType"
33
- v-model:new-network-invalid="newNetworkInvalid"
34
- :index="props.index"
35
- :type="props.type"
36
- :networks-table="props.networksTable"
37
- :error-validation-fields="props.errorValidationFields"
38
- :is-removable="isRemovable"
39
- :label="label"
40
- :error-text="apiError"
41
- :type-error="typeError"
42
- :location-options="locationOptions"
43
- :is-running="isRunning"
44
- :location-modal-is-show="locationModalIsShow"
45
- :state="props.state"
46
- @remove="emits('remove')"
47
- @remove-error-by-title="onRemoveValidationError"
48
- @change-location="changeLocation"
49
- @hide-location-modal="onHideLocationModal"
50
- @select-location="onSelectLocation"
51
- />
52
- </template>
53
-
54
- <script setup lang="ts">
55
- import type { UI_T_Project } from '~/lib/models/types'
56
- import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
57
- import type { UI_I_NetworkTableItem } from '~/lib/models/store/network/interfaces'
58
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
59
- import type { UI_I_SendDataNewNetwork } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
60
- import type { UI_T_NetworkType } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/types'
61
- import type {
62
- UI_I_Localization,
63
- UI_I_HTMLSelectElement,
64
- } from '~/lib/models/interfaces'
65
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
66
-
67
- const props = defineProps<{
68
- project: UI_T_Project
69
- index: number
70
- type: UI_T_NetworkType
71
- network: UI_I_SendDataNewNetwork
72
- networksTable: UI_I_NetworkTableItem[]
73
- errorValidationFields: UI_I_ErrorValidationField[]
74
- isEdit: boolean
75
- state?: string | number
76
- }>()
77
- const emits = defineEmits<{
78
- (event: 'send-data', value: UI_I_SendDataNewNetwork): void
79
- (event: 'invalid', value: boolean): void
80
- (event: 'remove'): void
81
- (event: 'remove-error-by-title', value: string): void
82
- (event: 'get-networks-table', value: UI_I_TablePayload): void
83
- }>()
84
-
85
- const { $store }: any = useNuxtApp()
86
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
87
-
88
- const valueProp = props.project === 'sphere' ? 'network' : 'net_bridge'
89
-
90
- const localization = computed<UI_I_Localization>(() => useLocal())
91
-
92
- const isRunning = computed<boolean>(() => {
93
- return props.state === 2
94
- })
95
-
96
- const isRemovable = computed<boolean>(() => {
97
- return (
98
- !props.isEdit ||
99
- !isRunning.value ||
100
- (isRunning.value && adapterType.value === 'virtio')
101
- )
102
- })
103
-
104
- const label = computed<string>(() => {
105
- if (props.type === 'edit')
106
- return `${localization.value.common.networkAdapter} ${props.index + 1}`
107
-
108
- return `${localization.value.common.newNetwork} *`
109
- })
110
-
111
- // const removeNetwork = (): void => {
112
- // emits('remove')
113
- // }
114
-
115
- const selectedLocationOld = ref<string>('')
116
- const selectedLocation = ref<string>('')
117
- const locationOptions = ref<UI_I_OptionItem[]>([])
118
-
119
- const getNetworks = (): void => {
120
- // if (props.networksTable.length) return // Из-за этого кода был баг. Открыть визард вм -> создать сеть -> открыть визард вм и в списке сетей нету новой сети
121
-
122
- const payload: UI_I_TablePayload = {
123
- pagination: {
124
- page: 1,
125
- pageSize: 100,
126
- },
127
- schema: 'full',
128
- type: 'network',
129
- sortBy: null,
130
- }
131
- emits('get-networks-table', payload)
132
- }
133
- getNetworks()
134
-
135
- const newNetworkInvalid = ref<boolean>(false)
136
- watch(
137
- newNetworkInvalid,
138
- (newValue) => {
139
- emits('invalid', newValue)
140
- },
141
- { immediate: true }
142
- )
143
-
144
- watch(
145
- () => props.networksTable,
146
- (newValue) => {
147
- const isExistValue = newValue.some(
148
- (network) => network[valueProp] === selectedLocation.value
149
- )
150
- if (!newValue.length) {
151
- locationOptions.value = [
152
- {
153
- text: localization.value.vmWizard.noAvailableNetworks,
154
- value: 'noAvailableNetworks',
155
- },
156
- ]
157
- selectedLocation.value = 'noAvailableNetworks'
158
- newNetworkInvalid.value = true
159
- return
160
- }
161
- newNetworkInvalid.value = false
162
-
163
- if (props.type === 'edit' || isExistValue) return
164
-
165
- selectedLocationOld.value = newValue[0][valueProp] || ''
166
- selectedLocation.value = newValue[0][valueProp] || ''
167
-
168
- locationOptions.value = [
169
- { text: newValue[0].name, value: newValue[0][valueProp] },
170
- { text: `${localization.value.common.browse}...`, value: '' },
171
- ]
172
- },
173
- { immediate: true }
174
- )
175
-
176
- const locationModalIsShow = ref<boolean>(false)
177
- const onHideLocationModal = (): void => {
178
- locationModalIsShow.value = false
179
- selectedLocation.value = selectedLocationOld.value
180
- }
181
- const changeLocation = (event: UI_I_HTMLSelectElement): void => {
182
- const value = event.target.value
183
- if (value === '') {
184
- locationModalIsShow.value = true
185
- return
186
- }
187
-
188
- selectedLocationOld.value = value
189
- selectedLocation.value = value
190
- // netBridge.value = value
191
- }
192
- const onSelectLocation = (network: UI_I_NetworkTableItem): void => {
193
- locationModalIsShow.value = false
194
-
195
- selectedLocationOld.value = network[valueProp]
196
- selectedLocation.value = network[valueProp]
197
-
198
- const hasNetwork = locationOptions.value.some(
199
- (option) => option.value === network[valueProp]
200
- )
201
- if (hasNetwork) {
202
- return
203
- }
204
-
205
- locationOptions.value = [
206
- ...locationOptions.value.slice(0, -1),
207
- { text: network.name, value: network[valueProp] },
208
- locationOptions.value[locationOptions.value.length - 1],
209
- ]
210
- }
211
-
212
- const adapterType = ref<string>('rtl8139')
213
-
214
- const target = ref<string>('')
215
-
216
- const macAddress = ref<string>('')
217
- const macAddressType = ref<string>('automatic')
218
-
219
- watch(
220
- [selectedLocation, adapterType, macAddress, macAddressType, locationOptions],
221
- () => {
222
- const option = locationOptions.value.find(
223
- (option) => option.value === selectedLocation.value
224
- )
225
- if (!option) return
226
-
227
- emits('send-data', {
228
- network: option.text,
229
- // net_bridge: props.project === 'procurator' ? option.value : '',
230
- net_bridge: option.value,
231
- target: target.value,
232
- model: adapterType.value,
233
- mac: macAddress.value,
234
- boot_order: props.network.boot_order,
235
- })
236
- },
237
- { immediate: true }
238
- )
239
-
240
- // Добавляем данные для редактирования
241
- watch(
242
- () => props.network,
243
- (newValue) => {
244
- // if (props.type !== 'edit') return
245
- if (props.type !== 'edit' && props.type !== 'clone') return
246
-
247
- locationOptions.value = [
248
- { text: newValue.network, value: newValue[valueProp] },
249
- { text: `${localization.value.common.browse}...`, value: '' },
250
- ]
251
- selectedLocation.value = newValue[valueProp]
252
-
253
- adapterType.value = newValue.model
254
- target.value = newValue.target
255
- // Сбрасываем mac address при клонировании
256
- macAddress.value = props.type === 'clone' ? '' : newValue.mac
257
- },
258
- { immediate: true }
259
- )
260
-
261
- watch(
262
- isRunning,
263
- (newValue) => {
264
- if (newValue && props.type === 'new') {
265
- adapterType.value = 'virtio'
266
- }
267
- },
268
- { immediate: true }
269
- )
270
-
271
- const typeError = computed<string>(
272
- () => `network_devices[${props.index}].network`
273
- )
274
-
275
- const apiError = computed<string>(() => {
276
- return (
277
- props.errorValidationFields?.find(
278
- (message) => message.field === typeError.value
279
- )?.error_message || ''
280
- )
281
- })
282
-
283
- const onRemoveValidationError = (): void => {
284
- emits('remove-error-by-title', typeError.value)
285
- }
286
- </script>
287
-
288
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-network-new
3
+ v-if="isNewView"
4
+ v-model:selected-location="selectedLocation"
5
+ v-model:adapter-type="adapterType"
6
+ v-model:mac-address="macAddress"
7
+ v-model:mac-address-type="macAddressType"
8
+ v-model:new-network-invalid="newNetworkInvalid"
9
+ :index="props.index"
10
+ :type="props.type"
11
+ :networks-table="props.networksTable"
12
+ :error-validation-fields="props.errorValidationFields"
13
+ :is-removable="isRemovable"
14
+ :label="label"
15
+ :error-text="apiError"
16
+ :type-error="typeError"
17
+ :location-options="locationOptions"
18
+ :is-running="isRunning"
19
+ :location-modal-is-show="locationModalIsShow"
20
+ :state="props.state"
21
+ @remove="emits('remove')"
22
+ @remove-error-by-title="onRemoveValidationError"
23
+ @change-location="changeLocation"
24
+ @hide-location-modal="onHideLocationModal"
25
+ @select-location="onSelectLocation"
26
+ />
27
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-network-old
28
+ v-else
29
+ v-model:selected-location="selectedLocation"
30
+ v-model:adapter-type="adapterType"
31
+ v-model:mac-address="macAddress"
32
+ v-model:mac-address-type="macAddressType"
33
+ v-model:new-network-invalid="newNetworkInvalid"
34
+ :index="props.index"
35
+ :type="props.type"
36
+ :networks-table="props.networksTable"
37
+ :error-validation-fields="props.errorValidationFields"
38
+ :is-removable="isRemovable"
39
+ :label="label"
40
+ :error-text="apiError"
41
+ :type-error="typeError"
42
+ :location-options="locationOptions"
43
+ :is-running="isRunning"
44
+ :location-modal-is-show="locationModalIsShow"
45
+ :state="props.state"
46
+ @remove="emits('remove')"
47
+ @remove-error-by-title="onRemoveValidationError"
48
+ @change-location="changeLocation"
49
+ @hide-location-modal="onHideLocationModal"
50
+ @select-location="onSelectLocation"
51
+ />
52
+ </template>
53
+
54
+ <script setup lang="ts">
55
+ import type { UI_T_Project } from '~/lib/models/types'
56
+ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
57
+ import type { UI_I_NetworkTableItem } from '~/lib/models/store/network/interfaces'
58
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
59
+ import type { UI_I_SendDataNewNetwork } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
60
+ import type { UI_T_NetworkType } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/types'
61
+ import type {
62
+ UI_I_Localization,
63
+ UI_I_HTMLSelectElement,
64
+ } from '~/lib/models/interfaces'
65
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
66
+
67
+ const props = defineProps<{
68
+ project: UI_T_Project
69
+ index: number
70
+ type: UI_T_NetworkType
71
+ network: UI_I_SendDataNewNetwork
72
+ networksTable: UI_I_NetworkTableItem[]
73
+ errorValidationFields: UI_I_ErrorValidationField[]
74
+ isEdit: boolean
75
+ state?: string | number
76
+ }>()
77
+ const emits = defineEmits<{
78
+ (event: 'send-data', value: UI_I_SendDataNewNetwork): void
79
+ (event: 'invalid', value: boolean): void
80
+ (event: 'remove'): void
81
+ (event: 'remove-error-by-title', value: string): void
82
+ (event: 'get-networks-table', value: UI_I_TablePayload): void
83
+ }>()
84
+
85
+ const { $store }: any = useNuxtApp()
86
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
87
+
88
+ const valueProp = props.project === 'sphere' ? 'network' : 'net_bridge'
89
+
90
+ const localization = computed<UI_I_Localization>(() => useLocal())
91
+
92
+ const isRunning = computed<boolean>(() => {
93
+ return props.state === 2
94
+ })
95
+
96
+ const isRemovable = computed<boolean>(() => {
97
+ return (
98
+ !props.isEdit ||
99
+ !isRunning.value ||
100
+ (isRunning.value && adapterType.value === 'virtio')
101
+ )
102
+ })
103
+
104
+ const label = computed<string>(() => {
105
+ if (props.type === 'edit')
106
+ return `${localization.value.common.networkAdapter} ${props.index + 1}`
107
+
108
+ return `${localization.value.common.newNetwork} *`
109
+ })
110
+
111
+ // const removeNetwork = (): void => {
112
+ // emits('remove')
113
+ // }
114
+
115
+ const selectedLocationOld = ref<string>('')
116
+ const selectedLocation = ref<string>('')
117
+ const locationOptions = ref<UI_I_OptionItem[]>([])
118
+
119
+ const getNetworks = (): void => {
120
+ // if (props.networksTable.length) return // Из-за этого кода был баг. Открыть визард вм -> создать сеть -> открыть визард вм и в списке сетей нету новой сети
121
+
122
+ const payload: UI_I_TablePayload = {
123
+ pagination: {
124
+ page: 1,
125
+ pageSize: 100,
126
+ },
127
+ schema: 'full',
128
+ type: 'network',
129
+ sortBy: null,
130
+ }
131
+ emits('get-networks-table', payload)
132
+ }
133
+ getNetworks()
134
+
135
+ const newNetworkInvalid = ref<boolean>(false)
136
+ watch(
137
+ newNetworkInvalid,
138
+ (newValue) => {
139
+ emits('invalid', newValue)
140
+ },
141
+ { immediate: true }
142
+ )
143
+
144
+ watch(
145
+ () => props.networksTable,
146
+ (newValue) => {
147
+ const isExistValue = newValue.some(
148
+ (network) => network[valueProp] === selectedLocation.value
149
+ )
150
+ if (!newValue.length) {
151
+ locationOptions.value = [
152
+ {
153
+ text: localization.value.vmWizard.noAvailableNetworks,
154
+ value: 'noAvailableNetworks',
155
+ },
156
+ ]
157
+ selectedLocation.value = 'noAvailableNetworks'
158
+ newNetworkInvalid.value = true
159
+ return
160
+ }
161
+ newNetworkInvalid.value = false
162
+
163
+ if (props.type === 'edit' || isExistValue) return
164
+
165
+ selectedLocationOld.value = newValue[0][valueProp] || ''
166
+ selectedLocation.value = newValue[0][valueProp] || ''
167
+
168
+ locationOptions.value = [
169
+ { text: newValue[0].name, value: newValue[0][valueProp] },
170
+ { text: `${localization.value.common.browse}...`, value: '' },
171
+ ]
172
+ },
173
+ { immediate: true }
174
+ )
175
+
176
+ const locationModalIsShow = ref<boolean>(false)
177
+ const onHideLocationModal = (): void => {
178
+ locationModalIsShow.value = false
179
+ selectedLocation.value = selectedLocationOld.value
180
+ }
181
+ const changeLocation = (event: UI_I_HTMLSelectElement): void => {
182
+ const value = event.target.value
183
+ if (value === '') {
184
+ locationModalIsShow.value = true
185
+ return
186
+ }
187
+
188
+ selectedLocationOld.value = value
189
+ selectedLocation.value = value
190
+ // netBridge.value = value
191
+ }
192
+ const onSelectLocation = (network: UI_I_NetworkTableItem): void => {
193
+ locationModalIsShow.value = false
194
+
195
+ selectedLocationOld.value = network[valueProp]
196
+ selectedLocation.value = network[valueProp]
197
+
198
+ const hasNetwork = locationOptions.value.some(
199
+ (option) => option.value === network[valueProp]
200
+ )
201
+ if (hasNetwork) {
202
+ return
203
+ }
204
+
205
+ locationOptions.value = [
206
+ ...locationOptions.value.slice(0, -1),
207
+ { text: network.name, value: network[valueProp] },
208
+ locationOptions.value[locationOptions.value.length - 1],
209
+ ]
210
+ }
211
+
212
+ const adapterType = ref<string>('rtl8139')
213
+
214
+ const target = ref<string>('')
215
+
216
+ const macAddress = ref<string>('')
217
+ const macAddressType = ref<string>('automatic')
218
+
219
+ watch(
220
+ [selectedLocation, adapterType, macAddress, macAddressType, locationOptions],
221
+ () => {
222
+ const option = locationOptions.value.find(
223
+ (option) => option.value === selectedLocation.value
224
+ )
225
+ if (!option) return
226
+
227
+ emits('send-data', {
228
+ network: option.text,
229
+ // net_bridge: props.project === 'procurator' ? option.value : '',
230
+ net_bridge: option.value,
231
+ target: target.value,
232
+ model: adapterType.value,
233
+ mac: macAddress.value,
234
+ boot_order: props.network.boot_order,
235
+ })
236
+ },
237
+ { immediate: true }
238
+ )
239
+
240
+ // Добавляем данные для редактирования
241
+ watch(
242
+ () => props.network,
243
+ (newValue) => {
244
+ // if (props.type !== 'edit') return
245
+ if (props.type !== 'edit' && props.type !== 'clone') return
246
+
247
+ locationOptions.value = [
248
+ { text: newValue.network, value: newValue[valueProp] },
249
+ { text: `${localization.value.common.browse}...`, value: '' },
250
+ ]
251
+ selectedLocation.value = newValue[valueProp]
252
+
253
+ adapterType.value = newValue.model
254
+ target.value = newValue.target
255
+ // Сбрасываем mac address при клонировании
256
+ macAddress.value = props.type === 'clone' ? '' : newValue.mac
257
+ },
258
+ { immediate: true }
259
+ )
260
+
261
+ watch(
262
+ isRunning,
263
+ (newValue) => {
264
+ if (newValue && props.type === 'new') {
265
+ adapterType.value = 'virtio'
266
+ }
267
+ },
268
+ { immediate: true }
269
+ )
270
+
271
+ const typeError = computed<string>(
272
+ () => `network_devices[${props.index}].network`
273
+ )
274
+
275
+ const apiError = computed<string>(() => {
276
+ return (
277
+ props.errorValidationFields?.find(
278
+ (message) => message.field === typeError.value
279
+ )?.error_message || ''
280
+ )
281
+ })
282
+
283
+ const onRemoveValidationError = (): void => {
284
+ emits('remove-error-by-title', typeError.value)
285
+ }
286
+ </script>
287
+
288
+ <style scoped lang="scss"></style>