bfg-common 1.6.76 → 1.6.78

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 (138) hide show
  1. package/assets/localization/local_be.json +1 -14
  2. package/assets/localization/local_en.json +1 -14
  3. package/assets/localization/local_hy.json +1 -14
  4. package/assets/localization/local_kk.json +1 -14
  5. package/assets/localization/local_ru.json +1 -14
  6. package/assets/localization/local_zh.json +1 -14
  7. package/components/atoms/dropdown/dropdown/Dropdown.vue +170 -170
  8. package/components/atoms/dropdown/dropdown/lib/models/interfaces.ts +10 -10
  9. package/components/common/adapterManager/AdapterManager.vue +473 -473
  10. package/components/common/adapterManager/AdapterManagerOld.vue +498 -498
  11. package/components/common/adapterManager/addAdapterModal/AddAdapterModal.vue +70 -70
  12. package/components/common/adapterManager/addAdapterModal/AddAdapterModalNew.vue +110 -110
  13. package/components/common/adapterManager/addAdapterModal/AddAdapterModalOld.vue +531 -531
  14. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModal.vue +32 -32
  15. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModalNew.vue +37 -37
  16. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModalOld.vue +73 -73
  17. package/components/common/adapterManager/lib/config/index.ts +19 -19
  18. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModal.vue +31 -31
  19. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModalNew.vue +34 -34
  20. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModalOld.vue +57 -57
  21. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModal.vue +31 -31
  22. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModalNew.vue +34 -34
  23. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModalOld.vue +57 -57
  24. package/components/common/adapterManager/ui/actions/AddAdapterButton.vue +34 -34
  25. package/components/common/adapterManager/ui/actions/RemoveAdapterButton.vue +41 -41
  26. package/components/common/adapterManager/ui/actions/VerticalSeparator.vue +10 -10
  27. package/components/common/adapterManager/ui/actions/bar/BarOld.vue +95 -95
  28. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButton.vue +28 -28
  29. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButtonNew.vue +76 -76
  30. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButtonOld.vue +33 -33
  31. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButton.vue +28 -28
  32. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButtonNew.vue +77 -77
  33. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButtonOld.vue +33 -33
  34. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapter.vue +24 -24
  35. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapterNew.vue +18 -18
  36. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapterOld.vue +38 -38
  37. package/components/common/adapterManager/ui/secondTitle/SecondTitle.vue +31 -31
  38. package/components/common/adapterManager/ui/secondTitle/SecondTitleNew.vue +51 -51
  39. package/components/common/adapterManager/ui/secondTitle/SecondTitleOld.vue +35 -35
  40. package/components/common/adapterManager/ui/table/Table.vue +88 -88
  41. package/components/common/adapterManager/ui/table/TableNew.vue +137 -137
  42. package/components/common/adapterManager/ui/table/TableOld.vue +141 -141
  43. package/components/common/adapterManager/ui/table/adapters/Adapters.vue +44 -44
  44. package/components/common/adapterManager/ui/table/adapters/AdaptersNew.vue +187 -187
  45. package/components/common/adapterManager/ui/table/adapters/AdaptersOld.vue +87 -87
  46. package/components/common/adapterManager/ui/table/header/Header.vue +57 -57
  47. package/components/common/adapterManager/ui/table/header/HeaderNew.vue +81 -81
  48. package/components/common/adapterManager/ui/table/header/HeaderOld.vue +79 -79
  49. package/components/common/adapterManager/ui/table/lib/models/types.ts +1 -1
  50. package/components/common/certificate/Certificate.vue +6 -16
  51. package/components/common/certificate/{Info/Old.vue → CertificateInfo.vue} +34 -6
  52. package/components/common/certificate/{tools/Tools.vue → Tools.vue} +23 -18
  53. package/components/common/certificate/lib/config/tabsPannel.ts +22 -0
  54. package/components/common/diagramMain/adapter/Adapter.vue +123 -123
  55. package/components/common/diagramMain/adapter/AdapterItem.vue +438 -438
  56. package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
  57. package/components/common/diagramMain/adapter/Contents.vue +212 -212
  58. package/components/common/diagramMain/adapter/Lines.vue +81 -81
  59. package/components/common/diagramMain/adapter/block/Block.vue +27 -27
  60. package/components/common/diagramMain/adapter/block/BlockNew.vue +58 -58
  61. package/components/common/diagramMain/adapter/block/BlockOld.vue +50 -50
  62. package/components/common/diagramMain/adapter/secondBlock/SecondBlock.vue +27 -27
  63. package/components/common/diagramMain/adapter/secondBlock/SecondBlockNew.vue +60 -60
  64. package/components/common/diagramMain/adapter/secondBlock/SecondBlockOld.vue +51 -51
  65. package/components/common/diagramMain/highlights/Highlights.vue +151 -151
  66. package/components/common/diagramMain/highlights/HighlightsNew.vue +124 -124
  67. package/components/common/diagramMain/highlights/HighlightsOld.vue +107 -107
  68. package/components/common/diagramMain/lib/config/index.ts +81 -81
  69. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  70. package/components/common/diagramMain/lib/config/positions.ts +194 -194
  71. package/components/common/diagramMain/lib/models/enums.ts +44 -44
  72. package/components/common/diagramMain/lib/models/interfaces.ts +760 -760
  73. package/components/common/diagramMain/lib/models/types.ts +21 -21
  74. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  75. package/components/common/diagramMain/modals/ManagePhysicalAdaptersModal.vue +331 -331
  76. package/components/common/diagramMain/modals/Modals.vue +483 -483
  77. package/components/common/diagramMain/modals/lib/config/adapterModal.ts +147 -147
  78. package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
  79. package/components/common/diagramMain/modals/lib/config/networkModal.ts +405 -405
  80. package/components/common/diagramMain/modals/lib/config/portModal.ts +253 -253
  81. package/components/common/diagramMain/modals/lib/config/switchModal.ts +245 -245
  82. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  83. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  84. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +88 -88
  85. package/components/common/diagramMain/modals/migrateVmkernelAdapter/MigrateVmkernelAdapter.vue +541 -541
  86. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
  87. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +170 -170
  88. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
  89. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/VmkernelAdapterReadyComplete.vue +49 -49
  90. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +19 -19
  91. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
  92. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
  93. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  94. package/components/common/diagramMain/modals/remove/RemoveModal.vue +82 -82
  95. package/components/common/diagramMain/modals/remove/RemoveModalNew.vue +106 -106
  96. package/components/common/diagramMain/modals/remove/RemoveModalOld.vue +241 -241
  97. package/components/common/diagramMain/modals/viewSettings/info/Info.vue +57 -57
  98. package/components/common/diagramMain/modals/viewSettings/info/InfoNew.vue +174 -174
  99. package/components/common/diagramMain/modals/viewSettings/info/InfoOld.vue +141 -141
  100. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettings.vue +45 -45
  101. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsNew.vue +323 -323
  102. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsOld.vue +203 -203
  103. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModal.vue +60 -60
  104. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModalNew.vue +50 -50
  105. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModalOld.vue +70 -70
  106. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/lib/models/interfaces.ts +48 -48
  107. package/components/common/diagramMain/network/Contents.vue +497 -497
  108. package/components/common/diagramMain/network/Lines.vue +107 -107
  109. package/components/common/diagramMain/network/Network.vue +141 -141
  110. package/components/common/diagramMain/network/block/Block.vue +37 -37
  111. package/components/common/diagramMain/network/block/BlockNew.vue +68 -68
  112. package/components/common/diagramMain/network/block/BlockOld.vue +64 -64
  113. package/components/common/diagramMain/network/noNetwork/NoNetwork.vue +12 -12
  114. package/components/common/diagramMain/network/noNetwork/NoNetworkNew.vue +89 -89
  115. package/components/common/diagramMain/network/noNetwork/NoNetworkOld.vue +61 -61
  116. package/components/common/diagramMain/network/secondBlock/SecondBlock.vue +41 -41
  117. package/components/common/diagramMain/network/secondBlock/SecondBlockNew.vue +64 -64
  118. package/components/common/diagramMain/network/secondBlock/SecondBlockOld.vue +60 -60
  119. package/components/common/diagramMain/port/Port.vue +580 -580
  120. package/components/common/diagramMain/port/Ports.vue +47 -47
  121. package/components/common/diagramMain/switch/Switch.vue +180 -180
  122. package/components/common/diagramMain/switch/SwitchSelected.vue +111 -111
  123. package/components/common/monitor/advanced/table/tableOld/TableOld.vue +93 -93
  124. package/components/common/monitor/utilization/lib/models/enums.ts +4 -4
  125. package/components/common/split/horizontal/New.vue +1 -1
  126. package/components/common/split/horizontal/Old.vue +1 -1
  127. package/package.json +2 -2
  128. package/components/common/certificate/Info/Info.vue +0 -61
  129. package/components/common/certificate/Info/new/New.vue +0 -285
  130. package/components/common/certificate/Info/new/lib/config/index.ts +0 -59
  131. package/components/common/certificate/Info/new/lib/models/interfaces.ts +0 -3
  132. package/components/common/certificate/Info/new/lib/utils/index.ts +0 -10
  133. package/components/common/certificate/Old.vue +0 -27
  134. package/components/common/certificate/new/New.vue +0 -30
  135. package/components/common/certificate/new/Skeleton.vue +0 -155
  136. package/components/common/certificate/tools/New.vue +0 -48
  137. package/components/common/certificate/tools/Old.vue +0 -39
  138. package/components/common/certificate/tools/lib/config/tabsPannel.ts +0 -20
@@ -1,498 +1,498 @@
1
- <template>
2
- <div
3
- :class="[
4
- 'edit-pg-failover-order-with-details',
5
- {
6
- 'element-disabled': !props.isActive,
7
- 'full-height': props.fullMode,
8
- 'add-adapter-view': props.isAddModal,
9
- 'is-dark': props.isDarkMode,
10
- },
11
- ]"
12
- >
13
- <div class="failover-order-with-details flex-grow-auto relative-container">
14
- <div class="absolute-container fill-parent">
15
- <div class="flex-row fill-parent">
16
- <div class="failover-order-master relative-container">
17
- <div class="absolute-container fill-parent">
18
- <div class="flex-column fill-parent">
19
- <common-adapter-manager-ui-second-title
20
- :is-add-modal="props.isAddModal"
21
- />
22
- <div class="flex-grow-auto relative-container">
23
- <div class="absolute-container fill-parent">
24
- <div class="fill-parent">
25
- <div
26
- class="fill-parent no-column-header assigned-adapters-datagrid failover-order"
27
- >
28
- <div class="k-grid k-widget" style="height: 100%">
29
- <common-adapter-manager-ui-actions-bar
30
- :full-mode="props.fullMode"
31
- :is-add-modal="props.isAddModal"
32
- :selected-is-header="props.selectedIsHeader"
33
- :is-disabled-move-up="props.isDisabledMoveUp"
34
- :is-disabled-move-down="props.isDisabledMoveDown"
35
- :is-disabled-remove="props.isDisabledRemove"
36
- @show-add-adapter-modal="onShowAddAdapterModal"
37
- @remove-adapter="onRemove"
38
- @move-up-adapter="onMoveUp"
39
- @move-down-adapter="onMoveDown"
40
- />
41
- <common-adapter-manager-ui-table
42
- :is-add-modal="props.isAddModal"
43
- :selected-add-adapter-id="
44
- props.selectedAddAdapterId
45
- "
46
- :selected-adapter-id="props.selectedAdapterId"
47
- :removed-adapters="props.removedAdapters"
48
- :existing-adapters-for-adding="
49
- props.existingAdaptersForAdding
50
- "
51
- :adapter-status="props.adapterStatus"
52
- :is-active-header="props.isActiveHeader"
53
- :is-standby-header="props.isStandbyHeader"
54
- :is-unused-header="props.isUnusedHeader"
55
- @select-add-adapter="onSelectAddAdapter"
56
- @select-adapter="onSelectAdapter"
57
- @click-empty-space="onClickEmptySpace"
58
- />
59
- </div>
60
- </div>
61
- </div>
62
- </div>
63
- </div>
64
- </div>
65
- </div>
66
- </div>
67
- <div class="failover-order-details relative-container">
68
- <div class="absolute-container fill-parent">
69
- <div
70
- :class="[
71
- 'fill-parent',
72
- {
73
- 'full-width-adapter-info': props.fullMode,
74
- },
75
- ]"
76
- >
77
- <div v-if="props.hasSelectedAdapter">
78
- <common-diagram-main-modals-view-settings-info
79
- modal-name="network-settings-modal"
80
- :show="true"
81
- :view-name="localization.common.onPhysicalNetworkAdapter"
82
- :modal-tabs="props.adapterViewSettingsModalTabs"
83
- :view-settings-fields="props.viewSettingsFields"
84
- />
85
- </div>
86
- <common-adapter-manager-ui-no-selected-adapter
87
- v-else
88
- :is-add-modal="props.isAddModal"
89
- />
90
- </div>
91
- </div>
92
- </div>
93
- </div>
94
- </div>
95
- </div>
96
- </div>
97
- </template>
98
-
99
- <script setup lang="ts">
100
- import type {
101
- UI_I_Localization,
102
- UI_I_ItemsWithTotalCounts,
103
- } from '~/lib/models/interfaces'
104
- import type {
105
- UI_I_Adapter,
106
- UI_I_AdapterStatus,
107
- UI_I_SwitchAdapterItem,
108
- UI_I_ViewSettingsFields,
109
- UI_I_NavigationItem,
110
- } from '~/components/common/diagramMain/lib/models/interfaces'
111
-
112
- const props = defineProps<{
113
- isActive: boolean
114
- fullMode: boolean
115
- isAddModal: boolean
116
- isDarkMode: boolean
117
- adapters: UI_I_ItemsWithTotalCounts<UI_I_SwitchAdapterItem>
118
- adapterStatus: UI_I_AdapterStatus
119
- existingAdaptersForAdding: (UI_I_Adapter | UI_I_SwitchAdapterItem)[]
120
- selectedAddAdapterId: string
121
- selectedIsHeader: boolean
122
- isDisabledMoveUp: boolean
123
- isDisabledMoveDown: boolean
124
- isDisabledRemove: boolean
125
- selectedAdapterId: string
126
- viewSettingsFields: UI_I_ViewSettingsFields[]
127
- isActiveHeader: boolean
128
- isUnusedHeader: boolean
129
- isStandbyHeader: boolean
130
- hasSelectedAdapter: boolean
131
- removedAdapters: string[]
132
- adapterViewSettingsModalTabs: UI_I_NavigationItem
133
- }>()
134
-
135
- const emits = defineEmits<{
136
- (event: 'get-free-adapters', cb: () => void): void
137
- (event: 'select-add-adapter', value: string): void
138
- (event: 'remove-adapter'): void
139
- (event: 'select-adapter', value: string): void
140
- (event: 'move-down'): void
141
- (event: 'move-up'): void
142
- (event: 'click-empty-space', value: Event): void
143
- }>()
144
-
145
- const localization = computed<UI_I_Localization>(() => useLocal())
146
-
147
- const onSelectAdapter = (adapterId: string): void => {
148
- emits('select-adapter', adapterId)
149
- }
150
-
151
- const onSelectAddAdapter = (adapterId: string): void => {
152
- emits('select-add-adapter', adapterId)
153
- }
154
-
155
- const onMoveDown = () => {
156
- emits('move-down')
157
- }
158
-
159
- const onMoveUp = () => {
160
- emits('move-up')
161
- }
162
-
163
- const onRemove = () => {
164
- emits('remove-adapter')
165
- }
166
-
167
- const onClickEmptySpace = (event: Event): void => {
168
- emits('click-empty-space', event)
169
- }
170
-
171
- const onShowAddAdapterModal = (): void => {
172
- emits('get-free-adapters')
173
- }
174
- </script>
175
-
176
- <style scoped lang="scss">
177
- div.edit-pg-failover-order-with-details {
178
- flex: 1 1 auto;
179
- flex-direction: column;
180
- display: flex;
181
- }
182
- .flex-grow-auto {
183
- flex: 1 0 auto;
184
- }
185
- .relative-container {
186
- position: relative;
187
- }
188
- .fill-parent {
189
- display: initial;
190
- overflow: visible;
191
- height: 100%;
192
- width: 100%;
193
- }
194
- .absolute-container {
195
- position: absolute;
196
- }
197
- .flex-row {
198
- display: flex;
199
- flex-direction: row;
200
- }
201
- .failover-order-master {
202
- flex: 0 0 200px;
203
- margin-right: 10px;
204
- margin-bottom: 2px;
205
- }
206
- .absolute-container {
207
- position: absolute;
208
- }
209
- .full-width-adapter-info {
210
- display: block;
211
- }
212
- .flex-column {
213
- display: flex;
214
- }
215
- .flex-column {
216
- flex-direction: column;
217
- }
218
-
219
- .k-widget {
220
- height: 100%;
221
- box-sizing: border-box;
222
- border: none;
223
- box-shadow: none;
224
- }
225
-
226
- .k-grid .k-grid-header {
227
- position: relative;
228
- border-radius: 3px 3px 0 0;
229
- overflow: hidden;
230
- background-color: #fafafa;
231
- padding-right: 18px;
232
- border: none;
233
-
234
- .k-grid-header-wrap {
235
- display: none;
236
- border-right: 0;
237
- border-color: #ccc;
238
- }
239
- }
240
- .k-grid-header table {
241
- table-layout: fixed;
242
- }
243
- .k-grid-header-wrap > table {
244
- margin-bottom: -1px;
245
-
246
- col {
247
- width: 150px;
248
- }
249
- }
250
- .k-grid table {
251
- width: 100%;
252
- margin: 0;
253
- max-width: none;
254
- border-collapse: separate;
255
- border-spacing: 0;
256
- empty-cells: show;
257
- border-width: 0;
258
- outline: 0;
259
- }
260
-
261
- .k-grid-content {
262
- width: auto;
263
- overflow-y: scroll;
264
- padding-right: 3px;
265
- height: 200px;
266
- }
267
- .full-height {
268
- .k-grid-content {
269
- width: auto;
270
- overflow-y: scroll;
271
- padding-right: 3px;
272
- height: 273px;
273
- }
274
- }
275
- .add-adapter-view {
276
- .k-grid-content {
277
- width: auto;
278
- overflow-y: scroll;
279
- padding-right: 3px;
280
- height: 430px;
281
- }
282
- }
283
- .k-selectable {
284
- height: auto;
285
-
286
- col {
287
- width: 150px;
288
- }
289
- }
290
-
291
- .k-grid.k-widget .k-grid-content,
292
- .k-grid.k-widget .k-grid-content-locked {
293
- border-left: 1px solid #ddd;
294
- border-right: 1px solid #ddd;
295
- }
296
- .k-grid-content {
297
- background: #fff;
298
- }
299
- .no-column-header .k-grid-content {
300
- border-top: 1px solid #ddd;
301
- border-bottom: 1px solid #ddd;
302
- }
303
- .k-grid-content {
304
- min-height: 35px;
305
- }
306
- .k-grid-content,
307
- .k-grid-content-locked,
308
- .k-pager-wrap {
309
- white-space: normal;
310
- }
311
- .k-grid-content {
312
- position: relative;
313
- zoom: 1;
314
- }
315
- .k-widget {
316
- line-height: normal;
317
- }
318
- .k-grid-content table,
319
- .k-grid-content-locked > table,
320
- .k-grid-footer table,
321
- .k-grid-header table {
322
- table-layout: fixed;
323
- }
324
-
325
- .k-grid-content table,
326
- .k-grid-content-locked > table,
327
- .k-grid-footer table,
328
- .k-grid-header table {
329
- table-layout: fixed;
330
- }
331
- .k-grid table {
332
- width: 100%;
333
- margin: 0;
334
- max-width: none;
335
- border-collapse: separate;
336
- border-spacing: 0;
337
- empty-cells: show;
338
- border-width: 0;
339
- outline: 0;
340
- }
341
-
342
- .assigned-pnic-sections {
343
- font-weight: 700;
344
- margin: 0 -9px;
345
- }
346
-
347
- .k-scrollbar-vertical {
348
- top: 0;
349
- right: 0;
350
- width: 17px;
351
- height: 100%;
352
- overflow-x: hidden;
353
- }
354
-
355
- .k-scrollbar {
356
- position: absolute;
357
- overflow: scroll;
358
- }
359
-
360
- .absolute-container {
361
- position: initial;
362
- }
363
-
364
- .failover-order-details {
365
- flex: 1 0 auto;
366
- border-left: 1px solid #ddd;
367
-
368
- & > div {
369
- padding-left: 10px;
370
- }
371
-
372
- .absolute-container {
373
- position: absolute;
374
- }
375
- }
376
- .compact {
377
- padding-top: 0;
378
- }
379
- .failover-order-with-details-title {
380
- margin: 0 !important;
381
- padding-top: 0 !important;
382
- }
383
- .element-disabled {
384
- pointer-events: none;
385
- cursor: not-allowed;
386
- opacity: 0.6;
387
- }
388
- .add-adapter-view {
389
- :deep(.table-fixed-full-height) {
390
- height: 430px;
391
- }
392
- :deep(.table-fixed-height) {
393
- height: 430px;
394
- max-height: 415px;
395
- }
396
- }
397
-
398
- div.edit-pg-failover-order-with-details.is-dark {
399
- .property-label-group {
400
- color: var(--main-color-mode2);
401
- }
402
- .flex-property-label-group {
403
- color: var(--main-color-mode2);
404
- }
405
- .flex-property-value-group {
406
- select {
407
- color: #fff;
408
- }
409
- }
410
- .failover-order-master {
411
- .secondary-title label {
412
- color: #fff;
413
- }
414
- }
415
- .k-grid-content {
416
- background-color: var(--modal-bg-color);
417
- }
418
- .vui-action-bar {
419
- background-color: var(--pannel-bg-color);
420
- color: var(--title-color);
421
-
422
- .action-link-container:not(.disabled) {
423
- &:hover {
424
- background-color: #29414e;
425
- border: 1px solid #c7e9ff;
426
- }
427
- }
428
-
429
- svg {
430
- fill: #fff;
431
- }
432
- }
433
-
434
- .k-grid.k-widget .k-grid-content {
435
- border-left: 1px solid #485764;
436
- border-right: 1px solid #485764;
437
- border-top: 1px solid #ddd;
438
- border-bottom: 1px solid #ddd;
439
-
440
- tbody tr {
441
- background-color: var(--modal-bg-color);
442
-
443
- td {
444
- border-bottom: 1px solid #666666;
445
- border-color: #666666;
446
- }
447
-
448
- &:hover {
449
- background-color: #324f61;
450
- color: var(--title-color);
451
-
452
- td {
453
- border-bottom: 1px solid #ffffff;
454
- }
455
- }
456
-
457
- &.k-state-selected {
458
- background-color: #d8e3e9;
459
- box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset;
460
-
461
- td span {
462
- color: #000;
463
- }
464
- }
465
- }
466
- }
467
-
468
- .failover-order-details {
469
- &.relative-container .absolute-container {
470
- background-color: var(--pannel-bg-color);
471
- color: var(--main-color-mode2);
472
-
473
- &:has(.no-items-selected-container) {
474
- background-color: transparent;
475
- }
476
- }
477
-
478
- td span {
479
- color: var(--main-color-mode2);
480
- }
481
- button span {
482
- color: var(--main-color-mode2);
483
-
484
- &:hover:not(.disabled) {
485
- background-color: transparent;
486
- border: 1px solid transparent;
487
- }
488
- }
489
- button.active span {
490
- color: #fff;
491
- }
492
- }
493
-
494
- .select-adapter-info span {
495
- color: var(--main-color-mode2);
496
- }
497
- }
498
- </style>
1
+ <template>
2
+ <div
3
+ :class="[
4
+ 'edit-pg-failover-order-with-details',
5
+ {
6
+ 'element-disabled': !props.isActive,
7
+ 'full-height': props.fullMode,
8
+ 'add-adapter-view': props.isAddModal,
9
+ 'is-dark': props.isDarkMode,
10
+ },
11
+ ]"
12
+ >
13
+ <div class="failover-order-with-details flex-grow-auto relative-container">
14
+ <div class="absolute-container fill-parent">
15
+ <div class="flex-row fill-parent">
16
+ <div class="failover-order-master relative-container">
17
+ <div class="absolute-container fill-parent">
18
+ <div class="flex-column fill-parent">
19
+ <common-adapter-manager-ui-second-title
20
+ :is-add-modal="props.isAddModal"
21
+ />
22
+ <div class="flex-grow-auto relative-container">
23
+ <div class="absolute-container fill-parent">
24
+ <div class="fill-parent">
25
+ <div
26
+ class="fill-parent no-column-header assigned-adapters-datagrid failover-order"
27
+ >
28
+ <div class="k-grid k-widget" style="height: 100%">
29
+ <common-adapter-manager-ui-actions-bar
30
+ :full-mode="props.fullMode"
31
+ :is-add-modal="props.isAddModal"
32
+ :selected-is-header="props.selectedIsHeader"
33
+ :is-disabled-move-up="props.isDisabledMoveUp"
34
+ :is-disabled-move-down="props.isDisabledMoveDown"
35
+ :is-disabled-remove="props.isDisabledRemove"
36
+ @show-add-adapter-modal="onShowAddAdapterModal"
37
+ @remove-adapter="onRemove"
38
+ @move-up-adapter="onMoveUp"
39
+ @move-down-adapter="onMoveDown"
40
+ />
41
+ <common-adapter-manager-ui-table
42
+ :is-add-modal="props.isAddModal"
43
+ :selected-add-adapter-id="
44
+ props.selectedAddAdapterId
45
+ "
46
+ :selected-adapter-id="props.selectedAdapterId"
47
+ :removed-adapters="props.removedAdapters"
48
+ :existing-adapters-for-adding="
49
+ props.existingAdaptersForAdding
50
+ "
51
+ :adapter-status="props.adapterStatus"
52
+ :is-active-header="props.isActiveHeader"
53
+ :is-standby-header="props.isStandbyHeader"
54
+ :is-unused-header="props.isUnusedHeader"
55
+ @select-add-adapter="onSelectAddAdapter"
56
+ @select-adapter="onSelectAdapter"
57
+ @click-empty-space="onClickEmptySpace"
58
+ />
59
+ </div>
60
+ </div>
61
+ </div>
62
+ </div>
63
+ </div>
64
+ </div>
65
+ </div>
66
+ </div>
67
+ <div class="failover-order-details relative-container">
68
+ <div class="absolute-container fill-parent">
69
+ <div
70
+ :class="[
71
+ 'fill-parent',
72
+ {
73
+ 'full-width-adapter-info': props.fullMode,
74
+ },
75
+ ]"
76
+ >
77
+ <div v-if="props.hasSelectedAdapter">
78
+ <common-diagram-main-modals-view-settings-info
79
+ modal-name="network-settings-modal"
80
+ :show="true"
81
+ :view-name="localization.common.onPhysicalNetworkAdapter"
82
+ :modal-tabs="props.adapterViewSettingsModalTabs"
83
+ :view-settings-fields="props.viewSettingsFields"
84
+ />
85
+ </div>
86
+ <common-adapter-manager-ui-no-selected-adapter
87
+ v-else
88
+ :is-add-modal="props.isAddModal"
89
+ />
90
+ </div>
91
+ </div>
92
+ </div>
93
+ </div>
94
+ </div>
95
+ </div>
96
+ </div>
97
+ </template>
98
+
99
+ <script setup lang="ts">
100
+ import type {
101
+ UI_I_Localization,
102
+ UI_I_ItemsWithTotalCounts,
103
+ } from '~/lib/models/interfaces'
104
+ import type {
105
+ UI_I_Adapter,
106
+ UI_I_AdapterStatus,
107
+ UI_I_SwitchAdapterItem,
108
+ UI_I_ViewSettingsFields,
109
+ UI_I_NavigationItem,
110
+ } from '~/components/common/diagramMain/lib/models/interfaces'
111
+
112
+ const props = defineProps<{
113
+ isActive: boolean
114
+ fullMode: boolean
115
+ isAddModal: boolean
116
+ isDarkMode: boolean
117
+ adapters: UI_I_ItemsWithTotalCounts<UI_I_SwitchAdapterItem>
118
+ adapterStatus: UI_I_AdapterStatus
119
+ existingAdaptersForAdding: (UI_I_Adapter | UI_I_SwitchAdapterItem)[]
120
+ selectedAddAdapterId: string
121
+ selectedIsHeader: boolean
122
+ isDisabledMoveUp: boolean
123
+ isDisabledMoveDown: boolean
124
+ isDisabledRemove: boolean
125
+ selectedAdapterId: string
126
+ viewSettingsFields: UI_I_ViewSettingsFields[]
127
+ isActiveHeader: boolean
128
+ isUnusedHeader: boolean
129
+ isStandbyHeader: boolean
130
+ hasSelectedAdapter: boolean
131
+ removedAdapters: string[]
132
+ adapterViewSettingsModalTabs: UI_I_NavigationItem
133
+ }>()
134
+
135
+ const emits = defineEmits<{
136
+ (event: 'get-free-adapters', cb: () => void): void
137
+ (event: 'select-add-adapter', value: string): void
138
+ (event: 'remove-adapter'): void
139
+ (event: 'select-adapter', value: string): void
140
+ (event: 'move-down'): void
141
+ (event: 'move-up'): void
142
+ (event: 'click-empty-space', value: Event): void
143
+ }>()
144
+
145
+ const localization = computed<UI_I_Localization>(() => useLocal())
146
+
147
+ const onSelectAdapter = (adapterId: string): void => {
148
+ emits('select-adapter', adapterId)
149
+ }
150
+
151
+ const onSelectAddAdapter = (adapterId: string): void => {
152
+ emits('select-add-adapter', adapterId)
153
+ }
154
+
155
+ const onMoveDown = () => {
156
+ emits('move-down')
157
+ }
158
+
159
+ const onMoveUp = () => {
160
+ emits('move-up')
161
+ }
162
+
163
+ const onRemove = () => {
164
+ emits('remove-adapter')
165
+ }
166
+
167
+ const onClickEmptySpace = (event: Event): void => {
168
+ emits('click-empty-space', event)
169
+ }
170
+
171
+ const onShowAddAdapterModal = (): void => {
172
+ emits('get-free-adapters')
173
+ }
174
+ </script>
175
+
176
+ <style scoped lang="scss">
177
+ div.edit-pg-failover-order-with-details {
178
+ flex: 1 1 auto;
179
+ flex-direction: column;
180
+ display: flex;
181
+ }
182
+ .flex-grow-auto {
183
+ flex: 1 0 auto;
184
+ }
185
+ .relative-container {
186
+ position: relative;
187
+ }
188
+ .fill-parent {
189
+ display: initial;
190
+ overflow: visible;
191
+ height: 100%;
192
+ width: 100%;
193
+ }
194
+ .absolute-container {
195
+ position: absolute;
196
+ }
197
+ .flex-row {
198
+ display: flex;
199
+ flex-direction: row;
200
+ }
201
+ .failover-order-master {
202
+ flex: 0 0 200px;
203
+ margin-right: 10px;
204
+ margin-bottom: 2px;
205
+ }
206
+ .absolute-container {
207
+ position: absolute;
208
+ }
209
+ .full-width-adapter-info {
210
+ display: block;
211
+ }
212
+ .flex-column {
213
+ display: flex;
214
+ }
215
+ .flex-column {
216
+ flex-direction: column;
217
+ }
218
+
219
+ .k-widget {
220
+ height: 100%;
221
+ box-sizing: border-box;
222
+ border: none;
223
+ box-shadow: none;
224
+ }
225
+
226
+ .k-grid .k-grid-header {
227
+ position: relative;
228
+ border-radius: 3px 3px 0 0;
229
+ overflow: hidden;
230
+ background-color: #fafafa;
231
+ padding-right: 18px;
232
+ border: none;
233
+
234
+ .k-grid-header-wrap {
235
+ display: none;
236
+ border-right: 0;
237
+ border-color: #ccc;
238
+ }
239
+ }
240
+ .k-grid-header table {
241
+ table-layout: fixed;
242
+ }
243
+ .k-grid-header-wrap > table {
244
+ margin-bottom: -1px;
245
+
246
+ col {
247
+ width: 150px;
248
+ }
249
+ }
250
+ .k-grid table {
251
+ width: 100%;
252
+ margin: 0;
253
+ max-width: none;
254
+ border-collapse: separate;
255
+ border-spacing: 0;
256
+ empty-cells: show;
257
+ border-width: 0;
258
+ outline: 0;
259
+ }
260
+
261
+ .k-grid-content {
262
+ width: auto;
263
+ overflow-y: scroll;
264
+ padding-right: 3px;
265
+ height: 200px;
266
+ }
267
+ .full-height {
268
+ .k-grid-content {
269
+ width: auto;
270
+ overflow-y: scroll;
271
+ padding-right: 3px;
272
+ height: 273px;
273
+ }
274
+ }
275
+ .add-adapter-view {
276
+ .k-grid-content {
277
+ width: auto;
278
+ overflow-y: scroll;
279
+ padding-right: 3px;
280
+ height: 430px;
281
+ }
282
+ }
283
+ .k-selectable {
284
+ height: auto;
285
+
286
+ col {
287
+ width: 150px;
288
+ }
289
+ }
290
+
291
+ .k-grid.k-widget .k-grid-content,
292
+ .k-grid.k-widget .k-grid-content-locked {
293
+ border-left: 1px solid #ddd;
294
+ border-right: 1px solid #ddd;
295
+ }
296
+ .k-grid-content {
297
+ background: #fff;
298
+ }
299
+ .no-column-header .k-grid-content {
300
+ border-top: 1px solid #ddd;
301
+ border-bottom: 1px solid #ddd;
302
+ }
303
+ .k-grid-content {
304
+ min-height: 35px;
305
+ }
306
+ .k-grid-content,
307
+ .k-grid-content-locked,
308
+ .k-pager-wrap {
309
+ white-space: normal;
310
+ }
311
+ .k-grid-content {
312
+ position: relative;
313
+ zoom: 1;
314
+ }
315
+ .k-widget {
316
+ line-height: normal;
317
+ }
318
+ .k-grid-content table,
319
+ .k-grid-content-locked > table,
320
+ .k-grid-footer table,
321
+ .k-grid-header table {
322
+ table-layout: fixed;
323
+ }
324
+
325
+ .k-grid-content table,
326
+ .k-grid-content-locked > table,
327
+ .k-grid-footer table,
328
+ .k-grid-header table {
329
+ table-layout: fixed;
330
+ }
331
+ .k-grid table {
332
+ width: 100%;
333
+ margin: 0;
334
+ max-width: none;
335
+ border-collapse: separate;
336
+ border-spacing: 0;
337
+ empty-cells: show;
338
+ border-width: 0;
339
+ outline: 0;
340
+ }
341
+
342
+ .assigned-pnic-sections {
343
+ font-weight: 700;
344
+ margin: 0 -9px;
345
+ }
346
+
347
+ .k-scrollbar-vertical {
348
+ top: 0;
349
+ right: 0;
350
+ width: 17px;
351
+ height: 100%;
352
+ overflow-x: hidden;
353
+ }
354
+
355
+ .k-scrollbar {
356
+ position: absolute;
357
+ overflow: scroll;
358
+ }
359
+
360
+ .absolute-container {
361
+ position: initial;
362
+ }
363
+
364
+ .failover-order-details {
365
+ flex: 1 0 auto;
366
+ border-left: 1px solid #ddd;
367
+
368
+ & > div {
369
+ padding-left: 10px;
370
+ }
371
+
372
+ .absolute-container {
373
+ position: absolute;
374
+ }
375
+ }
376
+ .compact {
377
+ padding-top: 0;
378
+ }
379
+ .failover-order-with-details-title {
380
+ margin: 0 !important;
381
+ padding-top: 0 !important;
382
+ }
383
+ .element-disabled {
384
+ pointer-events: none;
385
+ cursor: not-allowed;
386
+ opacity: 0.6;
387
+ }
388
+ .add-adapter-view {
389
+ :deep(.table-fixed-full-height) {
390
+ height: 430px;
391
+ }
392
+ :deep(.table-fixed-height) {
393
+ height: 430px;
394
+ max-height: 415px;
395
+ }
396
+ }
397
+
398
+ div.edit-pg-failover-order-with-details.is-dark {
399
+ .property-label-group {
400
+ color: var(--main-color-mode2);
401
+ }
402
+ .flex-property-label-group {
403
+ color: var(--main-color-mode2);
404
+ }
405
+ .flex-property-value-group {
406
+ select {
407
+ color: #fff;
408
+ }
409
+ }
410
+ .failover-order-master {
411
+ .secondary-title label {
412
+ color: #fff;
413
+ }
414
+ }
415
+ .k-grid-content {
416
+ background-color: var(--modal-bg-color);
417
+ }
418
+ .vui-action-bar {
419
+ background-color: var(--pannel-bg-color);
420
+ color: var(--title-color);
421
+
422
+ .action-link-container:not(.disabled) {
423
+ &:hover {
424
+ background-color: #29414e;
425
+ border: 1px solid #c7e9ff;
426
+ }
427
+ }
428
+
429
+ svg {
430
+ fill: #fff;
431
+ }
432
+ }
433
+
434
+ .k-grid.k-widget .k-grid-content {
435
+ border-left: 1px solid #485764;
436
+ border-right: 1px solid #485764;
437
+ border-top: 1px solid #ddd;
438
+ border-bottom: 1px solid #ddd;
439
+
440
+ tbody tr {
441
+ background-color: var(--modal-bg-color);
442
+
443
+ td {
444
+ border-bottom: 1px solid #666666;
445
+ border-color: #666666;
446
+ }
447
+
448
+ &:hover {
449
+ background-color: #324f61;
450
+ color: var(--title-color);
451
+
452
+ td {
453
+ border-bottom: 1px solid #ffffff;
454
+ }
455
+ }
456
+
457
+ &.k-state-selected {
458
+ background-color: #d8e3e9;
459
+ box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset;
460
+
461
+ td span {
462
+ color: #000;
463
+ }
464
+ }
465
+ }
466
+ }
467
+
468
+ .failover-order-details {
469
+ &.relative-container .absolute-container {
470
+ background-color: var(--pannel-bg-color);
471
+ color: var(--main-color-mode2);
472
+
473
+ &:has(.no-items-selected-container) {
474
+ background-color: transparent;
475
+ }
476
+ }
477
+
478
+ td span {
479
+ color: var(--main-color-mode2);
480
+ }
481
+ button span {
482
+ color: var(--main-color-mode2);
483
+
484
+ &:hover:not(.disabled) {
485
+ background-color: transparent;
486
+ border: 1px solid transparent;
487
+ }
488
+ }
489
+ button.active span {
490
+ color: #fff;
491
+ }
492
+ }
493
+
494
+ .select-adapter-info span {
495
+ color: var(--main-color-mode2);
496
+ }
497
+ }
498
+ </style>