bfg-common 1.5.252 → 1.5.254

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 (40) hide show
  1. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  2. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  3. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  4. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  5. package/assets/localization/local_be.json +19 -2
  6. package/assets/localization/local_en.json +19 -2
  7. package/assets/localization/local_hy.json +19 -2
  8. package/assets/localization/local_kk.json +19 -2
  9. package/assets/localization/local_ru.json +19 -2
  10. package/assets/localization/local_zh.json +20 -2
  11. package/assets/scss/clarity/local_ar.json +3 -1
  12. package/assets/scss/common/theme.scss +24 -0
  13. package/components/atoms/stack/StackBlock.vue +185 -185
  14. package/components/atoms/table/info/lib/models/interfaces.ts +10 -10
  15. package/components/common/browse/blocks/lib/models/types.ts +1 -1
  16. package/components/common/browse/lib/models/interfaces.ts +5 -5
  17. package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
  18. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  19. package/components/common/diagramMain/lib/models/types.ts +21 -21
  20. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  21. package/components/common/diagramMain/modals/editSettings/ConfirmTeamingSettingsModal.vue +40 -40
  22. package/components/common/diagramMain/modals/editSettings/tabs/NetworkProperties.vue +214 -214
  23. package/components/common/diagramMain/modals/editSettings/tabs/Security.vue +189 -189
  24. package/components/common/diagramMain/modals/editSettings/tabs/SwitchProperties.vue +163 -163
  25. package/components/common/diagramMain/modals/editSettings/tabs/TeamingFailover.vue +175 -175
  26. package/components/common/diagramMain/modals/editSettings/tabs/port/IpvFourSettings.vue +346 -346
  27. package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
  28. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  29. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +87 -87
  30. package/components/common/diagramMain/modals/lib/utils/index.ts +24 -24
  31. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
  32. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +169 -169
  33. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
  34. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +14 -14
  35. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
  36. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
  37. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  38. package/components/common/diagramMain/port/Ports.vue +47 -47
  39. package/lib/models/interfaces.ts +2 -0
  40. package/package.json +1 -1
@@ -1,331 +1,331 @@
1
- import type { UI_I_ItemsWithTotalCounts } from '~/lib/models/interfaces'
2
- import type {
3
- UI_I_Network,
4
- UI_I_SelectedPort,
5
- UI_I_NetworksWithPositions,
6
- UI_I_AdaptersWithPositions,
7
- UI_I_SelectedSwitchPositions,
8
- UI_I_DiagramData,
9
- UI_I_AdaptersHeight,
10
- UI_I_Adapter,
11
- UI_I_AdaptersPositions,
12
- UI_I_AdapterStatus,
13
- API_UI_I_SwitchItem,
14
- UI_I_AvailableAdapters,
15
- UI_I_SwitchAdapterItem,
16
- UI_I_AdapterWithError,
17
- } from '~/components/common/diagramMain/lib/models/interfaces'
18
- import type { UI_T_Adapters } from '~/components/common/diagramMain/lib/models/types'
19
- import {
20
- UI_E_NetworkType,
21
- UI_E_PositionsY,
22
- } from '~/components/common/diagramMain/lib/models/enums'
23
- import { NETWORK_POSITIONS } from '~/components/common/diagramMain/lib/config'
24
-
25
- export const hasPortAndNetwork = (
26
- selectedPort: UI_I_SelectedPort,
27
- id: string
28
- ): boolean =>
29
- selectedPort.portId !== '-1' &&
30
- selectedPort.networkId !== '-1' &&
31
- selectedPort.networkId === id
32
-
33
- export const networksPositions = (
34
- arr: number[],
35
- net: UI_I_NetworksWithPositions
36
- ): number[] => {
37
- if (net.ports.length === 0) return [...arr, net.connectLineY]
38
- if (!net.toggle)
39
- return [
40
- ...arr,
41
- net.portsPosition + NETWORK_POSITIONS.EMPTY_PORTS_PADDING_BOTTOM,
42
- ]
43
-
44
- return [
45
- ...arr,
46
- net.portsPosition +
47
- NETWORK_POSITIONS.FROM_VLAN_ID_TO_GROUP_NAME +
48
- NETWORK_POSITIONS.BETWEEN_VMS_AND_PORTS,
49
- net.networkType === UI_E_NetworkType.VCenter
50
- ? net.portsPosition +
51
- NETWORK_POSITIONS.FROM_VLAN_ID_TO_GROUP_NAME +
52
- NETWORK_POSITIONS.BETWEEN_V_CENTERS +
53
- NETWORK_POSITIONS.V_CENTER_HEIGHT * (net.portsCount - 1)
54
- : net.portsPosition +
55
- NETWORK_POSITIONS.FROM_VLAN_ID_TO_GROUP_NAME +
56
- NETWORK_POSITIONS.BETWEEN_VMS_AND_PORTS +
57
- NETWORK_POSITIONS.VMS_AND_PORTS_HEIGHT * (net.portsCount - 1),
58
- ]
59
- }
60
-
61
- export const getSelectedPortLinePositions = (
62
- selectedPortPosition: number | undefined,
63
- selectedNetworkData: UI_I_Network
64
- ) =>
65
- selectedPortPosition
66
- ? selectedNetworkData.networkType === UI_E_NetworkType.VCenter
67
- ? selectedPortPosition + 12.5
68
- : selectedPortPosition + 7.5
69
- : 0
70
-
71
- const selectedNetworkDataFunc = (
72
- networkId: string,
73
- networksWithPositions: UI_I_NetworksWithPositions[]
74
- ): UI_I_NetworksWithPositions | undefined =>
75
- networksWithPositions?.find(
76
- (network: UI_I_Network): boolean => network.id === networkId
77
- )
78
-
79
- export const getSelectNetworkDataFunc = (
80
- networkId: string,
81
- networksWithPositions: UI_I_NetworksWithPositions[],
82
- adaptersWithPositions: UI_I_AdaptersWithPositions
83
- ): UI_I_SelectedSwitchPositions | undefined => {
84
- const selectedNetworkData: UI_I_NetworksWithPositions | undefined =
85
- selectedNetworkDataFunc(networkId, networksWithPositions)
86
-
87
- if (!selectedNetworkData) return
88
-
89
- if (selectedNetworkData.state.state === 3)
90
- return {
91
- selectedSwitchLineY: {
92
- y1: 0,
93
- y2: 0,
94
- },
95
- selectedPort: {
96
- networkId,
97
- portId: '-1',
98
- activeAdapters: [],
99
- },
100
- }
101
-
102
- const activeAdapters: string[] = selectedNetworkData.activeAdapters
103
-
104
- const adaptersPositions: number[] =
105
- adaptersWithPositions.adapters
106
- ?.filter((adapter: UI_T_Adapters) => activeAdapters?.includes(adapter.id))
107
- ?.map((adapter: UI_T_Adapters) => adapter.adapterPosition + 7.5) || []
108
- let selectedPositions: number[] = []
109
-
110
- if (!adaptersWithPositions.toggle) {
111
- selectedPositions = [
112
- adaptersWithPositions.adaptersConnectLineY,
113
- selectedNetworkData.connectLineY,
114
- ]
115
- } else if (
116
- adaptersWithPositions.adapters === null ||
117
- adaptersWithPositions.adapters?.length === 0
118
- ) {
119
- selectedPositions = [47.5, selectedNetworkData.connectLineY].sort(
120
- (y1: number, y2: number) => y1 - y2
121
- )
122
- } else {
123
- selectedPositions = [
124
- ...adaptersPositions,
125
- selectedNetworkData.connectLineY,
126
- ].sort((y1: number, y2: number) => y1 - y2)
127
- }
128
-
129
- return {
130
- selectedSwitchLineY: {
131
- y1: selectedPositions[0],
132
- y2: selectedPositions[selectedPositions.length - 1],
133
- },
134
- selectedPort: {
135
- networkId,
136
- portId: '-1',
137
- activeAdapters: activeAdapters || [],
138
- },
139
- }
140
- }
141
-
142
- export const getSelectPortDataFunc = (
143
- networkId: string,
144
- portId: string,
145
- networksWithPositions: UI_I_NetworksWithPositions[],
146
- adaptersWithPositions: UI_I_AdaptersWithPositions
147
- ): UI_I_SelectedSwitchPositions | undefined => {
148
- const selectedNetworkData: UI_I_NetworksWithPositions | undefined =
149
- selectedNetworkDataFunc(networkId, networksWithPositions)
150
-
151
- if (!selectedNetworkData) return
152
-
153
- const activeAdapters: string[] = selectedNetworkData.activeAdapters
154
- const adaptersPositions: number[] =
155
- adaptersWithPositions.adapters
156
- ?.filter((adapter: UI_T_Adapters) => activeAdapters?.includes(adapter.id))
157
- ?.map((adapter: UI_T_Adapters) => adapter.adapterPosition + 7.5) || []
158
- const selectedPortPosition: number | undefined =
159
- selectedNetworkData.ports.find(
160
- (el): boolean => el.id === portId
161
- )?.portPosition
162
- const selectedPortLinePosition: number = getSelectedPortLinePositions(
163
- selectedPortPosition,
164
- selectedNetworkData
165
- )
166
- let selectedPositions: number[] = []
167
-
168
- if (!adaptersWithPositions.toggle) {
169
- selectedPositions = [
170
- adaptersWithPositions.adaptersConnectLineY,
171
- selectedNetworkData.connectLineY,
172
- selectedPortLinePosition,
173
- ]
174
- } else {
175
- selectedPositions = [...adaptersPositions, selectedPortLinePosition].sort(
176
- (y1: number, y2: number) => y1 - y2
177
- )
178
- }
179
-
180
- return {
181
- selectedSwitchLineY: {
182
- y1: selectedPositions[0],
183
- y2: selectedPositions[selectedPositions.length - 1],
184
- },
185
- selectedPort: {
186
- networkId,
187
- portId,
188
- activeAdapters: activeAdapters || [],
189
- },
190
- }
191
- }
192
-
193
- export const countAdaptersHeight = (
194
- diagramData: UI_I_DiagramData | null
195
- ): UI_I_AdaptersHeight => {
196
- const toggle: boolean = !!diagramData?.physicalAdapters?.toggle
197
- const adaptersCount: number =
198
- diagramData?.physicalAdapters?.adapters.length || 0
199
-
200
- return {
201
- height:
202
- UI_E_PositionsY.ADAPTER_FROM_RECT_TOP +
203
- (adaptersCount === 0
204
- ? UI_E_PositionsY.SINGLE_ADAPTER_HEIGHT
205
- : toggle
206
- ? adaptersCount * UI_E_PositionsY.SINGLE_ADAPTER_HEIGHT
207
- : 0) +
208
- UI_E_PositionsY.SPACE_FROM_RECT_BOTTOM,
209
- toggle,
210
- adaptersCount,
211
- }
212
- }
213
-
214
- export const getAdaptersPositions = (
215
- diagramData: UI_I_DiagramData | null,
216
- height: number
217
- ): UI_I_AdaptersPositions => {
218
- const titlePosition: number =
219
- UI_E_PositionsY.DIAGRAM_TOP +
220
- UI_E_PositionsY.BETWEEN_RECTS +
221
- UI_E_PositionsY.TITLE_FROM_RECT_TOP
222
-
223
- const rectPosition: number =
224
- UI_E_PositionsY.DIAGRAM_TOP + UI_E_PositionsY.BETWEEN_RECTS
225
-
226
- const adaptersConnectLineY: number = rectPosition + height / 2
227
-
228
- const adapters: UI_T_Adapters[] | null =
229
- diagramData?.physicalAdapters?.adapters.map(
230
- (adapter: UI_I_Adapter, index: number) => {
231
- const adapterPosition: number =
232
- UI_E_PositionsY.DIAGRAM_TOP +
233
- UI_E_PositionsY.BETWEEN_RECTS +
234
- UI_E_PositionsY.ADAPTER_FROM_RECT_TOP +
235
- UI_E_PositionsY.SINGLE_ADAPTER_HEIGHT * index
236
-
237
- return {
238
- ...adapter,
239
- adapterPosition,
240
- }
241
- }
242
- ) || null
243
-
244
- return {
245
- titlePosition,
246
- rectPosition,
247
- adaptersConnectLineY,
248
- adapters,
249
- }
250
- }
251
-
252
- export const makeSwitchSendData = (
253
- data: UI_I_DiagramData,
254
- adapterStatus: UI_I_AdapterStatus
255
- ): API_UI_I_SwitchItem | null => {
256
- if (!data.networking) return null
257
-
258
- return {
259
- id: data.id,
260
- mtu: data.networking.mtu,
261
- networks: data.networks.map((network: UI_I_Network) => network.title),
262
- nics: adapterStatus,
263
- security: {
264
- promiscuous: data.networking.securityPolicy[0].value,
265
- forged_transmits: data.networking.securityPolicy[1].value,
266
- mac_change: data.networking.securityPolicy[2].value,
267
- },
268
- teaming: {
269
- notify_switches: data.networking.nicTeamingPolicy[0].value,
270
- mode: data.networking.nicTeamingPolicy[1].value,
271
- link_detection_mode: data.networking.nicTeamingPolicy[2].value,
272
- failback: data.networking.nicTeamingPolicy[3].value,
273
- },
274
- shaping: {
275
- inherit: false,
276
- enabled: !!data.networking.shapingPolicy[0].value,
277
- average_bw: data.networking.average_bw,
278
- peak_bw: data.networking.peak_bw,
279
- burst_size: data.networking.burst_size,
280
- },
281
- }
282
- }
283
-
284
- export const getAvailableAdapters = (
285
- nics: UI_I_ItemsWithTotalCounts<UI_I_SwitchAdapterItem>,
286
- networkOrSwitchNics: UI_I_AdapterStatus
287
- ): UI_I_AvailableAdapters => {
288
- const availableAdapters: UI_I_AvailableAdapters = {
289
- activeAdapters: [],
290
- standbyAdapters: [],
291
- unusedAdapters: [],
292
- }
293
-
294
- if (nics?.items) {
295
- networkOrSwitchNics?.active?.forEach(
296
- (nic) =>
297
- nics?.items.find(
298
- (a: UI_I_SwitchAdapterItem): boolean => a.id === nic
299
- ) && availableAdapters.activeAdapters.push(nic)
300
- )
301
- networkOrSwitchNics?.standby?.forEach(
302
- (nic) =>
303
- nics?.items.find(
304
- (a: UI_I_SwitchAdapterItem): boolean => a.id === nic
305
- ) && availableAdapters.standbyAdapters.push(nic)
306
- )
307
- networkOrSwitchNics?.unused?.forEach(
308
- (nic) =>
309
- nics?.items.find(
310
- (a: UI_I_SwitchAdapterItem): boolean => a.id === nic
311
- ) && availableAdapters.unusedAdapters.push(nic)
312
- )
313
- }
314
-
315
- return availableAdapters
316
- }
317
-
318
- export const createAdapterWithError = (
319
- nic: string,
320
- switchId: string
321
- ): UI_I_AdapterWithError => ({
322
- fullName: nic,
323
- id: nic,
324
- name: nic,
325
- networks: [],
326
- state: { state: 1, errors: [] },
327
- switch: switchId,
328
- testId: `adapter-${nic}`,
329
- carrier: false,
330
- status: 'error',
331
- })
1
+ import type { UI_I_ItemsWithTotalCounts } from '~/lib/models/interfaces'
2
+ import type {
3
+ UI_I_Network,
4
+ UI_I_SelectedPort,
5
+ UI_I_NetworksWithPositions,
6
+ UI_I_AdaptersWithPositions,
7
+ UI_I_SelectedSwitchPositions,
8
+ UI_I_DiagramData,
9
+ UI_I_AdaptersHeight,
10
+ UI_I_Adapter,
11
+ UI_I_AdaptersPositions,
12
+ UI_I_AdapterStatus,
13
+ API_UI_I_SwitchItem,
14
+ UI_I_AvailableAdapters,
15
+ UI_I_SwitchAdapterItem,
16
+ UI_I_AdapterWithError,
17
+ } from '~/components/common/diagramMain/lib/models/interfaces'
18
+ import type { UI_T_Adapters } from '~/components/common/diagramMain/lib/models/types'
19
+ import {
20
+ UI_E_NetworkType,
21
+ UI_E_PositionsY,
22
+ } from '~/components/common/diagramMain/lib/models/enums'
23
+ import { NETWORK_POSITIONS } from '~/components/common/diagramMain/lib/config'
24
+
25
+ export const hasPortAndNetwork = (
26
+ selectedPort: UI_I_SelectedPort,
27
+ id: string
28
+ ): boolean =>
29
+ selectedPort.portId !== '-1' &&
30
+ selectedPort.networkId !== '-1' &&
31
+ selectedPort.networkId === id
32
+
33
+ export const networksPositions = (
34
+ arr: number[],
35
+ net: UI_I_NetworksWithPositions
36
+ ): number[] => {
37
+ if (net.ports.length === 0) return [...arr, net.connectLineY]
38
+ if (!net.toggle)
39
+ return [
40
+ ...arr,
41
+ net.portsPosition + NETWORK_POSITIONS.EMPTY_PORTS_PADDING_BOTTOM,
42
+ ]
43
+
44
+ return [
45
+ ...arr,
46
+ net.portsPosition +
47
+ NETWORK_POSITIONS.FROM_VLAN_ID_TO_GROUP_NAME +
48
+ NETWORK_POSITIONS.BETWEEN_VMS_AND_PORTS,
49
+ net.networkType === UI_E_NetworkType.VCenter
50
+ ? net.portsPosition +
51
+ NETWORK_POSITIONS.FROM_VLAN_ID_TO_GROUP_NAME +
52
+ NETWORK_POSITIONS.BETWEEN_V_CENTERS +
53
+ NETWORK_POSITIONS.V_CENTER_HEIGHT * (net.portsCount - 1)
54
+ : net.portsPosition +
55
+ NETWORK_POSITIONS.FROM_VLAN_ID_TO_GROUP_NAME +
56
+ NETWORK_POSITIONS.BETWEEN_VMS_AND_PORTS +
57
+ NETWORK_POSITIONS.VMS_AND_PORTS_HEIGHT * (net.portsCount - 1),
58
+ ]
59
+ }
60
+
61
+ export const getSelectedPortLinePositions = (
62
+ selectedPortPosition: number | undefined,
63
+ selectedNetworkData: UI_I_Network
64
+ ) =>
65
+ selectedPortPosition
66
+ ? selectedNetworkData.networkType === UI_E_NetworkType.VCenter
67
+ ? selectedPortPosition + 12.5
68
+ : selectedPortPosition + 7.5
69
+ : 0
70
+
71
+ const selectedNetworkDataFunc = (
72
+ networkId: string,
73
+ networksWithPositions: UI_I_NetworksWithPositions[]
74
+ ): UI_I_NetworksWithPositions | undefined =>
75
+ networksWithPositions?.find(
76
+ (network: UI_I_Network): boolean => network.id === networkId
77
+ )
78
+
79
+ export const getSelectNetworkDataFunc = (
80
+ networkId: string,
81
+ networksWithPositions: UI_I_NetworksWithPositions[],
82
+ adaptersWithPositions: UI_I_AdaptersWithPositions
83
+ ): UI_I_SelectedSwitchPositions | undefined => {
84
+ const selectedNetworkData: UI_I_NetworksWithPositions | undefined =
85
+ selectedNetworkDataFunc(networkId, networksWithPositions)
86
+
87
+ if (!selectedNetworkData) return
88
+
89
+ if (selectedNetworkData.state.state === 3)
90
+ return {
91
+ selectedSwitchLineY: {
92
+ y1: 0,
93
+ y2: 0,
94
+ },
95
+ selectedPort: {
96
+ networkId,
97
+ portId: '-1',
98
+ activeAdapters: [],
99
+ },
100
+ }
101
+
102
+ const activeAdapters: string[] = selectedNetworkData.activeAdapters
103
+
104
+ const adaptersPositions: number[] =
105
+ adaptersWithPositions.adapters
106
+ ?.filter((adapter: UI_T_Adapters) => activeAdapters?.includes(adapter.id))
107
+ ?.map((adapter: UI_T_Adapters) => adapter.adapterPosition + 7.5) || []
108
+ let selectedPositions: number[] = []
109
+
110
+ if (!adaptersWithPositions.toggle) {
111
+ selectedPositions = [
112
+ adaptersWithPositions.adaptersConnectLineY,
113
+ selectedNetworkData.connectLineY,
114
+ ]
115
+ } else if (
116
+ adaptersWithPositions.adapters === null ||
117
+ adaptersWithPositions.adapters?.length === 0
118
+ ) {
119
+ selectedPositions = [47.5, selectedNetworkData.connectLineY].sort(
120
+ (y1: number, y2: number) => y1 - y2
121
+ )
122
+ } else {
123
+ selectedPositions = [
124
+ ...adaptersPositions,
125
+ selectedNetworkData.connectLineY,
126
+ ].sort((y1: number, y2: number) => y1 - y2)
127
+ }
128
+
129
+ return {
130
+ selectedSwitchLineY: {
131
+ y1: selectedPositions[0],
132
+ y2: selectedPositions[selectedPositions.length - 1],
133
+ },
134
+ selectedPort: {
135
+ networkId,
136
+ portId: '-1',
137
+ activeAdapters: activeAdapters || [],
138
+ },
139
+ }
140
+ }
141
+
142
+ export const getSelectPortDataFunc = (
143
+ networkId: string,
144
+ portId: string,
145
+ networksWithPositions: UI_I_NetworksWithPositions[],
146
+ adaptersWithPositions: UI_I_AdaptersWithPositions
147
+ ): UI_I_SelectedSwitchPositions | undefined => {
148
+ const selectedNetworkData: UI_I_NetworksWithPositions | undefined =
149
+ selectedNetworkDataFunc(networkId, networksWithPositions)
150
+
151
+ if (!selectedNetworkData) return
152
+
153
+ const activeAdapters: string[] = selectedNetworkData.activeAdapters
154
+ const adaptersPositions: number[] =
155
+ adaptersWithPositions.adapters
156
+ ?.filter((adapter: UI_T_Adapters) => activeAdapters?.includes(adapter.id))
157
+ ?.map((adapter: UI_T_Adapters) => adapter.adapterPosition + 7.5) || []
158
+ const selectedPortPosition: number | undefined =
159
+ selectedNetworkData.ports.find(
160
+ (el): boolean => el.id === portId
161
+ )?.portPosition
162
+ const selectedPortLinePosition: number = getSelectedPortLinePositions(
163
+ selectedPortPosition,
164
+ selectedNetworkData
165
+ )
166
+ let selectedPositions: number[] = []
167
+
168
+ if (!adaptersWithPositions.toggle) {
169
+ selectedPositions = [
170
+ adaptersWithPositions.adaptersConnectLineY,
171
+ selectedNetworkData.connectLineY,
172
+ selectedPortLinePosition,
173
+ ]
174
+ } else {
175
+ selectedPositions = [...adaptersPositions, selectedPortLinePosition].sort(
176
+ (y1: number, y2: number) => y1 - y2
177
+ )
178
+ }
179
+
180
+ return {
181
+ selectedSwitchLineY: {
182
+ y1: selectedPositions[0],
183
+ y2: selectedPositions[selectedPositions.length - 1],
184
+ },
185
+ selectedPort: {
186
+ networkId,
187
+ portId,
188
+ activeAdapters: activeAdapters || [],
189
+ },
190
+ }
191
+ }
192
+
193
+ export const countAdaptersHeight = (
194
+ diagramData: UI_I_DiagramData | null
195
+ ): UI_I_AdaptersHeight => {
196
+ const toggle: boolean = !!diagramData?.physicalAdapters?.toggle
197
+ const adaptersCount: number =
198
+ diagramData?.physicalAdapters?.adapters.length || 0
199
+
200
+ return {
201
+ height:
202
+ UI_E_PositionsY.ADAPTER_FROM_RECT_TOP +
203
+ (adaptersCount === 0
204
+ ? UI_E_PositionsY.SINGLE_ADAPTER_HEIGHT
205
+ : toggle
206
+ ? adaptersCount * UI_E_PositionsY.SINGLE_ADAPTER_HEIGHT
207
+ : 0) +
208
+ UI_E_PositionsY.SPACE_FROM_RECT_BOTTOM,
209
+ toggle,
210
+ adaptersCount,
211
+ }
212
+ }
213
+
214
+ export const getAdaptersPositions = (
215
+ diagramData: UI_I_DiagramData | null,
216
+ height: number
217
+ ): UI_I_AdaptersPositions => {
218
+ const titlePosition: number =
219
+ UI_E_PositionsY.DIAGRAM_TOP +
220
+ UI_E_PositionsY.BETWEEN_RECTS +
221
+ UI_E_PositionsY.TITLE_FROM_RECT_TOP
222
+
223
+ const rectPosition: number =
224
+ UI_E_PositionsY.DIAGRAM_TOP + UI_E_PositionsY.BETWEEN_RECTS
225
+
226
+ const adaptersConnectLineY: number = rectPosition + height / 2
227
+
228
+ const adapters: UI_T_Adapters[] | null =
229
+ diagramData?.physicalAdapters?.adapters.map(
230
+ (adapter: UI_I_Adapter, index: number) => {
231
+ const adapterPosition: number =
232
+ UI_E_PositionsY.DIAGRAM_TOP +
233
+ UI_E_PositionsY.BETWEEN_RECTS +
234
+ UI_E_PositionsY.ADAPTER_FROM_RECT_TOP +
235
+ UI_E_PositionsY.SINGLE_ADAPTER_HEIGHT * index
236
+
237
+ return {
238
+ ...adapter,
239
+ adapterPosition,
240
+ }
241
+ }
242
+ ) || null
243
+
244
+ return {
245
+ titlePosition,
246
+ rectPosition,
247
+ adaptersConnectLineY,
248
+ adapters,
249
+ }
250
+ }
251
+
252
+ export const makeSwitchSendData = (
253
+ data: UI_I_DiagramData,
254
+ adapterStatus: UI_I_AdapterStatus
255
+ ): API_UI_I_SwitchItem | null => {
256
+ if (!data.networking) return null
257
+
258
+ return {
259
+ id: data.id,
260
+ mtu: data.networking.mtu,
261
+ networks: data.networks.map((network: UI_I_Network) => network.title),
262
+ nics: adapterStatus,
263
+ security: {
264
+ promiscuous: data.networking.securityPolicy[0].value,
265
+ forged_transmits: data.networking.securityPolicy[1].value,
266
+ mac_change: data.networking.securityPolicy[2].value,
267
+ },
268
+ teaming: {
269
+ notify_switches: data.networking.nicTeamingPolicy[0].value,
270
+ mode: data.networking.nicTeamingPolicy[1].value,
271
+ link_detection_mode: data.networking.nicTeamingPolicy[2].value,
272
+ failback: data.networking.nicTeamingPolicy[3].value,
273
+ },
274
+ shaping: {
275
+ inherit: false,
276
+ enabled: !!data.networking.shapingPolicy[0].value,
277
+ average_bw: data.networking.average_bw,
278
+ peak_bw: data.networking.peak_bw,
279
+ burst_size: data.networking.burst_size,
280
+ },
281
+ }
282
+ }
283
+
284
+ export const getAvailableAdapters = (
285
+ nics: UI_I_ItemsWithTotalCounts<UI_I_SwitchAdapterItem>,
286
+ networkOrSwitchNics: UI_I_AdapterStatus
287
+ ): UI_I_AvailableAdapters => {
288
+ const availableAdapters: UI_I_AvailableAdapters = {
289
+ activeAdapters: [],
290
+ standbyAdapters: [],
291
+ unusedAdapters: [],
292
+ }
293
+
294
+ if (nics?.items) {
295
+ networkOrSwitchNics?.active?.forEach(
296
+ (nic) =>
297
+ nics?.items.find(
298
+ (a: UI_I_SwitchAdapterItem): boolean => a.id === nic
299
+ ) && availableAdapters.activeAdapters.push(nic)
300
+ )
301
+ networkOrSwitchNics?.standby?.forEach(
302
+ (nic) =>
303
+ nics?.items.find(
304
+ (a: UI_I_SwitchAdapterItem): boolean => a.id === nic
305
+ ) && availableAdapters.standbyAdapters.push(nic)
306
+ )
307
+ networkOrSwitchNics?.unused?.forEach(
308
+ (nic) =>
309
+ nics?.items.find(
310
+ (a: UI_I_SwitchAdapterItem): boolean => a.id === nic
311
+ ) && availableAdapters.unusedAdapters.push(nic)
312
+ )
313
+ }
314
+
315
+ return availableAdapters
316
+ }
317
+
318
+ export const createAdapterWithError = (
319
+ nic: string,
320
+ switchId: string
321
+ ): UI_I_AdapterWithError => ({
322
+ fullName: nic,
323
+ id: nic,
324
+ name: nic,
325
+ networks: [],
326
+ state: { state: 1, errors: [] },
327
+ switch: switchId,
328
+ testId: `adapter-${nic}`,
329
+ carrier: false,
330
+ status: 'error',
331
+ })