bfg-common 1.6.102 → 1.6.104

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 (125) hide show
  1. package/components/common/adapterManager/AdapterManager.vue +473 -473
  2. package/components/common/adapterManager/AdapterManagerOld.vue +498 -498
  3. package/components/common/adapterManager/addAdapterModal/AddAdapterModal.vue +70 -70
  4. package/components/common/adapterManager/addAdapterModal/AddAdapterModalNew.vue +110 -110
  5. package/components/common/adapterManager/addAdapterModal/AddAdapterModalOld.vue +531 -531
  6. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModal.vue +32 -32
  7. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModalNew.vue +37 -37
  8. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModalOld.vue +73 -73
  9. package/components/common/adapterManager/lib/config/index.ts +19 -19
  10. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModal.vue +31 -31
  11. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModalNew.vue +34 -34
  12. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModalOld.vue +57 -57
  13. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModal.vue +31 -31
  14. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModalNew.vue +34 -34
  15. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModalOld.vue +57 -57
  16. package/components/common/adapterManager/ui/actions/AddAdapterButton.vue +34 -34
  17. package/components/common/adapterManager/ui/actions/RemoveAdapterButton.vue +41 -41
  18. package/components/common/adapterManager/ui/actions/VerticalSeparator.vue +10 -10
  19. package/components/common/adapterManager/ui/actions/bar/BarOld.vue +95 -95
  20. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButton.vue +28 -28
  21. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButtonNew.vue +76 -76
  22. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButtonOld.vue +33 -33
  23. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButton.vue +28 -28
  24. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButtonNew.vue +77 -77
  25. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButtonOld.vue +33 -33
  26. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapter.vue +24 -24
  27. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapterNew.vue +18 -18
  28. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapterOld.vue +38 -38
  29. package/components/common/adapterManager/ui/secondTitle/SecondTitle.vue +31 -31
  30. package/components/common/adapterManager/ui/secondTitle/SecondTitleNew.vue +51 -51
  31. package/components/common/adapterManager/ui/secondTitle/SecondTitleOld.vue +35 -35
  32. package/components/common/adapterManager/ui/table/Table.vue +88 -88
  33. package/components/common/adapterManager/ui/table/TableNew.vue +137 -137
  34. package/components/common/adapterManager/ui/table/TableOld.vue +141 -141
  35. package/components/common/adapterManager/ui/table/adapters/Adapters.vue +44 -44
  36. package/components/common/adapterManager/ui/table/adapters/AdaptersNew.vue +187 -187
  37. package/components/common/adapterManager/ui/table/adapters/AdaptersOld.vue +87 -87
  38. package/components/common/adapterManager/ui/table/header/Header.vue +57 -57
  39. package/components/common/adapterManager/ui/table/header/HeaderNew.vue +81 -81
  40. package/components/common/adapterManager/ui/table/header/HeaderOld.vue +79 -79
  41. package/components/common/adapterManager/ui/table/lib/models/types.ts +1 -1
  42. package/components/common/configure/physicalAdapters/PhysicalAdaptersNew.vue +200 -200
  43. package/components/common/configure/physicalAdapters/PhysicalAdaptersOld.vue +307 -307
  44. package/components/common/configure/vmkernelAdapters/VmkernelAdapters.vue +216 -0
  45. package/components/common/configure/vmkernelAdapters/VmkernelAdaptersNew.vue +335 -0
  46. package/components/common/configure/vmkernelAdapters/VmkernelAdaptersOld.vue +258 -0
  47. package/components/common/configure/vmkernelAdapters/tableView/TableView.vue +209 -0
  48. package/components/common/configure/vmkernelAdapters/tableView/TableViewNew.vue +451 -0
  49. package/components/common/configure/vmkernelAdapters/tableView/TableViewOld.vue +396 -0
  50. package/components/common/configure/vmkernelAdapters/tableView/lib/config/settings.ts +382 -0
  51. package/components/common/configure/vmkernelAdapters/tableView/lib/config/tableKeys.ts +25 -0
  52. package/components/common/configure/vmkernelAdapters/tableView/lib/config/vmKernelAdaptersTableConfig.ts +184 -0
  53. package/components/common/configure/vmkernelAdapters/tableView/lib/config/vmKernelAdaptersTableConfigNew.ts +244 -0
  54. package/components/common/configure/vmkernelAdapters/tableView/lib/models/interfaces.ts +9 -0
  55. package/components/common/configure/vmkernelAdapters/tableView/lib/models/types.ts +18 -0
  56. package/components/common/configure/vmkernelAdapters/tableView/mappers/mappers.ts +27 -0
  57. package/components/common/diagramMain/adapter/Adapter.vue +123 -123
  58. package/components/common/diagramMain/adapter/AdapterItem.vue +438 -438
  59. package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
  60. package/components/common/diagramMain/adapter/Contents.vue +212 -212
  61. package/components/common/diagramMain/adapter/Lines.vue +81 -81
  62. package/components/common/diagramMain/adapter/block/Block.vue +27 -27
  63. package/components/common/diagramMain/adapter/block/BlockNew.vue +58 -58
  64. package/components/common/diagramMain/adapter/block/BlockOld.vue +50 -50
  65. package/components/common/diagramMain/adapter/secondBlock/SecondBlock.vue +27 -27
  66. package/components/common/diagramMain/adapter/secondBlock/SecondBlockNew.vue +60 -60
  67. package/components/common/diagramMain/adapter/secondBlock/SecondBlockOld.vue +51 -51
  68. package/components/common/diagramMain/highlights/Highlights.vue +151 -151
  69. package/components/common/diagramMain/highlights/HighlightsNew.vue +124 -124
  70. package/components/common/diagramMain/highlights/HighlightsOld.vue +107 -107
  71. package/components/common/diagramMain/lib/config/index.ts +81 -81
  72. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  73. package/components/common/diagramMain/lib/config/positions.ts +194 -194
  74. package/components/common/diagramMain/lib/models/enums.ts +44 -44
  75. package/components/common/diagramMain/lib/models/interfaces.ts +10 -9
  76. package/components/common/diagramMain/lib/models/types.ts +21 -21
  77. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  78. package/components/common/diagramMain/modals/editSettings/lib/models/interfaces.ts +2 -2
  79. package/components/common/diagramMain/modals/editSettings/modal/EditSettingsModal.vue +1 -1
  80. package/components/common/diagramMain/modals/editSettings/modal/EditSettingsModalNew.vue +1 -1
  81. package/components/common/diagramMain/modals/editSettings/tabs/port/portProperties/PortPropertiesOld.vue +0 -1
  82. package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
  83. package/components/common/diagramMain/modals/lib/config/switchModal.ts +245 -245
  84. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  85. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +88 -88
  86. package/components/common/diagramMain/modals/migrateVmkernelAdapter/MigrateVmkernelAdapter.vue +541 -541
  87. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
  88. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +170 -170
  89. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
  90. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/VmkernelAdapterReadyComplete.vue +49 -49
  91. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +19 -19
  92. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
  93. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
  94. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  95. package/components/common/diagramMain/modals/remove/RemoveModal.vue +82 -82
  96. package/components/common/diagramMain/modals/remove/RemoveModalNew.vue +1 -1
  97. package/components/common/diagramMain/modals/remove/RemoveModalOld.vue +241 -241
  98. package/components/common/diagramMain/modals/viewSettings/info/Info.vue +4 -0
  99. package/components/common/diagramMain/modals/viewSettings/info/InfoNew.vue +9 -18
  100. package/components/common/diagramMain/modals/viewSettings/info/InfoOld.vue +10 -20
  101. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettings.vue +45 -45
  102. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsNew.vue +323 -323
  103. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsOld.vue +203 -203
  104. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModal.vue +60 -60
  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/wizards/network/add/Add.vue +1 -0
  125. package/package.json +1 -1
@@ -1,473 +1,473 @@
1
- <template>
2
- <common-adapter-manager-new
3
- v-if="isNewView"
4
- :is-active="props.isActive"
5
- :full-mode="props.fullMode"
6
- :core-adapters="props.coreAdapters"
7
- :is-add-modal="props.isAddModal"
8
- :is-dark-mode="props.isDarkMode"
9
- :adapters="props.adapters"
10
- :adapter-status="adapterStatusLocal"
11
- :existing-adapters-for-adding="props.existingAdaptersForAdding"
12
- :selected-is-header="selectedIsHeader"
13
- :is-disabled-move-up="isDisabledMoveUp"
14
- :is-disabled-move-down="isDisabledMoveDown"
15
- :is-disabled-remove="isDisabledRemove"
16
- :selected-adapter-id="selectedAdapterId"
17
- :view-settings-fields="viewSettingsFields"
18
- :selected-add-adapter-id="selectedAddAdapterId"
19
- :is-active-header="isActiveHeader"
20
- :is-unused-header="isUnusedHeader"
21
- :is-standby-header="isStandbyHeader"
22
- :has-selected-adapter="hasSelectedAdapter"
23
- :removed-adapters="removedAdapters"
24
- :adapter-view-settings-modal-tabs="adapterViewSettingsModalTabs"
25
- @get-free-adapters="onShowAddAdapterModal"
26
- @select-add-adapter="onSelectAddAdapter"
27
- @remove-adapter="onRemove"
28
- @select-adapter="onSelectAdapter"
29
- @move-down="onMoveDown"
30
- @move-up="onMoveUp"
31
- @click-empty-space="onClickEmptySpace"
32
- />
33
- <common-adapter-manager-old
34
- v-else
35
- :is-active="props.isActive"
36
- :full-mode="props.fullMode"
37
- :is-add-modal="props.isAddModal"
38
- :is-dark-mode="props.isDarkMode"
39
- :adapters="props.adapters"
40
- :adapter-status="adapterStatusLocal"
41
- :existing-adapters-for-adding="props.existingAdaptersForAdding"
42
- :selected-is-header="selectedIsHeader"
43
- :is-disabled-move-up="isDisabledMoveUp"
44
- :is-disabled-move-down="isDisabledMoveDown"
45
- :is-disabled-remove="isDisabledRemove"
46
- :selected-adapter-id="selectedAdapterId"
47
- :view-settings-fields="viewSettingsFields"
48
- :selected-add-adapter-id="selectedAddAdapterId"
49
- :is-active-header="isActiveHeader"
50
- :is-unused-header="isUnusedHeader"
51
- :is-standby-header="isStandbyHeader"
52
- :has-selected-adapter="hasSelectedAdapter"
53
- :removed-adapters="removedAdapters"
54
- :adapter-view-settings-modal-tabs="adapterViewSettingsModalTabs"
55
- @get-free-adapters="onShowAddAdapterModal"
56
- @select-add-adapter="onSelectAddAdapter"
57
- @remove-adapter="onRemove"
58
- @select-adapter="onSelectAdapter"
59
- @move-down="onMoveDown"
60
- @move-up="onMoveUp"
61
- @click-empty-space="onClickEmptySpace"
62
- />
63
- <teleport to="body">
64
- <common-adapter-manager-add-adapter-modal
65
- v-if="!props.isAddModal && existingAdaptersForAdding.length"
66
- :is-dark-mode="props.isDarkMode"
67
- :show="isShowAddAdapterModal"
68
- :existing-adapters-for-adding="existingAdaptersForAdding"
69
- :selected-add-adapter-id="selectedAddAdapterId"
70
- :adapters="props.adapters"
71
- @hide="onHideAddAdapterModal"
72
- @add-adapter="onAddSelectedAdapters"
73
- @select-add-adapter="onSelectAddAdapter"
74
- />
75
- <common-adapter-manager-add-adapter-warning-modal
76
- v-if="!props.isAddModal && !existingAdaptersForAdding.length"
77
- :test-id="props.testId"
78
- :show="isShowAddAdapterModal"
79
- @hide="onHideAddAdapterModal"
80
- />
81
- <common-adapter-manager-no-connected-active-adapters-modal
82
- :show="props.isShowNoConnectedActiveAdaptersModal"
83
- @hide="onHideNoConnectedActiveAdaptersModal"
84
- @submit="onConfirmNoActiveAdaptersModal"
85
- />
86
- <common-adapter-manager-no-active-adapters-modal
87
- :show="props.isShowNoActiveAdaptersModal"
88
- @hide="onHideNoActiveAdaptersModal"
89
- @submit="onConfirmNoActiveAdaptersModal"
90
- />
91
- </teleport>
92
- </template>
93
-
94
- <script setup lang="ts">
95
- import type {
96
- UI_I_Localization,
97
- UI_I_ItemsWithTotalCounts,
98
- } from '~/lib/models/interfaces'
99
- import type { UI_T_AdapterStatusNames } from '~/components/common/diagramMain/lib/models/types'
100
- import type {
101
- UI_I_Adapter,
102
- UI_I_AdapterStatus,
103
- UI_I_ModalsInitialData,
104
- UI_I_SwitchAdapterItem,
105
- } from '~/components/common/diagramMain/lib/models/interfaces'
106
- import {
107
- adapterViewSettingsModalTabsFunc,
108
- adapterViewSettingsFunc,
109
- } from '~/components/common/diagramMain/modals/lib/config'
110
- import { allAdaptersFunc } from '~/components/common/adapterManager/lib/config'
111
-
112
- const props = withDefaults(
113
- defineProps<{
114
- isActive?: boolean
115
- fullMode?: boolean
116
- isAddModal?: boolean
117
- isDarkMode: boolean
118
- adapters: UI_I_ItemsWithTotalCounts<UI_I_SwitchAdapterItem>
119
- initialData?: UI_I_ModalsInitialData
120
- addedAdapters?: string[]
121
- coreAdapters?: string[]
122
- freeAdapters?: UI_I_Adapter[]
123
- adapterStatus?: UI_I_AdapterStatus
124
- testId: string
125
- isShowNoConnectedActiveAdaptersModal?: boolean
126
- isShowNoActiveAdaptersModal?: boolean
127
- existingAdaptersForAdding?: (UI_I_Adapter | UI_I_SwitchAdapterItem)[]
128
- selectedAddAdapterId?: string
129
- }>(),
130
- {
131
- isActive: true,
132
- fullMode: false,
133
- isAddModal: false,
134
- adapters: () => ({
135
- total_items: 0,
136
- total_pages: 0,
137
- items: [],
138
- }),
139
- initialData: () => ({}),
140
- addedAdapters: () => [],
141
- coreAdapters: () => [],
142
- freeAdapters: () => [],
143
- adapterStatus: () => ({
144
- active: [],
145
- standby: [],
146
- unused: [],
147
- }),
148
- isShowNoConnectedActiveAdaptersModal: false,
149
- isShowNoActiveAdaptersModal: false,
150
- existingAdaptersForAdding: () => [],
151
- selectedAddAdapterId: '',
152
- }
153
- )
154
-
155
- const { $store }: any = useNuxtApp()
156
-
157
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
158
-
159
- const existingAdaptersForAdding = computed<
160
- (UI_I_Adapter | UI_I_SwitchAdapterItem)[]
161
- >(() =>
162
- [
163
- ...props.freeAdapters,
164
- ...props.adapters.items.filter((adapter: UI_I_SwitchAdapterItem) =>
165
- removedAdapters.value.includes(adapter.name)
166
- ),
167
- ].filter(
168
- (adapter: UI_I_Adapter | UI_I_SwitchAdapterItem) =>
169
- !props.addedAdapters?.includes(adapter.name)
170
- )
171
- )
172
-
173
- const localization = computed<UI_I_Localization>(() => useLocal())
174
-
175
- const adapterStatusLocal = ref<UI_I_AdapterStatus>(
176
- useDeepCopy(props.adapterStatus)
177
- )
178
-
179
- const isDisabledMoveUp = computed<boolean>(
180
- () =>
181
- selectedIsHeader.value ||
182
- adapterStatusLocal.value.active[0] === selectedAdapterId.value
183
- )
184
- const isDisabledMoveDown = computed<boolean>(
185
- () =>
186
- selectedIsHeader.value ||
187
- adapterStatusLocal.value.unused[
188
- adapterStatusLocal.value.unused.length - 1
189
- ] === selectedAdapterId.value
190
- )
191
- const hasSelectedAdapter = computed<boolean>(
192
- () =>
193
- (selectedAdapterId.value !== '' &&
194
- !selectedAdapterId.value.includes('header-')) ||
195
- selectedAddAdapterId.value !== ''
196
- )
197
- const isDisabledRemove = computed<boolean>(() =>
198
- props.coreAdapters.includes(selectedAdapterId.value)
199
- )
200
-
201
- const selectedIsHeader = computed<boolean>(
202
- () => !selectedAdapterId.value || selectedAdapterId.value.includes('header-')
203
- )
204
- const isActiveHeader = computed<boolean>(
205
- () => selectedAdapterId.value === 'header-active'
206
- )
207
- const isUnusedHeader = computed<boolean>(
208
- () => selectedAdapterId.value === 'header-unused'
209
- )
210
- const isStandbyHeader = computed<boolean>(
211
- () => selectedAdapterId.value === 'header-stand-by'
212
- )
213
-
214
- watch(
215
- () => props.adapterStatus,
216
- (newAdapterStatus: UI_I_AdapterStatus) => {
217
- adapterStatusLocal.value = useDeepCopy(newAdapterStatus)
218
- },
219
- { deep: true, immediate: true }
220
- )
221
-
222
- const removedAdapters = ref<string[]>([])
223
- const addedAdapters = ref<string[]>(props.addedAdapters)
224
-
225
- const selectedAdapterId = ref<string>('')
226
-
227
- const onSelectAdapter = (adapterId: string): void => {
228
- selectedAdapterId.value = adapterId
229
- }
230
-
231
- const selectedAddAdapterId = ref<string>('')
232
-
233
- const onSelectAddAdapter = (adapterId: string): void => {
234
- emits('select-add-adapter', adapterId)
235
- selectedAddAdapterId.value = adapterId
236
- }
237
-
238
- const moveDownForStatusGroup = (
239
- status: UI_T_AdapterStatusNames,
240
- adapterId: string
241
- ): void => {
242
- const isActiveSelectedAdapter =
243
- adapterStatusLocal.value[status].includes(adapterId)
244
-
245
- if (!isActiveSelectedAdapter) return
246
-
247
- const nextStatus: UI_T_AdapterStatusNames =
248
- status === 'active' ? 'standby' : 'unused'
249
-
250
- const selectedAdapterIndex =
251
- adapterStatusLocal.value[status].indexOf(adapterId)
252
-
253
- const activeLength = adapterStatusLocal.value[status].length
254
-
255
- const activeLastIndex = activeLength - 1
256
- const isNotLastOfActiveAdapters = selectedAdapterIndex !== activeLastIndex
257
-
258
- const isLastOfActiveAdapters = selectedAdapterIndex === activeLastIndex
259
-
260
- if (isNotLastOfActiveAdapters) {
261
- adapterStatusLocal.value[status].splice(selectedAdapterIndex, 1)
262
- adapterStatusLocal.value[status].splice(
263
- selectedAdapterIndex + 1,
264
- 0,
265
- adapterId
266
- )
267
- }
268
- if (isLastOfActiveAdapters && status !== 'unused') {
269
- adapterStatusLocal.value[status].splice(selectedAdapterIndex, 1)
270
- adapterStatusLocal.value[nextStatus].unshift(adapterId)
271
- }
272
- emits('change-adapter-status', adapterStatusLocal.value)
273
- }
274
-
275
- const moveUpForStatusGroup = (
276
- status: UI_T_AdapterStatusNames,
277
- adapterId: string
278
- ): void => {
279
- const isActiveSelectedAdapter =
280
- adapterStatusLocal.value[status].includes(adapterId)
281
-
282
- if (!isActiveSelectedAdapter) return
283
-
284
- const nextStatus: UI_T_AdapterStatusNames =
285
- status === 'unused' ? 'standby' : 'active'
286
- const selectedAdapterIndex =
287
- adapterStatusLocal.value[status].indexOf(adapterId)
288
- const activeFirstIndex = 0
289
- const isNotFirstOfActiveAdapters = selectedAdapterIndex !== activeFirstIndex
290
- const isFirstOfActiveAdapters = selectedAdapterIndex === activeFirstIndex
291
- if (isNotFirstOfActiveAdapters) {
292
- adapterStatusLocal.value[status].splice(selectedAdapterIndex, 1)
293
- adapterStatusLocal.value[status].splice(
294
- selectedAdapterIndex - 1,
295
- 0,
296
- adapterId
297
- )
298
- }
299
- if (isFirstOfActiveAdapters && status !== 'active') {
300
- adapterStatusLocal.value[status].splice(selectedAdapterIndex, 1)
301
- adapterStatusLocal.value[nextStatus].push(adapterId)
302
- }
303
- emits('change-adapter-status', adapterStatusLocal.value)
304
- }
305
-
306
- const onMoveDownWithId = (adapterId: string): void => {
307
- moveDownForStatusGroup('unused', adapterId)
308
- moveDownForStatusGroup('standby', adapterId)
309
- moveDownForStatusGroup('active', adapterId)
310
- }
311
-
312
- const onMoveDown = () => {
313
- onMoveDownWithId(selectedAdapterId.value)
314
- }
315
-
316
- const onMoveUpWithId = (adapterId: string): void => {
317
- moveUpForStatusGroup('active', adapterId)
318
- moveUpForStatusGroup('standby', adapterId)
319
- moveUpForStatusGroup('unused', adapterId)
320
- }
321
-
322
- const onMoveUp = () => {
323
- onMoveUpWithId(selectedAdapterId.value)
324
- }
325
-
326
- const onRemoveWithId = (adapterId: string): void => {
327
- adapterStatusLocal.value.active.includes(adapterId) &&
328
- (adapterStatusLocal.value.active = adapterStatusLocal.value.active.filter(
329
- (id: string) => id !== adapterId
330
- ))
331
- adapterStatusLocal.value.standby.includes(adapterId) &&
332
- (adapterStatusLocal.value.standby = adapterStatusLocal.value.standby.filter(
333
- (id: string) => id !== adapterId
334
- ))
335
- adapterStatusLocal.value.unused.includes(adapterId) &&
336
- (adapterStatusLocal.value.unused = adapterStatusLocal.value.unused.filter(
337
- (id: string) => id !== adapterId
338
- ))
339
-
340
- !props.freeAdapters.find(
341
- (adapter: UI_I_Adapter) => adapter.name === adapterId
342
- ) && removedAdapters.value.push(adapterId)
343
- addedAdapters.value = [
344
- ...adapterStatusLocal.value.active,
345
- ...adapterStatusLocal.value.unused,
346
- ...adapterStatusLocal.value.standby,
347
- ]
348
- emits('change-added-adapters', addedAdapters.value)
349
- emits('change-adapter-status', adapterStatusLocal.value)
350
-
351
- if (isNewView.value && adapterId !== selectedAdapterId.value) {
352
- return
353
- }
354
- selectedAdapterId.value = ''
355
- }
356
-
357
- const onRemove = (id?: string) => {
358
- onRemoveWithId(id || selectedAdapterId.value)
359
- }
360
-
361
- const onClickEmptySpace = (event: Event): void => {
362
- const targetElement = event.target as HTMLElement
363
-
364
- if (isNewView.value) {
365
- const addButton = targetElement.closest('.manager-header-add')
366
- const removeButton = targetElement.closest('.adapter-remove')
367
-
368
- if (!addButton && !removeButton) {
369
- selectedAdapterId.value = ''
370
- selectedAddAdapterId.value = ''
371
- emits('select-add-adapter', '')
372
- }
373
- }
374
- if (!isNewView.value && targetElement.classList.contains('k-grid-content')) {
375
- selectedAdapterId.value = ''
376
- selectedAddAdapterId.value = ''
377
- emits('select-add-adapter', '')
378
- }
379
- }
380
-
381
- const isShowAddAdapterModal = ref<boolean>(false)
382
-
383
- const onHideAddAdapterModal = (): void => {
384
- isShowAddAdapterModal.value = false
385
- }
386
-
387
- const emits = defineEmits<{
388
- (event: 'get-free-adapters', showModal: () => void): void
389
- (event: 'change-added-adapters', addedAdapters: string[]): void
390
- (event: 'change-adapter-status', adapterStatus: UI_I_AdapterStatus): void
391
- (event: 'hide-no-connected-active-adapters-modal'): void
392
- (event: 'hide-no-active-adapters-modal'): void
393
- (event: 'submit-from-modal'): void
394
- (event: 'select-add-adapter', id: string): void
395
- }>()
396
-
397
- const onHideNoConnectedActiveAdaptersModal = () => {
398
- emits('hide-no-connected-active-adapters-modal')
399
- }
400
- const onHideNoActiveAdaptersModal = () => {
401
- emits('hide-no-active-adapters-modal')
402
- }
403
- const onConfirmNoActiveAdaptersModal = () => {
404
- emits('submit-from-modal')
405
- }
406
-
407
- const showAddAdapterModal = () => {
408
- isShowAddAdapterModal.value = true
409
- }
410
- const onShowAddAdapterModal = (): void => {
411
- emits('get-free-adapters', showAddAdapterModal)
412
- }
413
-
414
- const onAddSelectedAdapters = (addAdapterId: string): void => {
415
- adapterStatusLocal.value.active.push(addAdapterId)
416
- removedAdapters.value = removedAdapters.value.filter(
417
- (id: string) => id !== addAdapterId
418
- )
419
- addedAdapters.value = [
420
- ...adapterStatusLocal.value.active,
421
- ...adapterStatusLocal.value.unused,
422
- ...adapterStatusLocal.value.standby,
423
- ]
424
- emits('change-added-adapters', addedAdapters.value)
425
- emits('change-adapter-status', adapterStatusLocal.value)
426
- onHideAddAdapterModal()
427
- }
428
-
429
- const adapterViewSettingsModalTabs = computed(() =>
430
- adapterViewSettingsModalTabsFunc(localization.value)
431
- )
432
-
433
- const allAdapters = computed<UI_I_Adapter[]>(() =>
434
- allAdaptersFunc(props.adapters.items)
435
- )
436
-
437
- const addAdapterViewSettings = computed(() =>
438
- adapterViewSettingsFunc(
439
- localization.value,
440
- allAdapters.value.find(
441
- (adapter: UI_I_Adapter) => adapter.name === props.selectedAddAdapterId
442
- ) || {},
443
- isNewView.value
444
- )
445
- )
446
-
447
- const selectedAdapterData = computed(
448
- () =>
449
- allAdapters.value.find(
450
- (adapter: UI_I_Adapter) => adapter.name === selectedAdapterId.value
451
- ) as UI_I_ModalsInitialData
452
- )
453
-
454
- const selectedAdapterDataFromFree = computed(
455
- () =>
456
- props.freeAdapters?.find(
457
- (adapter: UI_I_Adapter) => adapter.name === selectedAdapterId.value
458
- ) as UI_I_ModalsInitialData
459
- )
460
-
461
- const adapterViewSettings = computed(() => {
462
- if (!selectedAdapterId.value) return []
463
- return adapterViewSettingsFunc(
464
- localization.value,
465
- selectedAdapterData.value || selectedAdapterDataFromFree.value,
466
- isNewView.value
467
- )
468
- })
469
-
470
- const viewSettingsFields = computed(() =>
471
- props.isAddModal ? addAdapterViewSettings.value : adapterViewSettings.value
472
- )
473
- </script>
1
+ <template>
2
+ <common-adapter-manager-new
3
+ v-if="isNewView"
4
+ :is-active="props.isActive"
5
+ :full-mode="props.fullMode"
6
+ :core-adapters="props.coreAdapters"
7
+ :is-add-modal="props.isAddModal"
8
+ :is-dark-mode="props.isDarkMode"
9
+ :adapters="props.adapters"
10
+ :adapter-status="adapterStatusLocal"
11
+ :existing-adapters-for-adding="props.existingAdaptersForAdding"
12
+ :selected-is-header="selectedIsHeader"
13
+ :is-disabled-move-up="isDisabledMoveUp"
14
+ :is-disabled-move-down="isDisabledMoveDown"
15
+ :is-disabled-remove="isDisabledRemove"
16
+ :selected-adapter-id="selectedAdapterId"
17
+ :view-settings-fields="viewSettingsFields"
18
+ :selected-add-adapter-id="selectedAddAdapterId"
19
+ :is-active-header="isActiveHeader"
20
+ :is-unused-header="isUnusedHeader"
21
+ :is-standby-header="isStandbyHeader"
22
+ :has-selected-adapter="hasSelectedAdapter"
23
+ :removed-adapters="removedAdapters"
24
+ :adapter-view-settings-modal-tabs="adapterViewSettingsModalTabs"
25
+ @get-free-adapters="onShowAddAdapterModal"
26
+ @select-add-adapter="onSelectAddAdapter"
27
+ @remove-adapter="onRemove"
28
+ @select-adapter="onSelectAdapter"
29
+ @move-down="onMoveDown"
30
+ @move-up="onMoveUp"
31
+ @click-empty-space="onClickEmptySpace"
32
+ />
33
+ <common-adapter-manager-old
34
+ v-else
35
+ :is-active="props.isActive"
36
+ :full-mode="props.fullMode"
37
+ :is-add-modal="props.isAddModal"
38
+ :is-dark-mode="props.isDarkMode"
39
+ :adapters="props.adapters"
40
+ :adapter-status="adapterStatusLocal"
41
+ :existing-adapters-for-adding="props.existingAdaptersForAdding"
42
+ :selected-is-header="selectedIsHeader"
43
+ :is-disabled-move-up="isDisabledMoveUp"
44
+ :is-disabled-move-down="isDisabledMoveDown"
45
+ :is-disabled-remove="isDisabledRemove"
46
+ :selected-adapter-id="selectedAdapterId"
47
+ :view-settings-fields="viewSettingsFields"
48
+ :selected-add-adapter-id="selectedAddAdapterId"
49
+ :is-active-header="isActiveHeader"
50
+ :is-unused-header="isUnusedHeader"
51
+ :is-standby-header="isStandbyHeader"
52
+ :has-selected-adapter="hasSelectedAdapter"
53
+ :removed-adapters="removedAdapters"
54
+ :adapter-view-settings-modal-tabs="adapterViewSettingsModalTabs"
55
+ @get-free-adapters="onShowAddAdapterModal"
56
+ @select-add-adapter="onSelectAddAdapter"
57
+ @remove-adapter="onRemove"
58
+ @select-adapter="onSelectAdapter"
59
+ @move-down="onMoveDown"
60
+ @move-up="onMoveUp"
61
+ @click-empty-space="onClickEmptySpace"
62
+ />
63
+ <teleport to="body">
64
+ <common-adapter-manager-add-adapter-modal
65
+ v-if="!props.isAddModal && existingAdaptersForAdding.length"
66
+ :is-dark-mode="props.isDarkMode"
67
+ :show="isShowAddAdapterModal"
68
+ :existing-adapters-for-adding="existingAdaptersForAdding"
69
+ :selected-add-adapter-id="selectedAddAdapterId"
70
+ :adapters="props.adapters"
71
+ @hide="onHideAddAdapterModal"
72
+ @add-adapter="onAddSelectedAdapters"
73
+ @select-add-adapter="onSelectAddAdapter"
74
+ />
75
+ <common-adapter-manager-add-adapter-warning-modal
76
+ v-if="!props.isAddModal && !existingAdaptersForAdding.length"
77
+ :test-id="props.testId"
78
+ :show="isShowAddAdapterModal"
79
+ @hide="onHideAddAdapterModal"
80
+ />
81
+ <common-adapter-manager-no-connected-active-adapters-modal
82
+ :show="props.isShowNoConnectedActiveAdaptersModal"
83
+ @hide="onHideNoConnectedActiveAdaptersModal"
84
+ @submit="onConfirmNoActiveAdaptersModal"
85
+ />
86
+ <common-adapter-manager-no-active-adapters-modal
87
+ :show="props.isShowNoActiveAdaptersModal"
88
+ @hide="onHideNoActiveAdaptersModal"
89
+ @submit="onConfirmNoActiveAdaptersModal"
90
+ />
91
+ </teleport>
92
+ </template>
93
+
94
+ <script setup lang="ts">
95
+ import type {
96
+ UI_I_Localization,
97
+ UI_I_ItemsWithTotalCounts,
98
+ } from '~/lib/models/interfaces'
99
+ import type { UI_T_AdapterStatusNames } from '~/components/common/diagramMain/lib/models/types'
100
+ import type {
101
+ UI_I_Adapter,
102
+ UI_I_AdapterStatus,
103
+ UI_I_ModalsInitialData,
104
+ UI_I_SwitchAdapterItem,
105
+ } from '~/components/common/diagramMain/lib/models/interfaces'
106
+ import {
107
+ adapterViewSettingsModalTabsFunc,
108
+ adapterViewSettingsFunc,
109
+ } from '~/components/common/diagramMain/modals/lib/config'
110
+ import { allAdaptersFunc } from '~/components/common/adapterManager/lib/config'
111
+
112
+ const props = withDefaults(
113
+ defineProps<{
114
+ isActive?: boolean
115
+ fullMode?: boolean
116
+ isAddModal?: boolean
117
+ isDarkMode: boolean
118
+ adapters: UI_I_ItemsWithTotalCounts<UI_I_SwitchAdapterItem>
119
+ initialData?: UI_I_ModalsInitialData
120
+ addedAdapters?: string[]
121
+ coreAdapters?: string[]
122
+ freeAdapters?: UI_I_Adapter[]
123
+ adapterStatus?: UI_I_AdapterStatus
124
+ testId: string
125
+ isShowNoConnectedActiveAdaptersModal?: boolean
126
+ isShowNoActiveAdaptersModal?: boolean
127
+ existingAdaptersForAdding?: (UI_I_Adapter | UI_I_SwitchAdapterItem)[]
128
+ selectedAddAdapterId?: string
129
+ }>(),
130
+ {
131
+ isActive: true,
132
+ fullMode: false,
133
+ isAddModal: false,
134
+ adapters: () => ({
135
+ total_items: 0,
136
+ total_pages: 0,
137
+ items: [],
138
+ }),
139
+ initialData: () => ({}),
140
+ addedAdapters: () => [],
141
+ coreAdapters: () => [],
142
+ freeAdapters: () => [],
143
+ adapterStatus: () => ({
144
+ active: [],
145
+ standby: [],
146
+ unused: [],
147
+ }),
148
+ isShowNoConnectedActiveAdaptersModal: false,
149
+ isShowNoActiveAdaptersModal: false,
150
+ existingAdaptersForAdding: () => [],
151
+ selectedAddAdapterId: '',
152
+ }
153
+ )
154
+
155
+ const { $store }: any = useNuxtApp()
156
+
157
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
158
+
159
+ const existingAdaptersForAdding = computed<
160
+ (UI_I_Adapter | UI_I_SwitchAdapterItem)[]
161
+ >(() =>
162
+ [
163
+ ...props.freeAdapters,
164
+ ...props.adapters.items.filter((adapter: UI_I_SwitchAdapterItem) =>
165
+ removedAdapters.value.includes(adapter.name)
166
+ ),
167
+ ].filter(
168
+ (adapter: UI_I_Adapter | UI_I_SwitchAdapterItem) =>
169
+ !props.addedAdapters?.includes(adapter.name)
170
+ )
171
+ )
172
+
173
+ const localization = computed<UI_I_Localization>(() => useLocal())
174
+
175
+ const adapterStatusLocal = ref<UI_I_AdapterStatus>(
176
+ useDeepCopy(props.adapterStatus)
177
+ )
178
+
179
+ const isDisabledMoveUp = computed<boolean>(
180
+ () =>
181
+ selectedIsHeader.value ||
182
+ adapterStatusLocal.value.active[0] === selectedAdapterId.value
183
+ )
184
+ const isDisabledMoveDown = computed<boolean>(
185
+ () =>
186
+ selectedIsHeader.value ||
187
+ adapterStatusLocal.value.unused[
188
+ adapterStatusLocal.value.unused.length - 1
189
+ ] === selectedAdapterId.value
190
+ )
191
+ const hasSelectedAdapter = computed<boolean>(
192
+ () =>
193
+ (selectedAdapterId.value !== '' &&
194
+ !selectedAdapterId.value.includes('header-')) ||
195
+ selectedAddAdapterId.value !== ''
196
+ )
197
+ const isDisabledRemove = computed<boolean>(() =>
198
+ props.coreAdapters.includes(selectedAdapterId.value)
199
+ )
200
+
201
+ const selectedIsHeader = computed<boolean>(
202
+ () => !selectedAdapterId.value || selectedAdapterId.value.includes('header-')
203
+ )
204
+ const isActiveHeader = computed<boolean>(
205
+ () => selectedAdapterId.value === 'header-active'
206
+ )
207
+ const isUnusedHeader = computed<boolean>(
208
+ () => selectedAdapterId.value === 'header-unused'
209
+ )
210
+ const isStandbyHeader = computed<boolean>(
211
+ () => selectedAdapterId.value === 'header-stand-by'
212
+ )
213
+
214
+ watch(
215
+ () => props.adapterStatus,
216
+ (newAdapterStatus: UI_I_AdapterStatus) => {
217
+ adapterStatusLocal.value = useDeepCopy(newAdapterStatus)
218
+ },
219
+ { deep: true, immediate: true }
220
+ )
221
+
222
+ const removedAdapters = ref<string[]>([])
223
+ const addedAdapters = ref<string[]>(props.addedAdapters)
224
+
225
+ const selectedAdapterId = ref<string>('')
226
+
227
+ const onSelectAdapter = (adapterId: string): void => {
228
+ selectedAdapterId.value = adapterId
229
+ }
230
+
231
+ const selectedAddAdapterId = ref<string>('')
232
+
233
+ const onSelectAddAdapter = (adapterId: string): void => {
234
+ emits('select-add-adapter', adapterId)
235
+ selectedAddAdapterId.value = adapterId
236
+ }
237
+
238
+ const moveDownForStatusGroup = (
239
+ status: UI_T_AdapterStatusNames,
240
+ adapterId: string
241
+ ): void => {
242
+ const isActiveSelectedAdapter =
243
+ adapterStatusLocal.value[status].includes(adapterId)
244
+
245
+ if (!isActiveSelectedAdapter) return
246
+
247
+ const nextStatus: UI_T_AdapterStatusNames =
248
+ status === 'active' ? 'standby' : 'unused'
249
+
250
+ const selectedAdapterIndex =
251
+ adapterStatusLocal.value[status].indexOf(adapterId)
252
+
253
+ const activeLength = adapterStatusLocal.value[status].length
254
+
255
+ const activeLastIndex = activeLength - 1
256
+ const isNotLastOfActiveAdapters = selectedAdapterIndex !== activeLastIndex
257
+
258
+ const isLastOfActiveAdapters = selectedAdapterIndex === activeLastIndex
259
+
260
+ if (isNotLastOfActiveAdapters) {
261
+ adapterStatusLocal.value[status].splice(selectedAdapterIndex, 1)
262
+ adapterStatusLocal.value[status].splice(
263
+ selectedAdapterIndex + 1,
264
+ 0,
265
+ adapterId
266
+ )
267
+ }
268
+ if (isLastOfActiveAdapters && status !== 'unused') {
269
+ adapterStatusLocal.value[status].splice(selectedAdapterIndex, 1)
270
+ adapterStatusLocal.value[nextStatus].unshift(adapterId)
271
+ }
272
+ emits('change-adapter-status', adapterStatusLocal.value)
273
+ }
274
+
275
+ const moveUpForStatusGroup = (
276
+ status: UI_T_AdapterStatusNames,
277
+ adapterId: string
278
+ ): void => {
279
+ const isActiveSelectedAdapter =
280
+ adapterStatusLocal.value[status].includes(adapterId)
281
+
282
+ if (!isActiveSelectedAdapter) return
283
+
284
+ const nextStatus: UI_T_AdapterStatusNames =
285
+ status === 'unused' ? 'standby' : 'active'
286
+ const selectedAdapterIndex =
287
+ adapterStatusLocal.value[status].indexOf(adapterId)
288
+ const activeFirstIndex = 0
289
+ const isNotFirstOfActiveAdapters = selectedAdapterIndex !== activeFirstIndex
290
+ const isFirstOfActiveAdapters = selectedAdapterIndex === activeFirstIndex
291
+ if (isNotFirstOfActiveAdapters) {
292
+ adapterStatusLocal.value[status].splice(selectedAdapterIndex, 1)
293
+ adapterStatusLocal.value[status].splice(
294
+ selectedAdapterIndex - 1,
295
+ 0,
296
+ adapterId
297
+ )
298
+ }
299
+ if (isFirstOfActiveAdapters && status !== 'active') {
300
+ adapterStatusLocal.value[status].splice(selectedAdapterIndex, 1)
301
+ adapterStatusLocal.value[nextStatus].push(adapterId)
302
+ }
303
+ emits('change-adapter-status', adapterStatusLocal.value)
304
+ }
305
+
306
+ const onMoveDownWithId = (adapterId: string): void => {
307
+ moveDownForStatusGroup('unused', adapterId)
308
+ moveDownForStatusGroup('standby', adapterId)
309
+ moveDownForStatusGroup('active', adapterId)
310
+ }
311
+
312
+ const onMoveDown = () => {
313
+ onMoveDownWithId(selectedAdapterId.value)
314
+ }
315
+
316
+ const onMoveUpWithId = (adapterId: string): void => {
317
+ moveUpForStatusGroup('active', adapterId)
318
+ moveUpForStatusGroup('standby', adapterId)
319
+ moveUpForStatusGroup('unused', adapterId)
320
+ }
321
+
322
+ const onMoveUp = () => {
323
+ onMoveUpWithId(selectedAdapterId.value)
324
+ }
325
+
326
+ const onRemoveWithId = (adapterId: string): void => {
327
+ adapterStatusLocal.value.active.includes(adapterId) &&
328
+ (adapterStatusLocal.value.active = adapterStatusLocal.value.active.filter(
329
+ (id: string) => id !== adapterId
330
+ ))
331
+ adapterStatusLocal.value.standby.includes(adapterId) &&
332
+ (adapterStatusLocal.value.standby = adapterStatusLocal.value.standby.filter(
333
+ (id: string) => id !== adapterId
334
+ ))
335
+ adapterStatusLocal.value.unused.includes(adapterId) &&
336
+ (adapterStatusLocal.value.unused = adapterStatusLocal.value.unused.filter(
337
+ (id: string) => id !== adapterId
338
+ ))
339
+
340
+ !props.freeAdapters.find(
341
+ (adapter: UI_I_Adapter) => adapter.name === adapterId
342
+ ) && removedAdapters.value.push(adapterId)
343
+ addedAdapters.value = [
344
+ ...adapterStatusLocal.value.active,
345
+ ...adapterStatusLocal.value.unused,
346
+ ...adapterStatusLocal.value.standby,
347
+ ]
348
+ emits('change-added-adapters', addedAdapters.value)
349
+ emits('change-adapter-status', adapterStatusLocal.value)
350
+
351
+ if (isNewView.value && adapterId !== selectedAdapterId.value) {
352
+ return
353
+ }
354
+ selectedAdapterId.value = ''
355
+ }
356
+
357
+ const onRemove = (id?: string) => {
358
+ onRemoveWithId(id || selectedAdapterId.value)
359
+ }
360
+
361
+ const onClickEmptySpace = (event: Event): void => {
362
+ const targetElement = event.target as HTMLElement
363
+
364
+ if (isNewView.value) {
365
+ const addButton = targetElement.closest('.manager-header-add')
366
+ const removeButton = targetElement.closest('.adapter-remove')
367
+
368
+ if (!addButton && !removeButton) {
369
+ selectedAdapterId.value = ''
370
+ selectedAddAdapterId.value = ''
371
+ emits('select-add-adapter', '')
372
+ }
373
+ }
374
+ if (!isNewView.value && targetElement.classList.contains('k-grid-content')) {
375
+ selectedAdapterId.value = ''
376
+ selectedAddAdapterId.value = ''
377
+ emits('select-add-adapter', '')
378
+ }
379
+ }
380
+
381
+ const isShowAddAdapterModal = ref<boolean>(false)
382
+
383
+ const onHideAddAdapterModal = (): void => {
384
+ isShowAddAdapterModal.value = false
385
+ }
386
+
387
+ const emits = defineEmits<{
388
+ (event: 'get-free-adapters', showModal: () => void): void
389
+ (event: 'change-added-adapters', addedAdapters: string[]): void
390
+ (event: 'change-adapter-status', adapterStatus: UI_I_AdapterStatus): void
391
+ (event: 'hide-no-connected-active-adapters-modal'): void
392
+ (event: 'hide-no-active-adapters-modal'): void
393
+ (event: 'submit-from-modal'): void
394
+ (event: 'select-add-adapter', id: string): void
395
+ }>()
396
+
397
+ const onHideNoConnectedActiveAdaptersModal = () => {
398
+ emits('hide-no-connected-active-adapters-modal')
399
+ }
400
+ const onHideNoActiveAdaptersModal = () => {
401
+ emits('hide-no-active-adapters-modal')
402
+ }
403
+ const onConfirmNoActiveAdaptersModal = () => {
404
+ emits('submit-from-modal')
405
+ }
406
+
407
+ const showAddAdapterModal = () => {
408
+ isShowAddAdapterModal.value = true
409
+ }
410
+ const onShowAddAdapterModal = (): void => {
411
+ emits('get-free-adapters', showAddAdapterModal)
412
+ }
413
+
414
+ const onAddSelectedAdapters = (addAdapterId: string): void => {
415
+ adapterStatusLocal.value.active.push(addAdapterId)
416
+ removedAdapters.value = removedAdapters.value.filter(
417
+ (id: string) => id !== addAdapterId
418
+ )
419
+ addedAdapters.value = [
420
+ ...adapterStatusLocal.value.active,
421
+ ...adapterStatusLocal.value.unused,
422
+ ...adapterStatusLocal.value.standby,
423
+ ]
424
+ emits('change-added-adapters', addedAdapters.value)
425
+ emits('change-adapter-status', adapterStatusLocal.value)
426
+ onHideAddAdapterModal()
427
+ }
428
+
429
+ const adapterViewSettingsModalTabs = computed(() =>
430
+ adapterViewSettingsModalTabsFunc(localization.value)
431
+ )
432
+
433
+ const allAdapters = computed<UI_I_Adapter[]>(() =>
434
+ allAdaptersFunc(props.adapters.items)
435
+ )
436
+
437
+ const addAdapterViewSettings = computed(() =>
438
+ adapterViewSettingsFunc(
439
+ localization.value,
440
+ allAdapters.value.find(
441
+ (adapter: UI_I_Adapter) => adapter.name === props.selectedAddAdapterId
442
+ ) || {},
443
+ isNewView.value
444
+ )
445
+ )
446
+
447
+ const selectedAdapterData = computed(
448
+ () =>
449
+ allAdapters.value.find(
450
+ (adapter: UI_I_Adapter) => adapter.name === selectedAdapterId.value
451
+ ) as UI_I_ModalsInitialData
452
+ )
453
+
454
+ const selectedAdapterDataFromFree = computed(
455
+ () =>
456
+ props.freeAdapters?.find(
457
+ (adapter: UI_I_Adapter) => adapter.name === selectedAdapterId.value
458
+ ) as UI_I_ModalsInitialData
459
+ )
460
+
461
+ const adapterViewSettings = computed(() => {
462
+ if (!selectedAdapterId.value) return []
463
+ return adapterViewSettingsFunc(
464
+ localization.value,
465
+ selectedAdapterData.value || selectedAdapterDataFromFree.value,
466
+ isNewView.value
467
+ )
468
+ })
469
+
470
+ const viewSettingsFields = computed(() =>
471
+ props.isAddModal ? addAdapterViewSettings.value : adapterViewSettings.value
472
+ )
473
+ </script>