bfg-common 1.5.489 → 1.5.491

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 (112) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  3. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  4. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  5. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  6. package/components/atoms/TheIcon3.vue +50 -50
  7. package/components/atoms/collapse/CollapseNav.vue +170 -170
  8. package/components/atoms/perPage/PerPage.vue +58 -58
  9. package/components/atoms/table/dataGrid/DataGridPagination.vue +97 -97
  10. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  11. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  12. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  13. package/components/common/browse/blocks/lib/models/types.ts +1 -1
  14. package/components/common/browse/lib/models/interfaces.ts +5 -5
  15. package/components/common/context/lib/models/interfaces.ts +33 -33
  16. package/components/common/diagramMain/DiagramMain.vue +905 -905
  17. package/components/common/diagramMain/modals/remove/RemoveModalNew.vue +106 -106
  18. package/components/common/diagramMain/network/Contents.vue +497 -497
  19. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  20. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  21. package/components/common/pages/backups/DetailView.vue +52 -52
  22. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  23. package/components/common/pages/backups/modals/Modals.vue +243 -243
  24. package/components/common/pages/backups/modals/createBackup/configuration/Configuration.vue +29 -29
  25. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  26. package/components/common/pages/backups/modals/createBackup/datastores/tableView/TableView.vue +95 -95
  27. package/components/common/pages/backups/modals/createBackup/general/General.vue +141 -141
  28. package/components/common/pages/backups/modals/createBackup/lib/config/strategyOptions.ts +12 -12
  29. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  30. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  31. package/components/common/pages/backups/modals/restore/disks/Disks.vue +27 -27
  32. package/components/common/pages/backups/modals/restore/disks/tableView/lib/config/table.ts +117 -117
  33. package/components/common/pages/backups/modals/restore/name/Name.vue +166 -166
  34. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  35. package/components/common/pages/backups/modals/restore/networks/Networks.vue +67 -67
  36. package/components/common/pages/backups/modals/restore/networks/table/Table.vue +214 -214
  37. package/components/common/pages/backups/modals/restore/types/lib/config/typeOptions.ts +25 -25
  38. package/components/common/pages/backups/tools/Tools.vue +75 -75
  39. package/components/common/pages/backups/tools/lib/config/tabs.ts +36 -36
  40. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  41. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  42. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  43. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  44. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  45. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  46. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  47. package/components/common/select/radio/RadioGroup.vue +137 -137
  48. package/components/common/spiceConsole/Drawer.vue +392 -392
  49. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  50. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  51. package/components/common/tools/Actions.vue +207 -207
  52. package/components/common/treeView/TreeView.vue +52 -52
  53. package/components/common/vm/actions/add/Add.vue +877 -877
  54. package/components/common/vm/actions/add/New.vue +1 -1
  55. package/components/common/vm/actions/add/Old.vue +1 -1
  56. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  57. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  58. package/components/common/vm/actions/add/lib/config/steps.ts +347 -331
  59. package/components/common/vm/actions/clone/Clone.vue +1 -1
  60. package/components/common/vm/actions/clone/toTemplate/ToTemplate.vue +1 -1
  61. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +368 -368
  62. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  63. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  64. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/Table.vue +99 -99
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  70. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  71. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  72. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  73. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  74. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  75. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  76. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  77. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +143 -143
  78. package/components/common/vm/actions/common/select/computeResource/New.vue +184 -184
  79. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +131 -131
  80. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  81. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  82. package/components/common/vm/actions/common/select/name/Name.vue +200 -200
  83. package/components/common/vm/actions/common/select/name/New.vue +3 -4
  84. package/components/common/vm/actions/common/select/name/Old.vue +130 -131
  85. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  86. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  87. package/components/common/vm/actions/common/select/storage/new/New.vue +320 -320
  88. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  89. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  90. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  91. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  92. package/components/common/vm/actions/register/Register.vue +267 -267
  93. package/components/common/vm/actions/register/lib/config/steps.ts +86 -86
  94. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  95. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  96. package/composables/useAppVersion.ts +21 -21
  97. package/composables/useLocal.ts +6 -6
  98. package/composables/useLocalCommon.ts +39 -39
  99. package/package.json +1 -1
  100. package/plugins/date.ts +233 -233
  101. package/plugins/panelStates.ts +70 -70
  102. package/plugins/text.ts +59 -59
  103. package/public/spice-console/lib/images/bitmap.js +203 -203
  104. package/public/spice-console/network/spicechannel.js +440 -440
  105. package/public/spice-console/run.js +210 -210
  106. package/store/main/mutations.ts +7 -7
  107. package/store/main/state.ts +7 -7
  108. package/components/common/vmt/actions/add/Add.vue +0 -549
  109. package/components/common/vmt/actions/add/New.vue +0 -346
  110. package/components/common/vmt/actions/add/Old.vue +0 -305
  111. package/components/common/vmt/actions/add/lib/config/steps.ts +0 -107
  112. package/components/common/vmt/actions/add/lib/models/interfaces.ts +0 -23
@@ -1,905 +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 (
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>
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>