bfg-common 1.6.64 → 1.6.66

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 (144) hide show
  1. package/assets/localization/local_ru.json +5 -5
  2. package/components/atoms/dropdown/dropdown/Dropdown.vue +10 -8
  3. package/components/atoms/dropdown/dropdown/lib/models/interfaces.ts +1 -0
  4. package/components/common/adapterManager/AdapterManager.vue +473 -473
  5. package/components/common/adapterManager/AdapterManagerOld.vue +498 -498
  6. package/components/common/adapterManager/addAdapterModal/AddAdapterModal.vue +70 -70
  7. package/components/common/adapterManager/addAdapterModal/AddAdapterModalNew.vue +110 -110
  8. package/components/common/adapterManager/addAdapterModal/AddAdapterModalOld.vue +531 -531
  9. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModal.vue +32 -32
  10. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModalNew.vue +37 -37
  11. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModalOld.vue +73 -73
  12. package/components/common/adapterManager/lib/config/index.ts +19 -19
  13. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModal.vue +31 -31
  14. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModalNew.vue +34 -34
  15. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModalOld.vue +57 -57
  16. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModal.vue +31 -31
  17. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModalNew.vue +34 -34
  18. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModalOld.vue +57 -57
  19. package/components/common/adapterManager/ui/actions/AddAdapterButton.vue +34 -34
  20. package/components/common/adapterManager/ui/actions/RemoveAdapterButton.vue +41 -41
  21. package/components/common/adapterManager/ui/actions/VerticalSeparator.vue +10 -10
  22. package/components/common/adapterManager/ui/actions/bar/BarOld.vue +95 -95
  23. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButton.vue +28 -28
  24. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButtonNew.vue +76 -76
  25. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButtonOld.vue +33 -33
  26. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButton.vue +28 -28
  27. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButtonNew.vue +77 -77
  28. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButtonOld.vue +33 -33
  29. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapter.vue +24 -24
  30. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapterNew.vue +18 -18
  31. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapterOld.vue +38 -38
  32. package/components/common/adapterManager/ui/secondTitle/SecondTitle.vue +31 -31
  33. package/components/common/adapterManager/ui/secondTitle/SecondTitleNew.vue +51 -51
  34. package/components/common/adapterManager/ui/secondTitle/SecondTitleOld.vue +35 -35
  35. package/components/common/adapterManager/ui/table/Table.vue +88 -88
  36. package/components/common/adapterManager/ui/table/TableNew.vue +137 -137
  37. package/components/common/adapterManager/ui/table/TableOld.vue +141 -141
  38. package/components/common/adapterManager/ui/table/adapters/Adapters.vue +44 -44
  39. package/components/common/adapterManager/ui/table/adapters/AdaptersNew.vue +187 -187
  40. package/components/common/adapterManager/ui/table/adapters/AdaptersOld.vue +87 -87
  41. package/components/common/adapterManager/ui/table/header/Header.vue +57 -57
  42. package/components/common/adapterManager/ui/table/header/HeaderNew.vue +81 -81
  43. package/components/common/adapterManager/ui/table/header/HeaderOld.vue +79 -79
  44. package/components/common/adapterManager/ui/table/lib/models/types.ts +1 -1
  45. package/components/common/diagramMain/Diagram.vue +459 -459
  46. package/components/common/diagramMain/DiagramMain.vue +929 -929
  47. package/components/common/diagramMain/adapter/Adapter.vue +123 -123
  48. package/components/common/diagramMain/adapter/AdapterItem.vue +438 -438
  49. package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
  50. package/components/common/diagramMain/adapter/Contents.vue +212 -212
  51. package/components/common/diagramMain/adapter/Lines.vue +81 -81
  52. package/components/common/diagramMain/adapter/block/Block.vue +27 -27
  53. package/components/common/diagramMain/adapter/block/BlockNew.vue +58 -58
  54. package/components/common/diagramMain/adapter/block/BlockOld.vue +50 -50
  55. package/components/common/diagramMain/adapter/secondBlock/SecondBlock.vue +27 -27
  56. package/components/common/diagramMain/adapter/secondBlock/SecondBlockNew.vue +60 -60
  57. package/components/common/diagramMain/adapter/secondBlock/SecondBlockOld.vue +51 -51
  58. package/components/common/diagramMain/header/Header.vue +49 -49
  59. package/components/common/diagramMain/header/HeaderNew.vue +155 -155
  60. package/components/common/diagramMain/header/HeaderOld.vue +234 -234
  61. package/components/common/diagramMain/highlights/Highlights.vue +151 -151
  62. package/components/common/diagramMain/highlights/HighlightsNew.vue +124 -124
  63. package/components/common/diagramMain/highlights/HighlightsOld.vue +107 -107
  64. package/components/common/diagramMain/lib/config/index.ts +81 -81
  65. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  66. package/components/common/diagramMain/lib/config/positions.ts +194 -194
  67. package/components/common/diagramMain/lib/models/enums.ts +44 -44
  68. package/components/common/diagramMain/lib/models/interfaces.ts +760 -760
  69. package/components/common/diagramMain/lib/models/types.ts +21 -21
  70. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  71. package/components/common/diagramMain/modals/ManagePhysicalAdaptersModal.vue +331 -331
  72. package/components/common/diagramMain/modals/Modals.vue +483 -483
  73. package/components/common/diagramMain/modals/lib/config/adapterModal.ts +147 -147
  74. package/components/common/diagramMain/modals/lib/config/diagramConfig.ts +66 -66
  75. package/components/common/diagramMain/modals/lib/config/index.ts +56 -56
  76. package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
  77. package/components/common/diagramMain/modals/lib/config/networkModal.ts +405 -405
  78. package/components/common/diagramMain/modals/lib/config/portModal.ts +253 -253
  79. package/components/common/diagramMain/modals/lib/config/switchModal.ts +245 -245
  80. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  81. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  82. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +88 -88
  83. package/components/common/diagramMain/modals/migrateVmkernelAdapter/MigrateVmkernelAdapter.vue +541 -541
  84. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
  85. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +170 -170
  86. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
  87. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/VmkernelAdapterReadyComplete.vue +49 -49
  88. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +19 -19
  89. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
  90. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
  91. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  92. package/components/common/diagramMain/modals/remove/RemoveModal.vue +82 -82
  93. package/components/common/diagramMain/modals/remove/RemoveModalNew.vue +106 -106
  94. package/components/common/diagramMain/modals/remove/RemoveModalOld.vue +241 -241
  95. package/components/common/diagramMain/modals/viewSettings/info/Info.vue +57 -57
  96. package/components/common/diagramMain/modals/viewSettings/info/InfoNew.vue +174 -174
  97. package/components/common/diagramMain/modals/viewSettings/info/InfoOld.vue +141 -141
  98. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettings.vue +45 -45
  99. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsNew.vue +323 -323
  100. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsOld.vue +203 -203
  101. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModal.vue +60 -60
  102. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModalNew.vue +50 -50
  103. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModalOld.vue +70 -70
  104. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/lib/models/interfaces.ts +48 -48
  105. package/components/common/diagramMain/network/Contents.vue +497 -497
  106. package/components/common/diagramMain/network/Lines.vue +107 -107
  107. package/components/common/diagramMain/network/Network.vue +141 -141
  108. package/components/common/diagramMain/network/block/Block.vue +37 -37
  109. package/components/common/diagramMain/network/block/BlockNew.vue +68 -68
  110. package/components/common/diagramMain/network/block/BlockOld.vue +64 -64
  111. package/components/common/diagramMain/network/noNetwork/NoNetwork.vue +12 -12
  112. package/components/common/diagramMain/network/noNetwork/NoNetworkNew.vue +89 -89
  113. package/components/common/diagramMain/network/noNetwork/NoNetworkOld.vue +61 -61
  114. package/components/common/diagramMain/network/secondBlock/SecondBlock.vue +41 -41
  115. package/components/common/diagramMain/network/secondBlock/SecondBlockNew.vue +64 -64
  116. package/components/common/diagramMain/network/secondBlock/SecondBlockOld.vue +60 -60
  117. package/components/common/diagramMain/port/Port.vue +580 -580
  118. package/components/common/diagramMain/port/Ports.vue +47 -47
  119. package/components/common/diagramMain/skeleton/Header.vue +31 -31
  120. package/components/common/diagramMain/skeleton/Switch.vue +75 -75
  121. package/components/common/diagramMain/switch/Switch.vue +180 -180
  122. package/components/common/diagramMain/switch/SwitchSelected.vue +111 -111
  123. package/components/common/modals/Rename.vue +3 -1
  124. package/components/common/monitor/advanced/table/tableOld/TableOld.vue +93 -93
  125. package/components/common/monitor/utilization/Old.vue +65 -24
  126. package/components/common/monitor/utilization/Utilization.vue +22 -14
  127. package/components/common/monitor/utilization/infoBlock/InfoBlock.vue +125 -2
  128. package/components/common/monitor/utilization/infoBlock/New.vue +183 -3
  129. package/components/common/monitor/utilization/infoBlock/Old.vue +71 -66
  130. package/components/common/monitor/utilization/infoBlock/progressBar/New.vue +64 -0
  131. package/components/common/monitor/utilization/infoBlock/progressBar/Old.vue +65 -0
  132. package/components/common/monitor/utilization/infoBlock/progressBar/ProgressBar.vue +84 -0
  133. package/components/common/monitor/utilization/infoBlock/progressBar/lib/models/interfaces.ts +10 -0
  134. package/components/common/monitor/utilization/lib/models/enums.ts +4 -4
  135. package/components/common/monitor/utilization/lib/models/interfaces.ts +14 -12
  136. package/components/common/monitor/utilization/lib/models/types.ts +1 -0
  137. package/components/common/monitor/utilization/lib/utils/index.ts +64 -6
  138. package/components/common/monitor/utilization/new/New.vue +195 -0
  139. package/components/common/monitor/utilization/new/Portlet.vue +42 -0
  140. package/components/common/monitor/utilization/new/Skeleton.vue +120 -0
  141. package/components/common/monitor/utilization/new/lib/utils/newPortlet.ts +7 -0
  142. package/components/common/vm/actions/rename/Old.vue +1 -0
  143. package/package.json +1 -1
  144. package/components/common/monitor/utilization/New.vue +0 -5
@@ -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>