bfg-common 1.5.375 → 1.5.377

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 (170) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  3. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  4. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  5. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  6. package/assets/localization/local_be.json +15 -1
  7. package/assets/localization/local_en.json +15 -1
  8. package/assets/localization/local_hy.json +15 -1
  9. package/assets/localization/local_kk.json +15 -1
  10. package/assets/localization/local_ru.json +15 -1
  11. package/assets/localization/local_zh.json +15 -1
  12. package/components/atoms/TheIcon3.vue +50 -50
  13. package/components/atoms/collapse/CollapseNav.vue +170 -170
  14. package/components/atoms/collapse/CollapseNavItem.vue +226 -226
  15. package/components/atoms/nav/NavBar.vue +147 -147
  16. package/components/atoms/perPage/PerPage.vue +58 -58
  17. package/components/atoms/table/dataGrid/DataGrid.vue +1717 -1717
  18. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  19. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  20. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  21. package/components/common/backup/storage/actions/add/lib/config/steps.ts +168 -168
  22. package/components/common/backup/storage/actions/add/steps/hostAccessibility/HostAccessibility.vue +52 -52
  23. package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyComplete.vue +45 -45
  24. package/components/common/backup/storage/actions/delete/Delete.vue +65 -65
  25. package/components/common/browse/BrowseNew.vue +8 -2
  26. package/components/common/browse/blocks/Container.vue +234 -231
  27. package/components/common/browse/blocks/TitleNew.vue +2 -2
  28. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  29. package/components/common/browse/blocks/lib/models/types.ts +1 -1
  30. package/components/common/browse/lib/models/interfaces.ts +5 -5
  31. package/components/common/context/lib/models/interfaces.ts +33 -33
  32. package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
  33. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  34. package/components/common/diagramMain/lib/models/types.ts +21 -21
  35. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  36. package/components/common/diagramMain/modals/editSettings/ConfirmTeamingSettingsModal.vue +40 -40
  37. package/components/common/diagramMain/modals/editSettings/tabs/NetworkProperties.vue +214 -214
  38. package/components/common/diagramMain/modals/editSettings/tabs/Security.vue +189 -189
  39. package/components/common/diagramMain/modals/editSettings/tabs/SwitchProperties.vue +163 -163
  40. package/components/common/diagramMain/modals/editSettings/tabs/TeamingFailover.vue +175 -175
  41. package/components/common/diagramMain/modals/editSettings/tabs/port/IpvFourSettings.vue +346 -346
  42. package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
  43. package/components/common/diagramMain/modals/lib/config/networkModal.ts +398 -398
  44. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  45. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +87 -87
  46. package/components/common/diagramMain/modals/lib/utils/index.ts +24 -24
  47. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
  48. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +169 -169
  49. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
  50. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +14 -14
  51. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
  52. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
  53. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  54. package/components/common/diagramMain/network/Network.vue +141 -141
  55. package/components/common/diagramMain/port/Ports.vue +47 -47
  56. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  57. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  58. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  59. package/components/common/pages/home/headline/Headline.vue +45 -45
  60. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  61. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  62. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  63. package/components/common/pages/home/widgets/WidgetsNew.vue +88 -88
  64. package/components/common/pages/home/widgets/WidgetsOld.vue +36 -36
  65. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  66. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  67. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  68. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  69. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  70. package/components/common/pages/packages/Packages.vue +208 -208
  71. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  72. package/components/common/readyToComplete/New.vue +129 -129
  73. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  74. package/components/common/recursionTree/RecursionTree.vue +223 -223
  75. package/components/common/select/button/ButtonDropdown.vue +112 -112
  76. package/components/common/spiceConsole/Drawer.vue +377 -377
  77. package/components/common/spiceConsole/SpiceConsole.vue +127 -127
  78. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  79. package/components/common/tools/Actions.vue +207 -207
  80. package/components/common/vm/actions/add/Add.vue +831 -827
  81. package/components/common/vm/actions/add/Old.vue +388 -388
  82. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  83. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  84. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  85. package/components/common/vm/actions/clone/Clone.vue +823 -823
  86. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  87. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  88. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +321 -321
  89. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +227 -227
  90. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +100 -100
  91. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  92. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  93. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  94. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +78 -78
  95. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  96. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipNew.vue +154 -154
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/config/dropdownItems.ts +155 -155
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +307 -307
  102. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +385 -385
  103. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  104. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +85 -85
  105. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -288
  106. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/Table.vue +6 -0
  107. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
  108. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  109. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  110. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  111. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  112. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  113. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  114. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  115. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  116. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  117. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  118. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  119. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCard.vue +154 -154
  120. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  121. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +155 -155
  122. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +130 -130
  123. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsOld.vue +113 -113
  124. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  125. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  126. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  127. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptions.vue +95 -95
  128. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsOld.vue +155 -155
  129. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  130. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapOld.vue +44 -44
  131. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  132. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  133. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  134. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  135. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +143 -143
  136. package/components/common/vm/actions/common/select/computeResource/New.vue +184 -184
  137. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +131 -131
  138. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  139. package/components/common/vm/actions/common/select/createType/lib/config/items.ts +48 -48
  140. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  141. package/components/common/vm/actions/common/select/name/Name.vue +174 -174
  142. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  143. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  144. package/components/common/vm/actions/common/select/storage/Storage.vue +155 -155
  145. package/components/common/vm/actions/common/select/storage/new/New.vue +300 -300
  146. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  147. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  148. package/components/common/vm/actions/editSettings/EditSettings.vue +242 -242
  149. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  150. package/components/common/vmt/actions/add/lib/models/interfaces.ts +23 -23
  151. package/components/common/wizards/network/add/steps/SelectConnectionType.vue +104 -104
  152. package/components/common/wizards/network/add/steps/SelectedTargetDevice.vue +467 -467
  153. package/components/common/wizards/vm/migrate/Migrate.vue +349 -349
  154. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  155. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  156. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  157. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  158. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  159. package/components/common/wizards/vm/migrate/select/type/lib/config/typeOptions.ts +45 -45
  160. package/composables/productNameLocal.ts +30 -30
  161. package/composables/useAppVersion.ts +21 -21
  162. package/package.json +1 -1
  163. package/plugins/date.ts +233 -233
  164. package/plugins/panelStates.ts +70 -70
  165. package/plugins/text.ts +59 -59
  166. package/public/spice-console/lib/images/bitmap.js +203 -203
  167. package/public/spice-console/network/spicechannel.js +387 -387
  168. package/store/main/mutations.ts +7 -7
  169. package/store/main/state.ts +7 -7
  170. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -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
+ })