bfg-common 1.6.86 → 1.6.87

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 (140) hide show
  1. package/assets/localization/local_be.json +158 -3
  2. package/assets/localization/local_en.json +158 -3
  3. package/assets/localization/local_hy.json +158 -3
  4. package/assets/localization/local_kk.json +158 -3
  5. package/assets/localization/local_ru.json +158 -3
  6. package/assets/localization/local_zh.json +158 -3
  7. package/components/common/adapterManager/AdapterManager.vue +473 -473
  8. package/components/common/adapterManager/AdapterManagerOld.vue +498 -498
  9. package/components/common/adapterManager/addAdapterModal/AddAdapterModal.vue +70 -70
  10. package/components/common/adapterManager/addAdapterModal/AddAdapterModalNew.vue +110 -110
  11. package/components/common/adapterManager/addAdapterModal/AddAdapterModalOld.vue +531 -531
  12. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModal.vue +32 -32
  13. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModalNew.vue +37 -37
  14. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModalOld.vue +73 -73
  15. package/components/common/adapterManager/lib/config/index.ts +19 -19
  16. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModal.vue +31 -31
  17. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModalNew.vue +34 -34
  18. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModalOld.vue +57 -57
  19. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModal.vue +31 -31
  20. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModalNew.vue +34 -34
  21. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModalOld.vue +57 -57
  22. package/components/common/adapterManager/ui/actions/AddAdapterButton.vue +34 -34
  23. package/components/common/adapterManager/ui/actions/RemoveAdapterButton.vue +41 -41
  24. package/components/common/adapterManager/ui/actions/VerticalSeparator.vue +10 -10
  25. package/components/common/adapterManager/ui/actions/bar/BarOld.vue +95 -95
  26. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButton.vue +28 -28
  27. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButtonNew.vue +76 -76
  28. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButtonOld.vue +33 -33
  29. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButton.vue +28 -28
  30. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButtonNew.vue +77 -77
  31. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButtonOld.vue +33 -33
  32. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapter.vue +24 -24
  33. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapterNew.vue +18 -18
  34. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapterOld.vue +38 -38
  35. package/components/common/adapterManager/ui/secondTitle/SecondTitle.vue +31 -31
  36. package/components/common/adapterManager/ui/secondTitle/SecondTitleNew.vue +51 -51
  37. package/components/common/adapterManager/ui/secondTitle/SecondTitleOld.vue +35 -35
  38. package/components/common/adapterManager/ui/table/Table.vue +88 -88
  39. package/components/common/adapterManager/ui/table/TableNew.vue +137 -137
  40. package/components/common/adapterManager/ui/table/TableOld.vue +141 -141
  41. package/components/common/adapterManager/ui/table/adapters/Adapters.vue +44 -44
  42. package/components/common/adapterManager/ui/table/adapters/AdaptersNew.vue +187 -187
  43. package/components/common/adapterManager/ui/table/adapters/AdaptersOld.vue +87 -87
  44. package/components/common/adapterManager/ui/table/header/Header.vue +57 -57
  45. package/components/common/adapterManager/ui/table/header/HeaderNew.vue +81 -81
  46. package/components/common/adapterManager/ui/table/header/HeaderOld.vue +79 -79
  47. package/components/common/adapterManager/ui/table/lib/models/types.ts +1 -1
  48. package/components/common/diagramMain/adapter/Adapter.vue +123 -123
  49. package/components/common/diagramMain/adapter/AdapterItem.vue +438 -438
  50. package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
  51. package/components/common/diagramMain/adapter/Contents.vue +212 -212
  52. package/components/common/diagramMain/adapter/Lines.vue +81 -81
  53. package/components/common/diagramMain/adapter/block/Block.vue +27 -27
  54. package/components/common/diagramMain/adapter/block/BlockNew.vue +58 -58
  55. package/components/common/diagramMain/adapter/block/BlockOld.vue +50 -50
  56. package/components/common/diagramMain/adapter/secondBlock/SecondBlock.vue +27 -27
  57. package/components/common/diagramMain/adapter/secondBlock/SecondBlockNew.vue +60 -60
  58. package/components/common/diagramMain/adapter/secondBlock/SecondBlockOld.vue +51 -51
  59. package/components/common/diagramMain/highlights/Highlights.vue +151 -151
  60. package/components/common/diagramMain/highlights/HighlightsNew.vue +124 -124
  61. package/components/common/diagramMain/highlights/HighlightsOld.vue +107 -107
  62. package/components/common/diagramMain/lib/config/index.ts +81 -81
  63. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  64. package/components/common/diagramMain/lib/config/positions.ts +194 -194
  65. package/components/common/diagramMain/lib/models/enums.ts +44 -44
  66. package/components/common/diagramMain/lib/models/interfaces.ts +760 -760
  67. package/components/common/diagramMain/lib/models/types.ts +21 -21
  68. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  69. package/components/common/diagramMain/modals/editSettings/lib/models/interfaces.ts +30 -30
  70. package/components/common/diagramMain/modals/editSettings/modal/EditSettingsModal.vue +137 -137
  71. package/components/common/diagramMain/modals/editSettings/modal/EditSettingsModalNew.vue +1 -1
  72. package/components/common/diagramMain/modals/editSettings/tabs/port/portProperties/PortPropertiesOld.vue +1 -0
  73. package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
  74. package/components/common/diagramMain/modals/lib/config/switchModal.ts +245 -245
  75. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  76. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +88 -88
  77. package/components/common/diagramMain/modals/migrateVmkernelAdapter/MigrateVmkernelAdapter.vue +541 -541
  78. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
  79. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +170 -170
  80. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
  81. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/VmkernelAdapterReadyComplete.vue +49 -49
  82. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +19 -19
  83. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
  84. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
  85. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  86. package/components/common/diagramMain/modals/remove/RemoveModal.vue +82 -82
  87. package/components/common/diagramMain/modals/remove/RemoveModalNew.vue +157 -157
  88. package/components/common/diagramMain/modals/remove/RemoveModalOld.vue +241 -241
  89. package/components/common/diagramMain/modals/viewSettings/info/Info.vue +57 -57
  90. package/components/common/diagramMain/modals/viewSettings/info/InfoNew.vue +174 -174
  91. package/components/common/diagramMain/modals/viewSettings/info/InfoOld.vue +141 -141
  92. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettings.vue +45 -45
  93. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsNew.vue +323 -323
  94. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsOld.vue +203 -203
  95. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModal.vue +60 -60
  96. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModalOld.vue +70 -70
  97. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/lib/models/interfaces.ts +48 -48
  98. package/components/common/diagramMain/network/Contents.vue +497 -497
  99. package/components/common/diagramMain/network/Lines.vue +107 -107
  100. package/components/common/diagramMain/network/Network.vue +141 -141
  101. package/components/common/diagramMain/network/block/Block.vue +37 -37
  102. package/components/common/diagramMain/network/block/BlockNew.vue +68 -68
  103. package/components/common/diagramMain/network/block/BlockOld.vue +64 -64
  104. package/components/common/diagramMain/network/noNetwork/NoNetwork.vue +12 -12
  105. package/components/common/diagramMain/network/noNetwork/NoNetworkNew.vue +89 -89
  106. package/components/common/diagramMain/network/noNetwork/NoNetworkOld.vue +61 -61
  107. package/components/common/diagramMain/network/secondBlock/SecondBlock.vue +41 -41
  108. package/components/common/diagramMain/network/secondBlock/SecondBlockNew.vue +64 -64
  109. package/components/common/diagramMain/network/secondBlock/SecondBlockOld.vue +60 -60
  110. package/components/common/diagramMain/port/Port.vue +580 -580
  111. package/components/common/diagramMain/port/Ports.vue +47 -47
  112. package/components/common/diagramMain/switch/Switch.vue +180 -180
  113. package/components/common/diagramMain/switch/SwitchSelected.vue +111 -111
  114. package/components/common/monitor/advanced/table/tableOld/TableOld.vue +93 -93
  115. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/lib/config/utils.ts +903 -164
  116. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/object/Object.vue +12 -12
  117. package/components/common/monitor/advanced/tools/chartOptionsModal/lib/config/index.ts +2 -0
  118. package/components/common/monitor/advanced/tools/chartOptionsModal/lib/utils/checkSubmit.ts +3 -2
  119. package/components/common/monitor/lib/utils/local_be.json +13 -1
  120. package/components/common/monitor/lib/utils/local_en.json +13 -1
  121. package/components/common/monitor/lib/utils/local_hy.json +13 -1
  122. package/components/common/monitor/lib/utils/local_kk.json +13 -1
  123. package/components/common/monitor/lib/utils/local_ru.json +13 -1
  124. package/components/common/monitor/lib/utils/local_zh.json +13 -1
  125. package/components/common/monitor/utilization/lib/models/enums.ts +4 -4
  126. package/components/common/pages/backups/lib/models/interfaces.ts +1 -0
  127. package/components/common/pages/backups/modals/Modals.vue +1 -0
  128. package/components/common/pages/backups/modals/lib/config/restore.ts +1 -0
  129. package/components/common/pages/backups/modals/lib/models/interfaces.ts +1 -0
  130. package/components/common/pages/backups/modals/restore/Restore.vue +4 -2
  131. package/components/common/wizards/network/add/Add.vue +0 -1
  132. package/package.json +1 -1
  133. package/components/common/configure/vmkernelAdapters/VmkernelAdapters.vue +0 -254
  134. package/components/common/configure/vmkernelAdapters/tableView/TableView.vue +0 -427
  135. package/components/common/configure/vmkernelAdapters/tableView/lib/config/settings.ts +0 -300
  136. package/components/common/configure/vmkernelAdapters/tableView/lib/config/tableKeys.ts +0 -12
  137. package/components/common/configure/vmkernelAdapters/tableView/lib/config/vmKernelAdaptersTableConfig.ts +0 -166
  138. package/components/common/configure/vmkernelAdapters/tableView/lib/models/interfaces.ts +0 -9
  139. package/components/common/configure/vmkernelAdapters/tableView/lib/models/types.ts +0 -9
  140. package/components/common/configure/vmkernelAdapters/tableView/mappers/mappers.ts +0 -27
@@ -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>