bfg-common 1.5.488 → 1.5.489

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.
@@ -1,902 +1,905 @@
1
- <template>
2
- <div
3
- v-if="props.diagramData"
4
- :class="{ 'diagram-min-width': !props.inPortlet }"
5
- >
6
- <div class="diagram-main-container">
7
- <common-diagram-main-header
8
- :project="props.project"
9
- :in-portlet="props.inPortlet"
10
- :is-show-diagram="isShowDiagram"
11
- :diagram-name="props.diagramData.diagramName"
12
- :test-id="props.diagramData.testId"
13
- @toggle-diagram="onToggleDiagram"
14
- @show-modal="onShowModal"
15
- />
16
- <common-diagram-main-diagram
17
- :diagram-data="props.diagramData"
18
- :is-show-diagram="isShowDiagram"
19
- :in-portlet="props.inPortlet"
20
- :networks-with-positions="networksWithPositions"
21
- :main-rect-height="mainRectHeight"
22
- :main-switch-line="mainSwitchLine"
23
- :selected-main-line="selectedMainLine"
24
- :adapters-with-positions="adaptersWithPositions"
25
- :selected-port="selectedPort"
26
- :selected-adapter="selectedAdapter"
27
- :selected-network="selectedNetwork"
28
- :selected-switch-line-y="selectedSwitchLineY"
29
- :is-dark-mode="props.isDarkMode"
30
- :networks-count="networksCount"
31
- @click-diagram="onClickDiagram"
32
- @toggle-adapters="onToggleAdapters"
33
- @select-adapter="onSelectAdapter"
34
- @toggle-ports="onTogglePorts"
35
- @select-port="onSelectPort"
36
- @select-network="onSelectNetwork"
37
- @show-modal="onShowModal"
38
- />
39
- </div>
40
- <common-diagram-main-modals
41
- :is-show-port-view-settings-modal="isShowPortViewSettingsModal"
42
- :is-show-network-view-settings-modal="isShowNetworkViewSettingsModal"
43
- :is-show-adapter-view-settings-modal="isShowAdapterViewSettingsModal"
44
- :is-show-vcenter-view-settings-modal="isShowVCenterViewSettingsModal"
45
- :is-show-network-remove-modal="isShowNetworkRemoveModal"
46
- :is-show-switch-remove-modal="isShowSwitchRemoveModal"
47
- :is-show-port-remove-modal="isShowPortRemoveModal"
48
- :is-show-network-edit-settings-modal="isShowNetworkEditSettingsModal"
49
- :is-show-port-edit-settings-modal="isShowPortEditSettingsModal"
50
- :is-show-switch-edit-settings-modal="isShowSwitchEditSettingsModal"
51
- :is-show-switch-view-settings-modal="isShowSwitchViewSettingsModal"
52
- :is-show-switch-manage-physical-adapters-modal="
53
- isShowSwitchManagePhysicalAdaptersModal
54
- "
55
- :is-show-add-networking-modal="isShowAddNetworkingModal"
56
- :is-show-migrate-vmkernel-adapter-modal="
57
- isShowMigrateVmkernelAdapterModal
58
- "
59
- :initial-data="initialData"
60
- :host-name="props.hostName"
61
- :is-remove-modal-loading="props.isRemoveModalLoading"
62
- :diagram-data="props.diagramData"
63
- :adapters="props.adapters"
64
- :is-dark-mode="props.isDarkMode"
65
- :is-edit-modal-loading="props.isEditModalLoading"
66
- :free-adapters="props.freeAdapters"
67
- :manage-physical-adapter-status="managePhysicalAdapterStatus"
68
- :initial-manage-physical-adapter-status="
69
- initialManagePhysicalAdapterStatus
70
- "
71
- :is-manage-adapters-modal-loading="props.isManageAdaptersModalLoading"
72
- :standard-switches-initial="props.standardSwitchesInitial"
73
- :selected-standard-switch-id="selectedStandardSwitchId"
74
- :selected-switch-id="selectedSwitchId"
75
- :tcp-stacks="props.tcpStacks"
76
- :is-networking-loading="props.isNetworkingLoading"
77
- :networks-list="props.networksList"
78
- :is-migrate-adapter-loading="props.isMigrateAdapterLoading"
79
- :diagrams-data="props.diagramsData"
80
- :project="props.project"
81
- @hide-port-view-settings-modal="onHidePortViewSettingsModal"
82
- @hide-network-view-settings-modal="onHideNetworkViewSettingsModal"
83
- @hide-adapter-view-settings-modal="onHideAdapterViewSettingsModal"
84
- @hide-vcenter-view-settings-modal="onHideVCenterViewSettingsModal"
85
- @hide-switch-view-settings-modal="onHideSwitchViewSettingsModal"
86
- @hide-network-remove-modal="onHideNetworkRemoveModal"
87
- @hide-switch-remove-modal="onHideSwitchRemoveModal"
88
- @hide-port-remove-modal="onHidePortRemoveModal"
89
- @hide-network-edit-settings-modal="onHideNetworkEditSettingsModal"
90
- @hide-port-edit-settings-modal="onHidePortEditSettingsModal"
91
- @hide-switch-edit-settings-modal="onHideSwitchEditSettingsModal"
92
- @hide-switch-manage-physical-adapters-modal="
93
- onHideSwitchManagePhysicalAdaptersModal
94
- "
95
- @hide-add-networking-modal="onHideAddNetworkingModal"
96
- @hide-migrate-vmkernel-adapter-modal="onHideMigrateVmkernelAdapterModal"
97
- @remove="onRemove"
98
- @send-edit-data="onSendEditData"
99
- @change-edit-fields-data="onChangeEditFieldsData"
100
- @check-network-label="onCheckNetworkLabel"
101
- @send-manage-physical-adapters-data="onSendManagePhysicalAdaptersData"
102
- @change-adapter-status="onChangeManagePhysicalAdapterStatus"
103
- @get-free-adapters="onGetFreeAdapters"
104
- @get-existing-standard-switches="onGetExistingStandardSwitches"
105
- @get-tcp-stacks="onGetTcpStacks"
106
- @send-add-networking-data="onSendNetworkData"
107
- @add-networking-data-validate="onValidateBeforeSending"
108
- />
109
- </div>
110
- </template>
111
-
112
- <script setup lang="ts">
113
- import type {
114
- UI_I_Adapter,
115
- UI_I_AdapterStatus,
116
- UI_I_AdaptersWithPositions,
117
- UI_I_MainRectHeights,
118
- UI_I_ModalsInitialData,
119
- UI_I_Network,
120
- UI_I_EditFieldsData,
121
- UI_I_NetworksWithPositions,
122
- UI_I_SelectedAdapter,
123
- UI_I_SelectedPort,
124
- UI_I_SwitchLine,
125
- UI_I_ToggleDiagramAdaptersPayload,
126
- UI_I_ToggleDiagramPortsPayload,
127
- UI_I_PortToggleFlag,
128
- UI_I_DiagramData,
129
- UI_I_SwitchAdapterItem,
130
- } from '~/components/common/diagramMain/lib/models/interfaces'
131
- import type {
132
- UI_I_ArbitraryObject,
133
- UI_I_ItemsWithTotalCounts,
134
- } from '~/lib/models/interfaces'
135
- import type {
136
- UI_I_Switch,
137
- UI_I_TCPStack,
138
- } from '~/components/common/wizards/network/add/lib/models/interfaces'
139
- import type { UI_T_EditData } from '~/components/common/wizards/network/add/lib/models/types'
140
- import type { UI_T_Adapters } from '~/components/common/diagramMain/lib/models/types'
141
- import type { UI_T_Project } from '~/lib/models/types'
142
- import { UI_E_NetworkType, UI_E_PositionsY } from './lib/models/enums'
143
- import {
144
- managePhysicalAdapterStatusInitial,
145
- mainRectHeightsInitial,
146
- switchLineInitial,
147
- selectedPortInitial,
148
- selectedSwitchLineYInitial,
149
- selectedAdapterInitial,
150
- } from '~/components/common/diagramMain/lib/config'
151
- import {
152
- hasPortAndNetwork,
153
- networksPositions,
154
- getSelectNetworkDataFunc,
155
- getSelectPortDataFunc,
156
- countAdaptersHeight,
157
- getAdaptersPositions,
158
- } from '~/components/common/diagramMain/lib/utils/utils'
159
-
160
- const props = withDefaults(
161
- defineProps<{
162
- diagramData: UI_I_DiagramData
163
- project?: UI_T_Project
164
- inPortlet?: boolean
165
- standardSwitchesInitial?: UI_I_Switch[]
166
- hostName?: string
167
- adapters?: UI_I_ItemsWithTotalCounts<UI_I_SwitchAdapterItem>
168
- freeAdapters?: UI_I_Adapter[]
169
- networksList?: UI_I_Network[]
170
- isDarkMode: boolean
171
- tcpStacks?: UI_I_TCPStack[]
172
- diagramsData?: UI_I_DiagramData[]
173
- isManageAdaptersModalLoading?: boolean
174
- isNetworkingLoading?: boolean
175
- isRemoveModalLoading?: boolean
176
- isEditModalLoading?: boolean
177
- isMigrateAdapterLoading?: boolean
178
- }>(),
179
- {
180
- project: 'procurator',
181
- diagramData: null,
182
- inPortlet: false,
183
- standardSwitchesInitial: () => [],
184
- hostName: '',
185
- adapters: () => ({
186
- total_items: 0,
187
- total_pages: 0,
188
- items: [],
189
- }),
190
- freeAdapters: () => [],
191
- networksList: () => [],
192
- tcpStacks: () => [],
193
- diagramsData: [],
194
- isManageAdaptersModalLoading: false,
195
- isNetworkingLoading: false,
196
- isRemoveModalLoading: false,
197
- isEditModalLoading: false,
198
- isMigrateAdapterLoading: false,
199
- }
200
- )
201
-
202
- const initialData = ref<UI_I_ModalsInitialData>({})
203
- const switchInitialData = ref<UI_I_ModalsInitialData>({})
204
-
205
- watch(
206
- () => props.diagramData?.networking,
207
- (initial: UI_I_ModalsInitialData | undefined) => {
208
- if (initial) {
209
- initialData.value = initial
210
- switchInitialData.value = initial
211
- }
212
- },
213
- { deep: true, immediate: true }
214
- )
215
-
216
- const onValidateBeforeSending = (
217
- data: UI_T_EditData,
218
- type: string,
219
- setValidation: (messages: UI_I_ArbitraryObject<string>) => void
220
- ) => {
221
- emits('add-networking-data-validate', data, type, setValidation)
222
- }
223
-
224
- let initialManagePhysicalAdapterStatus = ref<UI_I_AdapterStatus>(
225
- managePhysicalAdapterStatusInitial
226
- )
227
-
228
- const managePhysicalAdapterStatus = ref<UI_I_AdapterStatus>(
229
- useDeepCopy(initialManagePhysicalAdapterStatus.value)
230
- )
231
-
232
- watch(
233
- () => props.diagramData,
234
- (newValue: UI_I_DiagramData) => {
235
- if (newValue?.networking) {
236
- initialManagePhysicalAdapterStatus.value = {
237
- active: useDeepCopy(props.diagramData?.networking?.activeAdapters),
238
- standby: useDeepCopy(props.diagramData?.networking?.standbyAdapters),
239
- unused: useDeepCopy(props.diagramData?.networking?.unusedAdapters),
240
- }
241
-
242
- managePhysicalAdapterStatus.value = useDeepCopy(
243
- initialManagePhysicalAdapterStatus.value
244
- )
245
- }
246
- },
247
- { deep: true, immediate: true }
248
- )
249
-
250
- const onChangeManagePhysicalAdapterStatus = (
251
- adapterStatusNew: UI_I_AdapterStatus
252
- ) => {
253
- managePhysicalAdapterStatus.value = adapterStatusNew
254
- }
255
-
256
- const isShowSwitchManagePhysicalAdaptersModal = ref<boolean>(false)
257
- const onHideSwitchManagePhysicalAdaptersModal = (): void => {
258
- isShowSwitchManagePhysicalAdaptersModal.value = false
259
- }
260
-
261
- const onSendManagePhysicalAdaptersData = (
262
- adapterStatus: UI_I_AdapterStatus,
263
- switchName: string,
264
- hideModal: () => void
265
- ) => {
266
- emits(
267
- 'send-manage-physical-adapters-data',
268
- adapterStatus,
269
- switchName,
270
- initialData.value,
271
- hideModal
272
- )
273
- }
274
-
275
- const isShowSwitchViewSettingsModal = ref<boolean>(false)
276
- const isShowSwitchEditSettingsModal = ref<boolean>(false)
277
- const isShowSwitchRemoveModal = ref<boolean>(false)
278
- const onHideSwitchViewSettingsModal = (): void => {
279
- isShowSwitchViewSettingsModal.value = false
280
- }
281
- const onHideSwitchEditSettingsModal = (): void => {
282
- isShowSwitchEditSettingsModal.value = false
283
- }
284
- const onHideSwitchRemoveModal = (): void => {
285
- isShowSwitchRemoveModal.value = false
286
- }
287
-
288
- const isShowAdapterViewSettingsModal = ref<boolean>(false)
289
- const onHideAdapterViewSettingsModal = (): void => {
290
- isShowAdapterViewSettingsModal.value = false
291
- }
292
-
293
- const isShowNetworkViewSettingsModal = ref<boolean>(false)
294
- const isShowNetworkEditSettingsModal = ref<boolean>(false)
295
- const isShowNetworkRemoveModal = ref<boolean>(false)
296
- const onHideNetworkViewSettingsModal = (): void => {
297
- isShowNetworkViewSettingsModal.value = false
298
- }
299
- const onHideNetworkEditSettingsModal = (): void => {
300
- isShowNetworkEditSettingsModal.value = false
301
- }
302
- const onHideNetworkRemoveModal = (): void => {
303
- isShowNetworkRemoveModal.value = false
304
- }
305
-
306
- const isShowPortViewSettingsModal = ref<boolean>(false)
307
- const isShowPortEditSettingsModal = ref<boolean>(false)
308
- const isShowPortRemoveModal = ref<boolean>(false)
309
- const onHidePortViewSettingsModal = (): void => {
310
- isShowPortViewSettingsModal.value = false
311
- }
312
- const onHidePortEditSettingsModal = (): void => {
313
- isShowPortEditSettingsModal.value = false
314
- }
315
- const onHidePortRemoveModal = (): void => {
316
- isShowPortRemoveModal.value = false
317
- }
318
-
319
- const isShowVCenterViewSettingsModal = ref<boolean>(false)
320
- const onHideVCenterViewSettingsModal = (): void => {
321
- isShowVCenterViewSettingsModal.value = false
322
- }
323
- const isShowAddNetworkingModal = ref<boolean>(false)
324
- const onHideAddNetworkingModal = (): void => {
325
- isShowAddNetworkingModal.value = false
326
- }
327
- const isShowMigrateVmkernelAdapterModal = ref<boolean>(false)
328
- const onHideMigrateVmkernelAdapterModal = (): void => {
329
- isShowMigrateVmkernelAdapterModal.value = false
330
- }
331
-
332
- const selectedStandardSwitchId = ref<string>('')
333
- const selectedSwitchId = ref<string>('')
334
-
335
- const onShowModal = (
336
- value: string,
337
- properties: UI_I_ModalsInitialData
338
- ): void => {
339
- switch (value) {
340
- case 'port-view-settings':
341
- initialData.value = properties
342
- isShowPortViewSettingsModal.value = true
343
- break
344
- case 'network-view-settings':
345
- isShowNetworkViewSettingsModal.value = true
346
- initialData.value = properties
347
- break
348
- case 'adapter-view-settings':
349
- isShowAdapterViewSettingsModal.value = true
350
- initialData.value = properties
351
- break
352
- case 'v-center-view-settings':
353
- isShowVCenterViewSettingsModal.value = true
354
- initialData.value = properties
355
- break
356
- case 'network-edit-settings':
357
- isShowNetworkEditSettingsModal.value = true
358
- initialData.value = properties
359
- break
360
- case 'port-edit-settings':
361
- initialData.value = properties
362
- isShowPortEditSettingsModal.value = true
363
- break
364
- case 'network-port-remove':
365
- initialData.value = properties
366
- isShowNetworkRemoveModal.value = true
367
- break
368
- case 'port-remove':
369
- initialData.value = properties
370
- isShowPortRemoveModal.value = true
371
- break
372
- case 'switch-edit':
373
- isShowSwitchEditSettingsModal.value = true
374
- initialData.value = useDeepCopy(switchInitialData.value)
375
- break
376
- case 'switch-manage-physical-adapters':
377
- isShowSwitchManagePhysicalAdaptersModal.value = true
378
- initialData.value = useDeepCopy(switchInitialData.value)
379
- break
380
- case 'add-networking':
381
- isShowAddNetworkingModal.value = true
382
- selectedStandardSwitchId.value = properties.switch_name
383
- selectedSwitchId.value = properties.switch_name
384
- break
385
- case 'switch-view-settings':
386
- isShowSwitchViewSettingsModal.value = true
387
- initialData.value = useDeepCopy(switchInitialData.value)
388
- break
389
- case 'migrate-vmkernel-adapter':
390
- isShowMigrateVmkernelAdapterModal.value = true
391
- break
392
- case 'switch-remove':
393
- isShowSwitchRemoveModal.value = true
394
- break
395
- }
396
- }
397
-
398
- const onRemove = (id: string, type: string) => {
399
- if (type === 'network' && selectedNetwork.value === id) {
400
- selectedNetwork.value = '-1'
401
- resetSelection()
402
- } else if (type === 'port' && selectedPort.value.portId === id) {
403
- selectedPort.value.networkId = '-1'
404
- selectedPort.value.portId = '-1'
405
- resetSelection()
406
- }
407
-
408
- const hideModal =
409
- type === 'network1' || type === 'network2'
410
- ? onHideNetworkRemoveModal
411
- : type === 'switch'
412
- ? onHideSwitchRemoveModal
413
- : onHidePortRemoveModal
414
-
415
- emits('remove', id, type, hideModal)
416
- }
417
- const onChangeEditFieldsData = (newEditFieldsData: UI_I_EditFieldsData) => {
418
- emits('change-edit-fields-data', newEditFieldsData)
419
- }
420
- const onCheckNetworkLabel = (
421
- label: string,
422
- sendMessage: (message: string) => void
423
- ) => {
424
- emits('check-network-label', label, sendMessage)
425
- }
426
- const onGetExistingStandardSwitches = () => {
427
- emits('get-existing-standard-switches')
428
- }
429
- const onGetTcpStacks = () => {
430
- emits('get-tcp-stacks')
431
- }
432
- const onGetFreeAdapters = (showModal: () => void) => {
433
- emits('get-free-adapters', showModal)
434
- }
435
- const onSendNetworkData = (
436
- data: UI_T_EditData,
437
- type: string,
438
- hideModal: () => void
439
- ) => {
440
- emits('send-add-networking-data', data, type, hideModal)
441
- }
442
- const onSendEditData = (type: string, hideModal: () => void, id?: string) => {
443
- emits('send-edit-data', type, initialData.value, hideModal, id)
444
- }
445
- const isShowDiagram = ref<boolean>(true)
446
- const onToggleDiagram = () => {
447
- isShowDiagram.value = !isShowDiagram.value
448
- }
449
- const mainRectHeights = ref<UI_I_MainRectHeights>(
450
- useDeepCopy(mainRectHeightsInitial)
451
- )
452
-
453
- const switchLine = ref<UI_I_SwitchLine>(useDeepCopy(switchLineInitial))
454
- const mainSwitchLine = computed<UI_I_SwitchLine>(
455
- () =>
456
- (switchLine.value.ay && {
457
- y1: Math.min(switchLine.value.y1, switchLine.value.ay),
458
- y2: Math.max(switchLine.value.y2, switchLine.value.ay),
459
- }) || { y1: 0, y2: 0 }
460
- )
461
-
462
- const selectedMainLine = ref(false)
463
- const selectedPort = ref<UI_I_SelectedPort>(useDeepCopy(selectedPortInitial))
464
- const selectedAdapter = ref<UI_I_SelectedAdapter>(
465
- useDeepCopy(selectedAdapterInitial)
466
- )
467
- const selectedNetwork = ref<string>('-1')
468
-
469
- const selectedSwitchLineY = ref<UI_I_SwitchLine>(
470
- useDeepCopy(selectedSwitchLineYInitial)
471
- )
472
- const mainRectHeight = computed<number>(() =>
473
- Math.max(
474
- mainRectHeights.value.networksHeight,
475
- mainRectHeights.value.adaptersHeight
476
- )
477
- )
478
-
479
- const countNetworksPositions = (
480
- newNetworks?: UI_I_Network[] | null
481
- ): UI_I_NetworksWithPositions[] => {
482
- let lastNetworkHeight = 0
483
- let lastPosition = UI_E_PositionsY.DIAGRAM_TOP + UI_E_PositionsY.BETWEEN_RECTS
484
- mainRectHeights.value.networksHeight =
485
- UI_E_PositionsY.DIAGRAM_TOP + UI_E_PositionsY.BETWEEN_RECTS
486
-
487
- const lastIndex = props.diagramData?.networks.findLastIndex(
488
- (network: UI_I_Network) =>
489
- network.activeAdapters.length > 0 && network.state.state !== 3
490
- )
491
-
492
- return (
493
- (newNetworks ? newNetworks : props.diagramData?.networks)?.map(
494
- (network: UI_I_Network, index: number) => {
495
- let portsCount = 0
496
- if (
497
- network.networkType ===
498
- (UI_E_NetworkType.VMPortsGroup || UI_E_NetworkType.VCenter)
499
- ) {
500
- portsCount = network.ports.length
501
- } else {
502
- portsCount = network.sysx ? 1 : 0
503
- }
504
- const portsHeight = network.toggle
505
- ? network.networkType === UI_E_NetworkType.VCenter
506
- ? portsCount * UI_E_PositionsY.SINGLE_V_CENTER_HEIGHT
507
- : portsCount * UI_E_PositionsY.SINGLE_PORT_HEIGHT
508
- : 0
509
- const networkHeight =
510
- UI_E_PositionsY.PORTS_FROM_RECT_TOP +
511
- portsHeight +
512
- (network.networkType === UI_E_NetworkType.VCenter
513
- ? UI_E_PositionsY.SINGLE_V_CENTER_HEIGHT - 10
514
- : UI_E_PositionsY.SINGLE_PORT_HEIGHT) +
515
- UI_E_PositionsY.SPACE_FROM_RECT_BOTTOM
516
-
517
- lastPosition +=
518
- lastNetworkHeight + (index && UI_E_PositionsY.BETWEEN_RECTS)
519
- lastNetworkHeight = networkHeight
520
-
521
- const connectLineY = lastPosition + networkHeight / 2
522
- const titlePosition = lastPosition + UI_E_PositionsY.TITLE_FROM_RECT_TOP
523
- const vlanPosition = lastPosition + UI_E_PositionsY.VLAN_FROM_RECT_TOP
524
- const portsPosition = lastPosition + UI_E_PositionsY.PORTS_FROM_RECT_TOP
525
-
526
- const networkPortsName =
527
- (network.networkType === UI_E_NetworkType.VMkernel &&
528
- 'VMkernel Ports') ||
529
- (network.networkType === UI_E_NetworkType.VMPortsGroup &&
530
- 'Virtual Machines') ||
531
- (network.networkType === UI_E_NetworkType.VCenter &&
532
- 'Virtual Machines') ||
533
- ''
534
-
535
- lastIndex !== -1 && index === 0 && (switchLine.value.y1 = connectLineY)
536
- lastIndex !== -1 &&
537
- index === lastIndex &&
538
- (switchLine.value.y2 = connectLineY)
539
-
540
- mainRectHeights.value.networksHeight +=
541
- networkHeight + UI_E_PositionsY.BETWEEN_RECTS
542
-
543
- const networkWithPortsPositions =
544
- network.networkType ===
545
- (UI_E_NetworkType.VMPortsGroup || UI_E_NetworkType.VCenter)
546
- ? network.ports.map((port, index) => {
547
- const portPosition =
548
- portsPosition +
549
- (network.networkType === UI_E_NetworkType.VCenter
550
- ? (index + 1) * UI_E_PositionsY.SINGLE_V_CENTER_HEIGHT - 10
551
- : (index + 1) * UI_E_PositionsY.SINGLE_PORT_HEIGHT)
552
-
553
- return {
554
- ...port,
555
- portPosition,
556
- }
557
- })
558
- : (network.sysx && [
559
- {
560
- id: network.sysx?.id,
561
- name: `${network.sysx?.id} ${
562
- network.sysx.ipv4_settings.ipv4
563
- ? `: ${network.sysx.ipv4_settings.ipv4}`
564
- : ''
565
- }`,
566
- state: network.sysx.state,
567
- testId: `network-port-${index}`,
568
- portPosition:
569
- portsPosition + UI_E_PositionsY.SINGLE_PORT_HEIGHT,
570
- },
571
- ]) ||
572
- []
573
-
574
- return {
575
- ...network,
576
- ports: networkWithPortsPositions,
577
- portsCount,
578
- portsHeight,
579
- networkHeight,
580
- rectPosition: lastPosition,
581
- connectLineY,
582
- titlePosition,
583
- vlanPosition,
584
- vlanId: network.vlanId || '--',
585
- portsPosition,
586
- networkPortsName,
587
- }
588
- }
589
- ) || []
590
- )
591
- }
592
- const networksWithPositions = ref<UI_I_NetworksWithPositions[]>(
593
- countNetworksPositions()
594
- )
595
-
596
- const isPortToggled = ref<UI_I_PortToggleFlag>({
597
- value: false,
598
- id: '',
599
- })
600
-
601
- const countAdaptersPositions = (): UI_I_AdaptersWithPositions => {
602
- const { height, toggle, adaptersCount } = countAdaptersHeight(
603
- props.diagramData
604
- )
605
-
606
- mainRectHeights.value.adaptersHeight =
607
- UI_E_PositionsY.DIAGRAM_TOP + UI_E_PositionsY.BETWEEN_RECTS * 2 + height
608
-
609
- const { titlePosition, rectPosition, adaptersConnectLineY, adapters } =
610
- getAdaptersPositions(props.diagramData, height)
611
-
612
- switchLine.value.ay = adaptersConnectLineY
613
-
614
- return {
615
- toggle,
616
- height,
617
- adapters,
618
- rectPosition,
619
- adaptersConnectLineY,
620
- titlePosition,
621
- adaptersCount,
622
- }
623
- }
624
-
625
- const adaptersWithPositions = computed<UI_I_AdaptersWithPositions>(() => {
626
- return countAdaptersPositions()
627
- })
628
-
629
- const networksCount = computed<number>(
630
- () =>
631
- networksWithPositions.value.filter(
632
- (networkWithPositions: UI_I_NetworksWithPositions) =>
633
- networkWithPositions.activeAdapters.length > 0 &&
634
- networkWithPositions.state.state !== 3
635
- ).length
636
- )
637
-
638
- watch(
639
- () => props.diagramData?.networks,
640
- (newValue: UI_I_Network[] | null) => {
641
- networksWithPositions.value = countNetworksPositions(newValue)
642
-
643
- isPortToggled.value.value && handlePortToggle()
644
-
645
- if (selectedAdapter.value.adapterId !== '-1') {
646
- onSelectAdapter(selectedAdapter.value.adapterId)
647
- return
648
- }
649
-
650
- if (selectedPort.value.portId !== '-1') {
651
- onSelectPort(selectedPort.value.networkId, selectedPort.value.portId)
652
- return
653
- }
654
-
655
- if (selectedNetwork.value !== '-1') {
656
- cashedNetworkId.value = '-1'
657
- onSelectNetwork(selectedNetwork.value)
658
- return
659
- }
660
-
661
- if (selectedMainLine.value && networksCount.value === 0) {
662
- selectedMainLine.value = false
663
- return
664
- }
665
-
666
- if (selectedMainLine.value) return
667
-
668
- resetSelection()
669
- },
670
- { deep: true }
671
- )
672
-
673
- const onSelectPort = (networkId: string, portId: string): void => {
674
- const selectPortData = getSelectPortDataFunc(
675
- networkId,
676
- portId,
677
- networksWithPositions.value,
678
- adaptersWithPositions.value
679
- )
680
-
681
- if (!selectPortData) return
682
-
683
- selectedSwitchLineY.value = selectPortData.selectedSwitchLineY
684
- selectedPort.value = selectPortData.selectedPort
685
- }
686
-
687
- const cashedNetworkId = ref<string>('-1')
688
-
689
- const onSelectNetwork = (networkId: string): void => {
690
- if (cashedNetworkId.value === networkId) {
691
- resetSelection()
692
- cashedNetworkId.value = '-1'
693
- return
694
- }
695
-
696
- selectedNetwork.value = networkId
697
-
698
- const selectNetworkData = getSelectNetworkDataFunc(
699
- networkId,
700
- networksWithPositions.value,
701
- adaptersWithPositions.value
702
- )
703
-
704
- cashedNetworkId.value = networkId
705
-
706
- if (!selectNetworkData) return
707
-
708
- selectedSwitchLineY.value = selectNetworkData.selectedSwitchLineY
709
- selectedPort.value = selectNetworkData.selectedPort
710
- }
711
-
712
- const onSelectAdapter = (adapterId: string): void => {
713
- const selectedNetworks: UI_I_NetworksWithPositions[] =
714
- networksWithPositions.value?.filter(
715
- (network: UI_I_NetworksWithPositions) =>
716
- network.activeAdapters.includes(adapterId) && network.state.state !== 3
717
- )
718
-
719
- let pos: number[] = selectedNetworks?.reduce(networksPositions, [])
720
- let selectedAdapterPosition: number | null =
721
- adaptersWithPositions.value.adapters?.find(
722
- (adapter: UI_T_Adapters) => adapter.id === adapterId
723
- )?.adapterPosition || null
724
-
725
- selectedAdapterPosition !== null &&
726
- (selectedAdapterPosition += 7.5) &&
727
- pos?.push(selectedAdapterPosition)
728
-
729
- pos = pos?.sort((y1, y2) => y1 - y2)
730
-
731
- if (pos) {
732
- selectedSwitchLineY.value = {
733
- y1: pos[0],
734
- y2: pos[pos.length - 1],
735
- }
736
- }
737
-
738
- selectedAdapter.value = {
739
- adapterId,
740
- connectedPorts:
741
- selectedNetworks?.map((network: UI_I_Network) => ({
742
- networkId: network.id,
743
- ports: network.ports.map((port) => port.id),
744
- })) || [],
745
- }
746
- }
747
-
748
- const resetSelection = (): void => {
749
- selectedPort.value = useDeepCopy(selectedPortInitial)
750
- selectedSwitchLineY.value = useDeepCopy(selectedSwitchLineYInitial)
751
- selectedAdapter.value = useDeepCopy(selectedAdapterInitial)
752
- selectedNetwork.value = '-1'
753
- selectedMainLine.value = false
754
- }
755
-
756
- const emits = defineEmits<{
757
- (
758
- event: 'toggle-ports',
759
- payload: Omit<UI_I_ToggleDiagramPortsPayload, 'paths'>
760
- ): void
761
- (
762
- event: 'toggle-adapters',
763
- payload: Omit<UI_I_ToggleDiagramAdaptersPayload, 'paths'>
764
- ): void
765
- (event: 'get-existing-standard-switches'): void
766
- (
767
- event: 'send-add-networking-data',
768
- data: UI_T_EditData,
769
- type: string,
770
- hideModal: () => void
771
- ): void
772
- (
773
- event: 'add-networking-data-validate',
774
- data: UI_T_EditData,
775
- type: string,
776
- setValidation: (message: UI_I_ArbitraryObject<string>) => void
777
- ): void
778
- (
779
- event: 'check-network-label',
780
- label: string,
781
- sendMessage: (message: string) => void
782
- ): void
783
- (event: 'get-free-adapters', showModal: () => void): void
784
- (
785
- event: 'send-edit-data',
786
- type: string,
787
- initialData: UI_I_ModalsInitialData,
788
- hideModal: () => void,
789
- id?: string
790
- ): void
791
- (event: 'change-edit-fields-data', editFieldsData: UI_I_EditFieldsData): void
792
- (event: 'remove', id: string, type: string, hideModal: () => void): void
793
- (
794
- event: 'send-manage-physical-adapters-data',
795
- adapterStatus: UI_I_AdapterStatus,
796
- switchName: string,
797
- initialData: UI_I_ModalsInitialData,
798
- hideModal: () => void
799
- ): void
800
- (event: 'get-tcp-stacks'): void
801
- }>()
802
-
803
- const onTogglePorts = (
804
- id: string,
805
- isToggle: boolean,
806
- diagramId: string
807
- ): void => {
808
- emits('toggle-ports', {
809
- id,
810
- isToggle,
811
- diagramId,
812
- })
813
-
814
- isPortToggled.value = {
815
- value: true,
816
- id: id,
817
- }
818
- }
819
-
820
- const handlePortToggle = () => {
821
- cashedNetworkId.value = '-1'
822
-
823
- selectedPort.value.portId !== '-1' &&
824
- onSelectPort(selectedPort.value.networkId, selectedPort.value.portId)
825
- selectedAdapter.value.adapterId !== '-1' &&
826
- onSelectAdapter(selectedAdapter.value.adapterId)
827
- selectedNetwork.value !== '-1' && onSelectNetwork(selectedNetwork.value)
828
- hasPortAndNetwork(selectedPort.value, isPortToggled.value.id) &&
829
- resetSelection()
830
-
831
- isPortToggled.value = {
832
- value: false,
833
- id: '',
834
- }
835
- }
836
-
837
- const onToggleAdapters = (): void => {
838
- cashedNetworkId.value = '-1'
839
-
840
- const newState = !adaptersWithPositions.value.toggle
841
- const payload: Omit<UI_I_ToggleDiagramAdaptersPayload, 'paths'> = {
842
- isToggle: newState,
843
- diagramId: props.diagramData?.id || '',
844
- }
845
-
846
- emits('toggle-adapters', payload)
847
-
848
- selectedPort.value.portId !== '-1' &&
849
- onSelectPort(selectedPort.value.networkId, selectedPort.value.portId)
850
- selectedAdapter.value.adapterId !== '-1' && resetSelection()
851
- selectedNetwork.value !== '-1' && onSelectNetwork(selectedNetwork.value)
852
- }
853
-
854
- const onClickDiagram = (ev: MouseEvent): void => {
855
- const target = ev.target as HTMLElement
856
- const targetClassList = target.classList
857
-
858
- if (!targetClassList.contains('network-title')) {
859
- cashedNetworkId.value = '-1'
860
- }
861
-
862
- if (targetClassList.contains('main-line__handler')) {
863
- resetSelection()
864
- selectedMainLine.value = true
865
- } else {
866
- !(
867
- target.closest('.diagram-block__toggle') ||
868
- target.closest('.diagram-actions') ||
869
- target.closest('.dropdown-actions-container')
870
- ) && resetSelection()
871
- }
872
- }
873
- </script>
874
-
875
- <style scoped lang="scss">
876
- .diagram {
877
- &-min-width {
878
- //min-width: 745px;
879
- //min-width: 764px;
880
- }
881
- &-main-container {
882
- padding-top: 5px;
883
- }
884
- }
885
- </style>
886
- <style lang="scss">
887
- .diagram-main-actions__popup.navbar-dropdown-menu {
888
- .btn {
889
- border-radius: 3px;
890
- border-bottom: none;
891
- &:hover {
892
- border-bottom: none;
893
- }
894
- span {
895
- font-size: 14px;
896
- }
897
- &:active {
898
- box-shadow: none;
899
- }
900
- }
901
- }
902
- </style>
1
+ <template>
2
+ <div
3
+ v-if="props.diagramData"
4
+ :class="{ 'diagram-min-width': !props.inPortlet }"
5
+ >
6
+ <div class="diagram-main-container">
7
+ <common-diagram-main-header
8
+ :project="props.project"
9
+ :in-portlet="props.inPortlet"
10
+ :is-show-diagram="isShowDiagram"
11
+ :diagram-name="props.diagramData.diagramName"
12
+ :test-id="props.diagramData.testId"
13
+ @toggle-diagram="onToggleDiagram"
14
+ @show-modal="onShowModal"
15
+ />
16
+ <common-diagram-main-diagram
17
+ :diagram-data="props.diagramData"
18
+ :is-show-diagram="isShowDiagram"
19
+ :in-portlet="props.inPortlet"
20
+ :networks-with-positions="networksWithPositions"
21
+ :main-rect-height="mainRectHeight"
22
+ :main-switch-line="mainSwitchLine"
23
+ :selected-main-line="selectedMainLine"
24
+ :adapters-with-positions="adaptersWithPositions"
25
+ :selected-port="selectedPort"
26
+ :selected-adapter="selectedAdapter"
27
+ :selected-network="selectedNetwork"
28
+ :selected-switch-line-y="selectedSwitchLineY"
29
+ :is-dark-mode="props.isDarkMode"
30
+ :networks-count="networksCount"
31
+ @click-diagram="onClickDiagram"
32
+ @toggle-adapters="onToggleAdapters"
33
+ @select-adapter="onSelectAdapter"
34
+ @toggle-ports="onTogglePorts"
35
+ @select-port="onSelectPort"
36
+ @select-network="onSelectNetwork"
37
+ @show-modal="onShowModal"
38
+ />
39
+ </div>
40
+ <common-diagram-main-modals
41
+ :is-show-port-view-settings-modal="isShowPortViewSettingsModal"
42
+ :is-show-network-view-settings-modal="isShowNetworkViewSettingsModal"
43
+ :is-show-adapter-view-settings-modal="isShowAdapterViewSettingsModal"
44
+ :is-show-vcenter-view-settings-modal="isShowVCenterViewSettingsModal"
45
+ :is-show-network-remove-modal="isShowNetworkRemoveModal"
46
+ :is-show-switch-remove-modal="isShowSwitchRemoveModal"
47
+ :is-show-port-remove-modal="isShowPortRemoveModal"
48
+ :is-show-network-edit-settings-modal="isShowNetworkEditSettingsModal"
49
+ :is-show-port-edit-settings-modal="isShowPortEditSettingsModal"
50
+ :is-show-switch-edit-settings-modal="isShowSwitchEditSettingsModal"
51
+ :is-show-switch-view-settings-modal="isShowSwitchViewSettingsModal"
52
+ :is-show-switch-manage-physical-adapters-modal="
53
+ isShowSwitchManagePhysicalAdaptersModal
54
+ "
55
+ :is-show-add-networking-modal="isShowAddNetworkingModal"
56
+ :is-show-migrate-vmkernel-adapter-modal="
57
+ isShowMigrateVmkernelAdapterModal
58
+ "
59
+ :initial-data="initialData"
60
+ :host-name="props.hostName"
61
+ :is-remove-modal-loading="props.isRemoveModalLoading"
62
+ :diagram-data="props.diagramData"
63
+ :adapters="props.adapters"
64
+ :is-dark-mode="props.isDarkMode"
65
+ :is-edit-modal-loading="props.isEditModalLoading"
66
+ :free-adapters="props.freeAdapters"
67
+ :manage-physical-adapter-status="managePhysicalAdapterStatus"
68
+ :initial-manage-physical-adapter-status="
69
+ initialManagePhysicalAdapterStatus
70
+ "
71
+ :is-manage-adapters-modal-loading="props.isManageAdaptersModalLoading"
72
+ :standard-switches-initial="props.standardSwitchesInitial"
73
+ :selected-standard-switch-id="selectedStandardSwitchId"
74
+ :selected-switch-id="selectedSwitchId"
75
+ :tcp-stacks="props.tcpStacks"
76
+ :is-networking-loading="props.isNetworkingLoading"
77
+ :networks-list="props.networksList"
78
+ :is-migrate-adapter-loading="props.isMigrateAdapterLoading"
79
+ :diagrams-data="props.diagramsData"
80
+ :project="props.project"
81
+ @hide-port-view-settings-modal="onHidePortViewSettingsModal"
82
+ @hide-network-view-settings-modal="onHideNetworkViewSettingsModal"
83
+ @hide-adapter-view-settings-modal="onHideAdapterViewSettingsModal"
84
+ @hide-vcenter-view-settings-modal="onHideVCenterViewSettingsModal"
85
+ @hide-switch-view-settings-modal="onHideSwitchViewSettingsModal"
86
+ @hide-network-remove-modal="onHideNetworkRemoveModal"
87
+ @hide-switch-remove-modal="onHideSwitchRemoveModal"
88
+ @hide-port-remove-modal="onHidePortRemoveModal"
89
+ @hide-network-edit-settings-modal="onHideNetworkEditSettingsModal"
90
+ @hide-port-edit-settings-modal="onHidePortEditSettingsModal"
91
+ @hide-switch-edit-settings-modal="onHideSwitchEditSettingsModal"
92
+ @hide-switch-manage-physical-adapters-modal="
93
+ onHideSwitchManagePhysicalAdaptersModal
94
+ "
95
+ @hide-add-networking-modal="onHideAddNetworkingModal"
96
+ @hide-migrate-vmkernel-adapter-modal="onHideMigrateVmkernelAdapterModal"
97
+ @remove="onRemove"
98
+ @send-edit-data="onSendEditData"
99
+ @change-edit-fields-data="onChangeEditFieldsData"
100
+ @check-network-label="onCheckNetworkLabel"
101
+ @send-manage-physical-adapters-data="onSendManagePhysicalAdaptersData"
102
+ @change-adapter-status="onChangeManagePhysicalAdapterStatus"
103
+ @get-free-adapters="onGetFreeAdapters"
104
+ @get-existing-standard-switches="onGetExistingStandardSwitches"
105
+ @get-tcp-stacks="onGetTcpStacks"
106
+ @send-add-networking-data="onSendNetworkData"
107
+ @add-networking-data-validate="onValidateBeforeSending"
108
+ />
109
+ </div>
110
+ </template>
111
+
112
+ <script setup lang="ts">
113
+ import type {
114
+ UI_I_Adapter,
115
+ UI_I_AdapterStatus,
116
+ UI_I_AdaptersWithPositions,
117
+ UI_I_MainRectHeights,
118
+ UI_I_ModalsInitialData,
119
+ UI_I_Network,
120
+ UI_I_EditFieldsData,
121
+ UI_I_NetworksWithPositions,
122
+ UI_I_SelectedAdapter,
123
+ UI_I_SelectedPort,
124
+ UI_I_SwitchLine,
125
+ UI_I_ToggleDiagramAdaptersPayload,
126
+ UI_I_ToggleDiagramPortsPayload,
127
+ UI_I_PortToggleFlag,
128
+ UI_I_DiagramData,
129
+ UI_I_SwitchAdapterItem,
130
+ } from '~/components/common/diagramMain/lib/models/interfaces'
131
+ import type {
132
+ UI_I_ArbitraryObject,
133
+ UI_I_ItemsWithTotalCounts,
134
+ } from '~/lib/models/interfaces'
135
+ import type {
136
+ UI_I_Switch,
137
+ UI_I_TCPStack,
138
+ } from '~/components/common/wizards/network/add/lib/models/interfaces'
139
+ import type { UI_T_EditData } from '~/components/common/wizards/network/add/lib/models/types'
140
+ import type { UI_T_Adapters } from '~/components/common/diagramMain/lib/models/types'
141
+ import type { UI_T_Project } from '~/lib/models/types'
142
+ import { UI_E_NetworkType, UI_E_PositionsY } from './lib/models/enums'
143
+ import {
144
+ managePhysicalAdapterStatusInitial,
145
+ mainRectHeightsInitial,
146
+ switchLineInitial,
147
+ selectedPortInitial,
148
+ selectedSwitchLineYInitial,
149
+ selectedAdapterInitial,
150
+ } from '~/components/common/diagramMain/lib/config'
151
+ import {
152
+ hasPortAndNetwork,
153
+ networksPositions,
154
+ getSelectNetworkDataFunc,
155
+ getSelectPortDataFunc,
156
+ countAdaptersHeight,
157
+ getAdaptersPositions,
158
+ } from '~/components/common/diagramMain/lib/utils/utils'
159
+
160
+ const props = withDefaults(
161
+ defineProps<{
162
+ diagramData: UI_I_DiagramData
163
+ project?: UI_T_Project
164
+ inPortlet?: boolean
165
+ standardSwitchesInitial?: UI_I_Switch[]
166
+ hostName?: string
167
+ adapters?: UI_I_ItemsWithTotalCounts<UI_I_SwitchAdapterItem>
168
+ freeAdapters?: UI_I_Adapter[]
169
+ networksList?: UI_I_Network[]
170
+ isDarkMode: boolean
171
+ tcpStacks?: UI_I_TCPStack[]
172
+ diagramsData?: UI_I_DiagramData[]
173
+ isManageAdaptersModalLoading?: boolean
174
+ isNetworkingLoading?: boolean
175
+ isRemoveModalLoading?: boolean
176
+ isEditModalLoading?: boolean
177
+ isMigrateAdapterLoading?: boolean
178
+ }>(),
179
+ {
180
+ project: 'procurator',
181
+ diagramData: null,
182
+ inPortlet: false,
183
+ standardSwitchesInitial: () => [],
184
+ hostName: '',
185
+ adapters: () => ({
186
+ total_items: 0,
187
+ total_pages: 0,
188
+ items: [],
189
+ }),
190
+ freeAdapters: () => [],
191
+ networksList: () => [],
192
+ tcpStacks: () => [],
193
+ diagramsData: [],
194
+ isManageAdaptersModalLoading: false,
195
+ isNetworkingLoading: false,
196
+ isRemoveModalLoading: false,
197
+ isEditModalLoading: false,
198
+ isMigrateAdapterLoading: false,
199
+ }
200
+ )
201
+
202
+ const initialData = ref<UI_I_ModalsInitialData>({})
203
+ const switchInitialData = ref<UI_I_ModalsInitialData>({})
204
+
205
+ watch(
206
+ () => props.diagramData?.networking,
207
+ (initial: UI_I_ModalsInitialData | undefined) => {
208
+ if (initial) {
209
+ initialData.value = initial
210
+ switchInitialData.value = initial
211
+ }
212
+ },
213
+ { deep: true, immediate: true }
214
+ )
215
+
216
+ const onValidateBeforeSending = (
217
+ data: UI_T_EditData,
218
+ type: string,
219
+ setValidation: (messages: UI_I_ArbitraryObject<string>) => void
220
+ ) => {
221
+ emits('add-networking-data-validate', data, type, setValidation)
222
+ }
223
+
224
+ let initialManagePhysicalAdapterStatus = ref<UI_I_AdapterStatus>(
225
+ managePhysicalAdapterStatusInitial
226
+ )
227
+
228
+ const managePhysicalAdapterStatus = ref<UI_I_AdapterStatus>(
229
+ useDeepCopy(initialManagePhysicalAdapterStatus.value)
230
+ )
231
+
232
+ watch(
233
+ () => props.diagramData,
234
+ (newValue: UI_I_DiagramData) => {
235
+ if (newValue?.networking) {
236
+ initialManagePhysicalAdapterStatus.value = {
237
+ active: useDeepCopy(props.diagramData?.networking?.activeAdapters),
238
+ standby: useDeepCopy(props.diagramData?.networking?.standbyAdapters),
239
+ unused: useDeepCopy(props.diagramData?.networking?.unusedAdapters),
240
+ }
241
+
242
+ managePhysicalAdapterStatus.value = useDeepCopy(
243
+ initialManagePhysicalAdapterStatus.value
244
+ )
245
+ }
246
+ },
247
+ { deep: true, immediate: true }
248
+ )
249
+
250
+ const onChangeManagePhysicalAdapterStatus = (
251
+ adapterStatusNew: UI_I_AdapterStatus
252
+ ) => {
253
+ managePhysicalAdapterStatus.value = adapterStatusNew
254
+ }
255
+
256
+ const isShowSwitchManagePhysicalAdaptersModal = ref<boolean>(false)
257
+ const onHideSwitchManagePhysicalAdaptersModal = (): void => {
258
+ isShowSwitchManagePhysicalAdaptersModal.value = false
259
+ }
260
+
261
+ const onSendManagePhysicalAdaptersData = (
262
+ adapterStatus: UI_I_AdapterStatus,
263
+ switchName: string,
264
+ hideModal: () => void
265
+ ) => {
266
+ emits(
267
+ 'send-manage-physical-adapters-data',
268
+ adapterStatus,
269
+ switchName,
270
+ initialData.value,
271
+ hideModal
272
+ )
273
+ }
274
+
275
+ const isShowSwitchViewSettingsModal = ref<boolean>(false)
276
+ const isShowSwitchEditSettingsModal = ref<boolean>(false)
277
+ const isShowSwitchRemoveModal = ref<boolean>(false)
278
+ const onHideSwitchViewSettingsModal = (): void => {
279
+ isShowSwitchViewSettingsModal.value = false
280
+ }
281
+ const onHideSwitchEditSettingsModal = (): void => {
282
+ isShowSwitchEditSettingsModal.value = false
283
+ }
284
+ const onHideSwitchRemoveModal = (): void => {
285
+ isShowSwitchRemoveModal.value = false
286
+ }
287
+
288
+ const isShowAdapterViewSettingsModal = ref<boolean>(false)
289
+ const onHideAdapterViewSettingsModal = (): void => {
290
+ isShowAdapterViewSettingsModal.value = false
291
+ }
292
+
293
+ const isShowNetworkViewSettingsModal = ref<boolean>(false)
294
+ const isShowNetworkEditSettingsModal = ref<boolean>(false)
295
+ const isShowNetworkRemoveModal = ref<boolean>(false)
296
+ const onHideNetworkViewSettingsModal = (): void => {
297
+ isShowNetworkViewSettingsModal.value = false
298
+ }
299
+ const onHideNetworkEditSettingsModal = (): void => {
300
+ isShowNetworkEditSettingsModal.value = false
301
+ }
302
+ const onHideNetworkRemoveModal = (): void => {
303
+ isShowNetworkRemoveModal.value = false
304
+ }
305
+
306
+ const isShowPortViewSettingsModal = ref<boolean>(false)
307
+ const isShowPortEditSettingsModal = ref<boolean>(false)
308
+ const isShowPortRemoveModal = ref<boolean>(false)
309
+ const onHidePortViewSettingsModal = (): void => {
310
+ isShowPortViewSettingsModal.value = false
311
+ }
312
+ const onHidePortEditSettingsModal = (): void => {
313
+ isShowPortEditSettingsModal.value = false
314
+ }
315
+ const onHidePortRemoveModal = (): void => {
316
+ isShowPortRemoveModal.value = false
317
+ }
318
+
319
+ const isShowVCenterViewSettingsModal = ref<boolean>(false)
320
+ const onHideVCenterViewSettingsModal = (): void => {
321
+ isShowVCenterViewSettingsModal.value = false
322
+ }
323
+ const isShowAddNetworkingModal = ref<boolean>(false)
324
+ const onHideAddNetworkingModal = (): void => {
325
+ isShowAddNetworkingModal.value = false
326
+ }
327
+ const isShowMigrateVmkernelAdapterModal = ref<boolean>(false)
328
+ const onHideMigrateVmkernelAdapterModal = (): void => {
329
+ isShowMigrateVmkernelAdapterModal.value = false
330
+ }
331
+
332
+ const selectedStandardSwitchId = ref<string>('')
333
+ const selectedSwitchId = ref<string>('')
334
+
335
+ const onShowModal = (
336
+ value: string,
337
+ properties: UI_I_ModalsInitialData
338
+ ): void => {
339
+ switch (value) {
340
+ case 'port-view-settings':
341
+ initialData.value = properties
342
+ isShowPortViewSettingsModal.value = true
343
+ break
344
+ case 'network-view-settings':
345
+ isShowNetworkViewSettingsModal.value = true
346
+ initialData.value = properties
347
+ break
348
+ case 'adapter-view-settings':
349
+ isShowAdapterViewSettingsModal.value = true
350
+ initialData.value = properties
351
+ break
352
+ case 'v-center-view-settings':
353
+ isShowVCenterViewSettingsModal.value = true
354
+ initialData.value = properties
355
+ break
356
+ case 'network-edit-settings':
357
+ isShowNetworkEditSettingsModal.value = true
358
+ initialData.value = properties
359
+ break
360
+ case 'port-edit-settings':
361
+ initialData.value = properties
362
+ isShowPortEditSettingsModal.value = true
363
+ break
364
+ case 'network-port-remove':
365
+ initialData.value = properties
366
+ isShowNetworkRemoveModal.value = true
367
+ break
368
+ case 'port-remove':
369
+ initialData.value = properties
370
+ isShowPortRemoveModal.value = true
371
+ break
372
+ case 'switch-edit':
373
+ isShowSwitchEditSettingsModal.value = true
374
+ initialData.value = useDeepCopy(switchInitialData.value)
375
+ break
376
+ case 'switch-manage-physical-adapters':
377
+ isShowSwitchManagePhysicalAdaptersModal.value = true
378
+ initialData.value = useDeepCopy(switchInitialData.value)
379
+ break
380
+ case 'add-networking':
381
+ isShowAddNetworkingModal.value = true
382
+ selectedStandardSwitchId.value = properties.switch_name
383
+ selectedSwitchId.value = properties.switch_name
384
+ break
385
+ case 'switch-view-settings':
386
+ isShowSwitchViewSettingsModal.value = true
387
+ initialData.value = useDeepCopy(switchInitialData.value)
388
+ break
389
+ case 'migrate-vmkernel-adapter':
390
+ isShowMigrateVmkernelAdapterModal.value = true
391
+ break
392
+ case 'switch-remove':
393
+ isShowSwitchRemoveModal.value = true
394
+ break
395
+ }
396
+ }
397
+
398
+ const onRemove = (id: string, type: string) => {
399
+ if (
400
+ (type === 'network' || type === 'network1' || type === 'network2') &&
401
+ selectedNetwork.value === id
402
+ ) {
403
+ selectedNetwork.value = '-1'
404
+ resetSelection()
405
+ } else if (type === 'port' && selectedPort.value.portId === id) {
406
+ selectedPort.value.networkId = '-1'
407
+ selectedPort.value.portId = '-1'
408
+ resetSelection()
409
+ }
410
+
411
+ const hideModal =
412
+ type === 'network' || type === 'network1' || type === 'network2'
413
+ ? onHideNetworkRemoveModal
414
+ : type === 'switch'
415
+ ? onHideSwitchRemoveModal
416
+ : onHidePortRemoveModal
417
+
418
+ emits('remove', id, type, hideModal)
419
+ }
420
+ const onChangeEditFieldsData = (newEditFieldsData: UI_I_EditFieldsData) => {
421
+ emits('change-edit-fields-data', newEditFieldsData)
422
+ }
423
+ const onCheckNetworkLabel = (
424
+ label: string,
425
+ sendMessage: (message: string) => void
426
+ ) => {
427
+ emits('check-network-label', label, sendMessage)
428
+ }
429
+ const onGetExistingStandardSwitches = () => {
430
+ emits('get-existing-standard-switches')
431
+ }
432
+ const onGetTcpStacks = () => {
433
+ emits('get-tcp-stacks')
434
+ }
435
+ const onGetFreeAdapters = (showModal: () => void) => {
436
+ emits('get-free-adapters', showModal)
437
+ }
438
+ const onSendNetworkData = (
439
+ data: UI_T_EditData,
440
+ type: string,
441
+ hideModal: () => void
442
+ ) => {
443
+ emits('send-add-networking-data', data, type, hideModal)
444
+ }
445
+ const onSendEditData = (type: string, hideModal: () => void, id?: string) => {
446
+ emits('send-edit-data', type, initialData.value, hideModal, id)
447
+ }
448
+ const isShowDiagram = ref<boolean>(true)
449
+ const onToggleDiagram = () => {
450
+ isShowDiagram.value = !isShowDiagram.value
451
+ }
452
+ const mainRectHeights = ref<UI_I_MainRectHeights>(
453
+ useDeepCopy(mainRectHeightsInitial)
454
+ )
455
+
456
+ const switchLine = ref<UI_I_SwitchLine>(useDeepCopy(switchLineInitial))
457
+ const mainSwitchLine = computed<UI_I_SwitchLine>(
458
+ () =>
459
+ (switchLine.value.ay && {
460
+ y1: Math.min(switchLine.value.y1, switchLine.value.ay),
461
+ y2: Math.max(switchLine.value.y2, switchLine.value.ay),
462
+ }) || { y1: 0, y2: 0 }
463
+ )
464
+
465
+ const selectedMainLine = ref(false)
466
+ const selectedPort = ref<UI_I_SelectedPort>(useDeepCopy(selectedPortInitial))
467
+ const selectedAdapter = ref<UI_I_SelectedAdapter>(
468
+ useDeepCopy(selectedAdapterInitial)
469
+ )
470
+ const selectedNetwork = ref<string>('-1')
471
+
472
+ const selectedSwitchLineY = ref<UI_I_SwitchLine>(
473
+ useDeepCopy(selectedSwitchLineYInitial)
474
+ )
475
+ const mainRectHeight = computed<number>(() =>
476
+ Math.max(
477
+ mainRectHeights.value.networksHeight,
478
+ mainRectHeights.value.adaptersHeight
479
+ )
480
+ )
481
+
482
+ const countNetworksPositions = (
483
+ newNetworks?: UI_I_Network[] | null
484
+ ): UI_I_NetworksWithPositions[] => {
485
+ let lastNetworkHeight = 0
486
+ let lastPosition = UI_E_PositionsY.DIAGRAM_TOP + UI_E_PositionsY.BETWEEN_RECTS
487
+ mainRectHeights.value.networksHeight =
488
+ UI_E_PositionsY.DIAGRAM_TOP + UI_E_PositionsY.BETWEEN_RECTS
489
+
490
+ const lastIndex = props.diagramData?.networks.findLastIndex(
491
+ (network: UI_I_Network) =>
492
+ network.activeAdapters.length > 0 && network.state.state !== 3
493
+ )
494
+
495
+ return (
496
+ (newNetworks ? newNetworks : props.diagramData?.networks)?.map(
497
+ (network: UI_I_Network, index: number) => {
498
+ let portsCount = 0
499
+ if (
500
+ network.networkType ===
501
+ (UI_E_NetworkType.VMPortsGroup || UI_E_NetworkType.VCenter)
502
+ ) {
503
+ portsCount = network.ports.length
504
+ } else {
505
+ portsCount = network.sysx ? 1 : 0
506
+ }
507
+ const portsHeight = network.toggle
508
+ ? network.networkType === UI_E_NetworkType.VCenter
509
+ ? portsCount * UI_E_PositionsY.SINGLE_V_CENTER_HEIGHT
510
+ : portsCount * UI_E_PositionsY.SINGLE_PORT_HEIGHT
511
+ : 0
512
+ const networkHeight =
513
+ UI_E_PositionsY.PORTS_FROM_RECT_TOP +
514
+ portsHeight +
515
+ (network.networkType === UI_E_NetworkType.VCenter
516
+ ? UI_E_PositionsY.SINGLE_V_CENTER_HEIGHT - 10
517
+ : UI_E_PositionsY.SINGLE_PORT_HEIGHT) +
518
+ UI_E_PositionsY.SPACE_FROM_RECT_BOTTOM
519
+
520
+ lastPosition +=
521
+ lastNetworkHeight + (index && UI_E_PositionsY.BETWEEN_RECTS)
522
+ lastNetworkHeight = networkHeight
523
+
524
+ const connectLineY = lastPosition + networkHeight / 2
525
+ const titlePosition = lastPosition + UI_E_PositionsY.TITLE_FROM_RECT_TOP
526
+ const vlanPosition = lastPosition + UI_E_PositionsY.VLAN_FROM_RECT_TOP
527
+ const portsPosition = lastPosition + UI_E_PositionsY.PORTS_FROM_RECT_TOP
528
+
529
+ const networkPortsName =
530
+ (network.networkType === UI_E_NetworkType.VMkernel &&
531
+ 'VMkernel Ports') ||
532
+ (network.networkType === UI_E_NetworkType.VMPortsGroup &&
533
+ 'Virtual Machines') ||
534
+ (network.networkType === UI_E_NetworkType.VCenter &&
535
+ 'Virtual Machines') ||
536
+ ''
537
+
538
+ lastIndex !== -1 && index === 0 && (switchLine.value.y1 = connectLineY)
539
+ lastIndex !== -1 &&
540
+ index === lastIndex &&
541
+ (switchLine.value.y2 = connectLineY)
542
+
543
+ mainRectHeights.value.networksHeight +=
544
+ networkHeight + UI_E_PositionsY.BETWEEN_RECTS
545
+
546
+ const networkWithPortsPositions =
547
+ network.networkType ===
548
+ (UI_E_NetworkType.VMPortsGroup || UI_E_NetworkType.VCenter)
549
+ ? network.ports.map((port, index) => {
550
+ const portPosition =
551
+ portsPosition +
552
+ (network.networkType === UI_E_NetworkType.VCenter
553
+ ? (index + 1) * UI_E_PositionsY.SINGLE_V_CENTER_HEIGHT - 10
554
+ : (index + 1) * UI_E_PositionsY.SINGLE_PORT_HEIGHT)
555
+
556
+ return {
557
+ ...port,
558
+ portPosition,
559
+ }
560
+ })
561
+ : (network.sysx && [
562
+ {
563
+ id: network.sysx?.id,
564
+ name: `${network.sysx?.id} ${
565
+ network.sysx.ipv4_settings.ipv4
566
+ ? `: ${network.sysx.ipv4_settings.ipv4}`
567
+ : ''
568
+ }`,
569
+ state: network.sysx.state,
570
+ testId: `network-port-${index}`,
571
+ portPosition:
572
+ portsPosition + UI_E_PositionsY.SINGLE_PORT_HEIGHT,
573
+ },
574
+ ]) ||
575
+ []
576
+
577
+ return {
578
+ ...network,
579
+ ports: networkWithPortsPositions,
580
+ portsCount,
581
+ portsHeight,
582
+ networkHeight,
583
+ rectPosition: lastPosition,
584
+ connectLineY,
585
+ titlePosition,
586
+ vlanPosition,
587
+ vlanId: network.vlanId || '--',
588
+ portsPosition,
589
+ networkPortsName,
590
+ }
591
+ }
592
+ ) || []
593
+ )
594
+ }
595
+ const networksWithPositions = ref<UI_I_NetworksWithPositions[]>(
596
+ countNetworksPositions()
597
+ )
598
+
599
+ const isPortToggled = ref<UI_I_PortToggleFlag>({
600
+ value: false,
601
+ id: '',
602
+ })
603
+
604
+ const countAdaptersPositions = (): UI_I_AdaptersWithPositions => {
605
+ const { height, toggle, adaptersCount } = countAdaptersHeight(
606
+ props.diagramData
607
+ )
608
+
609
+ mainRectHeights.value.adaptersHeight =
610
+ UI_E_PositionsY.DIAGRAM_TOP + UI_E_PositionsY.BETWEEN_RECTS * 2 + height
611
+
612
+ const { titlePosition, rectPosition, adaptersConnectLineY, adapters } =
613
+ getAdaptersPositions(props.diagramData, height)
614
+
615
+ switchLine.value.ay = adaptersConnectLineY
616
+
617
+ return {
618
+ toggle,
619
+ height,
620
+ adapters,
621
+ rectPosition,
622
+ adaptersConnectLineY,
623
+ titlePosition,
624
+ adaptersCount,
625
+ }
626
+ }
627
+
628
+ const adaptersWithPositions = computed<UI_I_AdaptersWithPositions>(() => {
629
+ return countAdaptersPositions()
630
+ })
631
+
632
+ const networksCount = computed<number>(
633
+ () =>
634
+ networksWithPositions.value.filter(
635
+ (networkWithPositions: UI_I_NetworksWithPositions) =>
636
+ networkWithPositions.activeAdapters.length > 0 &&
637
+ networkWithPositions.state.state !== 3
638
+ ).length
639
+ )
640
+
641
+ watch(
642
+ () => props.diagramData?.networks,
643
+ (newValue: UI_I_Network[] | null) => {
644
+ networksWithPositions.value = countNetworksPositions(newValue)
645
+
646
+ isPortToggled.value.value && handlePortToggle()
647
+
648
+ if (selectedAdapter.value.adapterId !== '-1') {
649
+ onSelectAdapter(selectedAdapter.value.adapterId)
650
+ return
651
+ }
652
+
653
+ if (selectedPort.value.portId !== '-1') {
654
+ onSelectPort(selectedPort.value.networkId, selectedPort.value.portId)
655
+ return
656
+ }
657
+
658
+ if (selectedNetwork.value !== '-1') {
659
+ cashedNetworkId.value = '-1'
660
+ onSelectNetwork(selectedNetwork.value)
661
+ return
662
+ }
663
+
664
+ if (selectedMainLine.value && networksCount.value === 0) {
665
+ selectedMainLine.value = false
666
+ return
667
+ }
668
+
669
+ if (selectedMainLine.value) return
670
+
671
+ resetSelection()
672
+ },
673
+ { deep: true }
674
+ )
675
+
676
+ const onSelectPort = (networkId: string, portId: string): void => {
677
+ const selectPortData = getSelectPortDataFunc(
678
+ networkId,
679
+ portId,
680
+ networksWithPositions.value,
681
+ adaptersWithPositions.value
682
+ )
683
+
684
+ if (!selectPortData) return
685
+
686
+ selectedSwitchLineY.value = selectPortData.selectedSwitchLineY
687
+ selectedPort.value = selectPortData.selectedPort
688
+ }
689
+
690
+ const cashedNetworkId = ref<string>('-1')
691
+
692
+ const onSelectNetwork = (networkId: string): void => {
693
+ if (cashedNetworkId.value === networkId) {
694
+ resetSelection()
695
+ cashedNetworkId.value = '-1'
696
+ return
697
+ }
698
+
699
+ selectedNetwork.value = networkId
700
+
701
+ const selectNetworkData = getSelectNetworkDataFunc(
702
+ networkId,
703
+ networksWithPositions.value,
704
+ adaptersWithPositions.value
705
+ )
706
+
707
+ cashedNetworkId.value = networkId
708
+
709
+ if (!selectNetworkData) return
710
+
711
+ selectedSwitchLineY.value = selectNetworkData.selectedSwitchLineY
712
+ selectedPort.value = selectNetworkData.selectedPort
713
+ }
714
+
715
+ const onSelectAdapter = (adapterId: string): void => {
716
+ const selectedNetworks: UI_I_NetworksWithPositions[] =
717
+ networksWithPositions.value?.filter(
718
+ (network: UI_I_NetworksWithPositions) =>
719
+ network.activeAdapters.includes(adapterId) && network.state.state !== 3
720
+ )
721
+
722
+ let pos: number[] = selectedNetworks?.reduce(networksPositions, [])
723
+ let selectedAdapterPosition: number | null =
724
+ adaptersWithPositions.value.adapters?.find(
725
+ (adapter: UI_T_Adapters) => adapter.id === adapterId
726
+ )?.adapterPosition || null
727
+
728
+ selectedAdapterPosition !== null &&
729
+ (selectedAdapterPosition += 7.5) &&
730
+ pos?.push(selectedAdapterPosition)
731
+
732
+ pos = pos?.sort((y1, y2) => y1 - y2)
733
+
734
+ if (pos) {
735
+ selectedSwitchLineY.value = {
736
+ y1: pos[0],
737
+ y2: pos[pos.length - 1],
738
+ }
739
+ }
740
+
741
+ selectedAdapter.value = {
742
+ adapterId,
743
+ connectedPorts:
744
+ selectedNetworks?.map((network: UI_I_Network) => ({
745
+ networkId: network.id,
746
+ ports: network.ports.map((port) => port.id),
747
+ })) || [],
748
+ }
749
+ }
750
+
751
+ const resetSelection = (): void => {
752
+ selectedPort.value = useDeepCopy(selectedPortInitial)
753
+ selectedSwitchLineY.value = useDeepCopy(selectedSwitchLineYInitial)
754
+ selectedAdapter.value = useDeepCopy(selectedAdapterInitial)
755
+ selectedNetwork.value = '-1'
756
+ selectedMainLine.value = false
757
+ }
758
+
759
+ const emits = defineEmits<{
760
+ (
761
+ event: 'toggle-ports',
762
+ payload: Omit<UI_I_ToggleDiagramPortsPayload, 'paths'>
763
+ ): void
764
+ (
765
+ event: 'toggle-adapters',
766
+ payload: Omit<UI_I_ToggleDiagramAdaptersPayload, 'paths'>
767
+ ): void
768
+ (event: 'get-existing-standard-switches'): void
769
+ (
770
+ event: 'send-add-networking-data',
771
+ data: UI_T_EditData,
772
+ type: string,
773
+ hideModal: () => void
774
+ ): void
775
+ (
776
+ event: 'add-networking-data-validate',
777
+ data: UI_T_EditData,
778
+ type: string,
779
+ setValidation: (message: UI_I_ArbitraryObject<string>) => void
780
+ ): void
781
+ (
782
+ event: 'check-network-label',
783
+ label: string,
784
+ sendMessage: (message: string) => void
785
+ ): void
786
+ (event: 'get-free-adapters', showModal: () => void): void
787
+ (
788
+ event: 'send-edit-data',
789
+ type: string,
790
+ initialData: UI_I_ModalsInitialData,
791
+ hideModal: () => void,
792
+ id?: string
793
+ ): void
794
+ (event: 'change-edit-fields-data', editFieldsData: UI_I_EditFieldsData): void
795
+ (event: 'remove', id: string, type: string, hideModal: () => void): void
796
+ (
797
+ event: 'send-manage-physical-adapters-data',
798
+ adapterStatus: UI_I_AdapterStatus,
799
+ switchName: string,
800
+ initialData: UI_I_ModalsInitialData,
801
+ hideModal: () => void
802
+ ): void
803
+ (event: 'get-tcp-stacks'): void
804
+ }>()
805
+
806
+ const onTogglePorts = (
807
+ id: string,
808
+ isToggle: boolean,
809
+ diagramId: string
810
+ ): void => {
811
+ emits('toggle-ports', {
812
+ id,
813
+ isToggle,
814
+ diagramId,
815
+ })
816
+
817
+ isPortToggled.value = {
818
+ value: true,
819
+ id: id,
820
+ }
821
+ }
822
+
823
+ const handlePortToggle = () => {
824
+ cashedNetworkId.value = '-1'
825
+
826
+ selectedPort.value.portId !== '-1' &&
827
+ onSelectPort(selectedPort.value.networkId, selectedPort.value.portId)
828
+ selectedAdapter.value.adapterId !== '-1' &&
829
+ onSelectAdapter(selectedAdapter.value.adapterId)
830
+ selectedNetwork.value !== '-1' && onSelectNetwork(selectedNetwork.value)
831
+ hasPortAndNetwork(selectedPort.value, isPortToggled.value.id) &&
832
+ resetSelection()
833
+
834
+ isPortToggled.value = {
835
+ value: false,
836
+ id: '',
837
+ }
838
+ }
839
+
840
+ const onToggleAdapters = (): void => {
841
+ cashedNetworkId.value = '-1'
842
+
843
+ const newState = !adaptersWithPositions.value.toggle
844
+ const payload: Omit<UI_I_ToggleDiagramAdaptersPayload, 'paths'> = {
845
+ isToggle: newState,
846
+ diagramId: props.diagramData?.id || '',
847
+ }
848
+
849
+ emits('toggle-adapters', payload)
850
+
851
+ selectedPort.value.portId !== '-1' &&
852
+ onSelectPort(selectedPort.value.networkId, selectedPort.value.portId)
853
+ selectedAdapter.value.adapterId !== '-1' && resetSelection()
854
+ selectedNetwork.value !== '-1' && onSelectNetwork(selectedNetwork.value)
855
+ }
856
+
857
+ const onClickDiagram = (ev: MouseEvent): void => {
858
+ const target = ev.target as HTMLElement
859
+ const targetClassList = target.classList
860
+
861
+ if (!targetClassList.contains('network-title')) {
862
+ cashedNetworkId.value = '-1'
863
+ }
864
+
865
+ if (targetClassList.contains('main-line__handler')) {
866
+ resetSelection()
867
+ selectedMainLine.value = true
868
+ } else {
869
+ !(
870
+ target.closest('.diagram-block__toggle') ||
871
+ target.closest('.diagram-actions') ||
872
+ target.closest('.dropdown-actions-container')
873
+ ) && resetSelection()
874
+ }
875
+ }
876
+ </script>
877
+
878
+ <style scoped lang="scss">
879
+ .diagram {
880
+ &-min-width {
881
+ //min-width: 745px;
882
+ //min-width: 764px;
883
+ }
884
+ &-main-container {
885
+ padding-top: 5px;
886
+ }
887
+ }
888
+ </style>
889
+ <style lang="scss">
890
+ .diagram-main-actions__popup.navbar-dropdown-menu {
891
+ .btn {
892
+ border-radius: 3px;
893
+ border-bottom: none;
894
+ &:hover {
895
+ border-bottom: none;
896
+ }
897
+ span {
898
+ font-size: 14px;
899
+ }
900
+ &:active {
901
+ box-shadow: none;
902
+ }
903
+ }
904
+ }
905
+ </style>