bfg-common 1.6.63 → 1.6.65

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 (188) hide show
  1. package/assets/localization/local_be.json +5 -1
  2. package/assets/localization/local_en.json +15 -11
  3. package/assets/localization/local_hy.json +5 -1
  4. package/assets/localization/local_kk.json +5 -1
  5. package/assets/localization/local_ru.json +10 -6
  6. package/assets/localization/local_zh.json +5 -1
  7. package/components/atoms/dropdown/dropdown/Dropdown.vue +8 -10
  8. package/components/atoms/dropdown/dropdown/lib/models/interfaces.ts +0 -1
  9. package/components/common/adapterManager/AdapterManager.vue +473 -473
  10. package/components/common/adapterManager/AdapterManagerNew.vue +86 -0
  11. package/components/common/adapterManager/AdapterManagerOld.vue +498 -498
  12. package/components/common/adapterManager/addAdapterModal/AddAdapterModal.vue +70 -70
  13. package/components/common/adapterManager/addAdapterModal/AddAdapterModalNew.vue +110 -110
  14. package/components/common/adapterManager/addAdapterModal/AddAdapterModalOld.vue +531 -531
  15. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModal.vue +32 -32
  16. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModalNew.vue +37 -37
  17. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModalOld.vue +73 -73
  18. package/components/common/adapterManager/lib/config/index.ts +19 -19
  19. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModal.vue +31 -31
  20. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModalNew.vue +34 -34
  21. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModalOld.vue +57 -57
  22. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModal.vue +31 -31
  23. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModalNew.vue +34 -34
  24. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModalOld.vue +57 -57
  25. package/components/common/adapterManager/ui/actions/AddAdapterButton.vue +34 -34
  26. package/components/common/adapterManager/ui/actions/RemoveAdapterButton.vue +41 -41
  27. package/components/common/adapterManager/ui/actions/VerticalSeparator.vue +10 -10
  28. package/components/common/adapterManager/ui/actions/bar/Bar.vue +2 -0
  29. package/components/common/adapterManager/ui/actions/bar/BarNew.vue +3 -2
  30. package/components/common/adapterManager/ui/actions/bar/BarOld.vue +95 -95
  31. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButton.vue +28 -28
  32. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButtonNew.vue +76 -76
  33. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButtonOld.vue +33 -33
  34. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButton.vue +28 -28
  35. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButtonNew.vue +77 -77
  36. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButtonOld.vue +33 -33
  37. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapter.vue +24 -24
  38. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapterNew.vue +18 -18
  39. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapterOld.vue +38 -38
  40. package/components/common/adapterManager/ui/secondTitle/SecondTitle.vue +31 -31
  41. package/components/common/adapterManager/ui/secondTitle/SecondTitleNew.vue +51 -51
  42. package/components/common/adapterManager/ui/secondTitle/SecondTitleOld.vue +35 -35
  43. package/components/common/adapterManager/ui/table/Table.vue +88 -88
  44. package/components/common/adapterManager/ui/table/TableNew.vue +137 -137
  45. package/components/common/adapterManager/ui/table/TableOld.vue +141 -141
  46. package/components/common/adapterManager/ui/table/adapters/Adapters.vue +44 -44
  47. package/components/common/adapterManager/ui/table/adapters/AdaptersNew.vue +187 -187
  48. package/components/common/adapterManager/ui/table/adapters/AdaptersOld.vue +87 -87
  49. package/components/common/adapterManager/ui/table/header/Header.vue +57 -57
  50. package/components/common/adapterManager/ui/table/header/HeaderNew.vue +81 -81
  51. package/components/common/adapterManager/ui/table/header/HeaderOld.vue +79 -79
  52. package/components/common/adapterManager/ui/table/lib/models/types.ts +1 -1
  53. package/components/common/diagramMain/Diagram.vue +459 -459
  54. package/components/common/diagramMain/DiagramMain.vue +929 -929
  55. package/components/common/diagramMain/adapter/Adapter.vue +123 -123
  56. package/components/common/diagramMain/adapter/AdapterItem.vue +438 -438
  57. package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
  58. package/components/common/diagramMain/adapter/Contents.vue +212 -212
  59. package/components/common/diagramMain/adapter/Lines.vue +81 -81
  60. package/components/common/diagramMain/adapter/block/Block.vue +27 -27
  61. package/components/common/diagramMain/adapter/block/BlockNew.vue +58 -58
  62. package/components/common/diagramMain/adapter/block/BlockOld.vue +50 -50
  63. package/components/common/diagramMain/adapter/secondBlock/SecondBlock.vue +27 -27
  64. package/components/common/diagramMain/adapter/secondBlock/SecondBlockNew.vue +60 -60
  65. package/components/common/diagramMain/adapter/secondBlock/SecondBlockOld.vue +51 -51
  66. package/components/common/diagramMain/header/Header.vue +49 -49
  67. package/components/common/diagramMain/header/HeaderNew.vue +155 -155
  68. package/components/common/diagramMain/header/HeaderOld.vue +234 -234
  69. package/components/common/diagramMain/highlights/Highlights.vue +151 -151
  70. package/components/common/diagramMain/highlights/HighlightsNew.vue +124 -124
  71. package/components/common/diagramMain/highlights/HighlightsOld.vue +107 -107
  72. package/components/common/diagramMain/lib/config/index.ts +81 -81
  73. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  74. package/components/common/diagramMain/lib/config/positions.ts +194 -194
  75. package/components/common/diagramMain/lib/models/enums.ts +44 -44
  76. package/components/common/diagramMain/lib/models/interfaces.ts +760 -760
  77. package/components/common/diagramMain/lib/models/types.ts +21 -21
  78. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  79. package/components/common/diagramMain/modals/ManagePhysicalAdaptersModal.vue +331 -331
  80. package/components/common/diagramMain/modals/Modals.vue +483 -483
  81. package/components/common/diagramMain/modals/UnsavedChangesModal.vue +32 -0
  82. package/components/common/diagramMain/modals/editSettings/EditSettings.vue +104 -102
  83. package/components/common/diagramMain/modals/editSettings/EditSettingsNew.vue +285 -0
  84. package/components/common/diagramMain/modals/editSettings/EditSettingsOld.vue +254 -0
  85. package/components/common/diagramMain/modals/editSettings/confirmTeamingSettingsModal/ConfirmTeamingSettingsModal.vue +31 -0
  86. package/components/common/diagramMain/modals/editSettings/confirmTeamingSettingsModal/ConfirmTeamingSettingsModalNew.vue +82 -0
  87. package/components/common/diagramMain/modals/editSettings/{ConfirmTeamingSettingsModal.vue → confirmTeamingSettingsModal/ConfirmTeamingSettingsModalOld.vue} +2 -5
  88. package/components/common/diagramMain/modals/editSettings/lib/config/config.ts +15 -0
  89. package/components/common/diagramMain/modals/editSettings/lib/models/interfaces.ts +6 -0
  90. package/components/common/diagramMain/modals/editSettings/lib/utils/utils.ts +177 -0
  91. package/components/common/diagramMain/modals/editSettings/modal/EditSettingsModal.vue +137 -0
  92. package/components/common/diagramMain/modals/editSettings/modal/EditSettingsModalNew.vue +91 -0
  93. package/components/common/diagramMain/modals/editSettings/{EditSettingsModal.vue → modal/EditSettingsModalOld.vue} +12 -51
  94. package/components/common/diagramMain/modals/editSettings/tabs/networkProperties/NetworkProperties.vue +158 -0
  95. package/components/common/diagramMain/modals/editSettings/tabs/networkProperties/NetworkPropertiesNew.vue +262 -0
  96. package/components/common/diagramMain/modals/editSettings/tabs/{NetworkProperties.vue → networkProperties/NetworkPropertiesOld.vue} +12 -113
  97. package/components/common/diagramMain/modals/editSettings/tabs/port/ipvFourSettings/IpvFourSettings.vue +192 -0
  98. package/components/common/diagramMain/modals/editSettings/tabs/port/ipvFourSettings/IpvFourSettingsNew.vue +388 -0
  99. package/components/common/diagramMain/modals/editSettings/tabs/port/{IpvFourSettings.vue → ipvFourSettings/IpvFourSettingsOld.vue} +11 -152
  100. package/components/common/diagramMain/modals/editSettings/tabs/port/portProperties/PortProperties.vue +139 -0
  101. package/components/common/diagramMain/modals/editSettings/tabs/port/portProperties/PortPropertiesNew.vue +286 -0
  102. package/components/common/diagramMain/modals/editSettings/tabs/port/{PortProperties.vue → portProperties/PortPropertiesOld.vue} +12 -103
  103. package/components/common/diagramMain/modals/editSettings/tabs/security/Security.vue +209 -0
  104. package/components/common/diagramMain/modals/editSettings/tabs/security/SecurityNew.vue +233 -0
  105. package/components/common/diagramMain/modals/editSettings/tabs/{Security.vue → security/SecurityOld.vue} +25 -48
  106. package/components/common/diagramMain/modals/editSettings/tabs/switchProperties/SwitchProperties.vue +128 -0
  107. package/components/common/diagramMain/modals/editSettings/tabs/switchProperties/SwitchPropertiesNew.vue +235 -0
  108. package/components/common/diagramMain/modals/editSettings/tabs/switchProperties/SwitchPropertiesOld.vue +87 -0
  109. package/components/common/diagramMain/modals/editSettings/tabs/teamingFailover/TeamingFailover.vue +99 -0
  110. package/components/common/diagramMain/modals/editSettings/tabs/teamingFailover/TeamingFailoverNew.vue +319 -0
  111. package/components/common/diagramMain/modals/editSettings/tabs/{TeamingFailover.vue → teamingFailover/TeamingFailoverOld.vue} +11 -48
  112. package/components/common/diagramMain/modals/editSettings/tabs/trafficShaping/TrafficShaping.vue +173 -0
  113. package/components/common/diagramMain/modals/editSettings/tabs/trafficShaping/TrafficShapingNew.vue +348 -0
  114. package/components/common/diagramMain/modals/editSettings/tabs/{TrafficShaping.vue → trafficShaping/TrafficShapingOld.vue} +12 -134
  115. package/components/common/diagramMain/modals/lib/config/adapterModal.ts +147 -147
  116. package/components/common/diagramMain/modals/lib/config/diagramConfig.ts +66 -66
  117. package/components/common/diagramMain/modals/lib/config/index.ts +56 -56
  118. package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
  119. package/components/common/diagramMain/modals/lib/config/networkModal.ts +405 -405
  120. package/components/common/diagramMain/modals/lib/config/portModal.ts +253 -253
  121. package/components/common/diagramMain/modals/lib/config/switchModal.ts +245 -245
  122. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  123. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  124. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +88 -88
  125. package/components/common/diagramMain/modals/lib/utils/index.ts +34 -4
  126. package/components/common/diagramMain/modals/migrateVmkernelAdapter/MigrateVmkernelAdapter.vue +541 -541
  127. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
  128. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +170 -170
  129. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
  130. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/VmkernelAdapterReadyComplete.vue +49 -49
  131. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +19 -19
  132. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
  133. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
  134. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  135. package/components/common/diagramMain/modals/remove/RemoveModal.vue +82 -82
  136. package/components/common/diagramMain/modals/remove/RemoveModalNew.vue +106 -106
  137. package/components/common/diagramMain/modals/remove/RemoveModalOld.vue +241 -241
  138. package/components/common/diagramMain/modals/viewSettings/info/Info.vue +57 -57
  139. package/components/common/diagramMain/modals/viewSettings/info/InfoNew.vue +174 -174
  140. package/components/common/diagramMain/modals/viewSettings/info/InfoOld.vue +141 -141
  141. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettings.vue +45 -45
  142. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsNew.vue +323 -323
  143. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsOld.vue +203 -203
  144. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModal.vue +60 -60
  145. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModalNew.vue +50 -50
  146. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModalOld.vue +70 -70
  147. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/lib/models/interfaces.ts +48 -48
  148. package/components/common/diagramMain/network/Contents.vue +497 -497
  149. package/components/common/diagramMain/network/Lines.vue +107 -107
  150. package/components/common/diagramMain/network/Network.vue +141 -141
  151. package/components/common/diagramMain/network/block/Block.vue +37 -37
  152. package/components/common/diagramMain/network/block/BlockNew.vue +68 -68
  153. package/components/common/diagramMain/network/block/BlockOld.vue +64 -64
  154. package/components/common/diagramMain/network/noNetwork/NoNetwork.vue +12 -12
  155. package/components/common/diagramMain/network/noNetwork/NoNetworkNew.vue +89 -89
  156. package/components/common/diagramMain/network/noNetwork/NoNetworkOld.vue +61 -61
  157. package/components/common/diagramMain/network/secondBlock/SecondBlock.vue +41 -41
  158. package/components/common/diagramMain/network/secondBlock/SecondBlockNew.vue +64 -64
  159. package/components/common/diagramMain/network/secondBlock/SecondBlockOld.vue +60 -60
  160. package/components/common/diagramMain/port/Port.vue +580 -580
  161. package/components/common/diagramMain/port/Ports.vue +47 -47
  162. package/components/common/diagramMain/skeleton/Header.vue +31 -31
  163. package/components/common/diagramMain/skeleton/Switch.vue +75 -75
  164. package/components/common/diagramMain/switch/Switch.vue +180 -180
  165. package/components/common/diagramMain/switch/SwitchSelected.vue +111 -111
  166. package/components/common/modals/Rename.vue +3 -1
  167. package/components/common/monitor/advanced/table/tableOld/TableOld.vue +93 -93
  168. package/components/common/monitor/utilization/New.vue +5 -0
  169. package/components/common/monitor/utilization/Old.vue +24 -65
  170. package/components/common/monitor/utilization/Utilization.vue +14 -22
  171. package/components/common/monitor/utilization/infoBlock/InfoBlock.vue +2 -125
  172. package/components/common/monitor/utilization/infoBlock/New.vue +3 -183
  173. package/components/common/monitor/utilization/infoBlock/Old.vue +66 -71
  174. package/components/common/monitor/utilization/lib/models/enums.ts +4 -4
  175. package/components/common/monitor/utilization/lib/models/interfaces.ts +12 -14
  176. package/components/common/monitor/utilization/lib/utils/index.ts +6 -64
  177. package/components/common/vm/actions/rename/Old.vue +1 -0
  178. package/package.json +2 -2
  179. package/components/common/diagramMain/modals/editSettings/tabs/SwitchProperties.vue +0 -164
  180. package/components/common/monitor/utilization/infoBlock/progressBar/New.vue +0 -64
  181. package/components/common/monitor/utilization/infoBlock/progressBar/Old.vue +0 -65
  182. package/components/common/monitor/utilization/infoBlock/progressBar/ProgressBar.vue +0 -84
  183. package/components/common/monitor/utilization/infoBlock/progressBar/lib/models/interfaces.ts +0 -10
  184. package/components/common/monitor/utilization/lib/models/types.ts +0 -1
  185. package/components/common/monitor/utilization/new/New.vue +0 -167
  186. package/components/common/monitor/utilization/new/Portlet.vue +0 -42
  187. package/components/common/monitor/utilization/new/Skeleton.vue +0 -120
  188. package/components/common/monitor/utilization/new/lib/utils/newPortlet.ts +0 -7
@@ -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>