bfg-common 1.6.78 → 1.6.79

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 (27) hide show
  1. package/assets/localization/local_be.json +14 -1
  2. package/assets/localization/local_en.json +14 -1
  3. package/assets/localization/local_hy.json +14 -1
  4. package/assets/localization/local_kk.json +14 -1
  5. package/assets/localization/local_ru.json +14 -1
  6. package/assets/localization/local_zh.json +14 -1
  7. package/components/common/adapterManager/AdapterManagerNew.vue +1 -0
  8. package/components/common/certificate/Certificate.vue +16 -6
  9. package/components/common/certificate/Info/Info.vue +61 -0
  10. package/components/common/certificate/{CertificateInfo.vue → Info/Old.vue} +6 -34
  11. package/components/common/certificate/Info/new/New.vue +285 -0
  12. package/components/common/certificate/Info/new/lib/config/index.ts +59 -0
  13. package/components/common/certificate/Info/new/lib/models/interfaces.ts +3 -0
  14. package/components/common/certificate/Info/new/lib/utils/index.ts +10 -0
  15. package/components/common/certificate/Old.vue +27 -0
  16. package/components/common/certificate/new/New.vue +30 -0
  17. package/components/common/certificate/new/Skeleton.vue +155 -0
  18. package/components/common/certificate/tools/New.vue +48 -0
  19. package/components/common/certificate/tools/Old.vue +39 -0
  20. package/components/common/certificate/{Tools.vue → tools/Tools.vue} +18 -23
  21. package/components/common/certificate/tools/lib/config/tabsPannel.ts +20 -0
  22. package/components/common/diagramMain/modals/Modals.vue +479 -483
  23. package/components/common/diagramMain/modals/managePhysicalAdapters/ManagePhysicalAdapters.vue +164 -0
  24. package/components/common/diagramMain/modals/managePhysicalAdapters/ManagePhysicalAdaptersNew.vue +306 -0
  25. package/components/common/diagramMain/modals/{ManagePhysicalAdaptersModal.vue → managePhysicalAdapters/ManagePhysicalAdaptersOld.vue} +245 -331
  26. package/package.json +2 -2
  27. package/components/common/certificate/lib/config/tabsPannel.ts +0 -22
@@ -1,331 +1,245 @@
1
- <template>
2
- <div>
3
- <atoms-modal
4
- :width="props.width"
5
- :height="props.height"
6
- :show="props.show"
7
- :title="localization.common.managePhysicalNetworkAdapters"
8
- :second-title="props.switchName"
9
- :class="[
10
- 'diagram-action__edit',
11
- {
12
- 'is-dark': props.isDarkMode,
13
- },
14
- ]"
15
- @hide="onHideManagePhysicalAdaptersModal"
16
- @submit="onSendManageAdapter"
17
- >
18
- <template #modalBody>
19
- <div class="wizard-content__container">
20
- <div class="wizard-content">
21
- <common-adapter-manager
22
- :adapters="props.adapters"
23
- :free-adapters="props.freeAdapters"
24
- :added-adapters="addedAdapters"
25
- :adapter-status="props.adapterStatus"
26
- :is-dark-mode="props.isDarkMode"
27
- test-id="manage-physical-adapter"
28
- :is-active="true"
29
- :full-mode="true"
30
- :is-show-no-connected-active-adapters-modal="
31
- isShowNoConnectedActiveAdaptersModal
32
- "
33
- :is-show-no-active-adapters-modal="isShowNoActiveAdaptersModal"
34
-
35
- @hide-no-connected-active-adapters-modal="
36
- onHideNoConnectedActiveAdaptersModal
37
- "
38
- @hide-no-active-adapters-modal="onHideNoActiveAdaptersModal"
39
- @submit-from-modal="onConfirmNoActiveAdaptersModal"
40
- @change-added-adapters="onChangeAddedAdapters"
41
- @change-adapter-status="onChangeAdapterStatus"
42
- @get-free-adapters="onGetFreeAdapters"
43
- />
44
- </div>
45
- </div>
46
- <atoms-loader v-show="props.isManageAdaptersModalLoading" />
47
- </template>
48
- </atoms-modal>
49
- </div>
50
- </template>
51
-
52
- <script setup lang="ts">
53
- import type {
54
- UI_I_Localization,
55
- UI_I_ItemsWithTotalCounts,
56
- } from '~/lib/models/interfaces'
57
- import type {
58
- UI_I_Adapter,
59
- UI_I_AdapterStatus,
60
- UI_I_SwitchAdapterItem,
61
- } from '~/components/common/diagramMain/lib/models/interfaces'
62
-
63
- // Props from up
64
- const props = withDefaults(
65
- defineProps<{
66
- switchName: string
67
- show: boolean
68
- viewName: string
69
- width: string
70
- height: string
71
- freeAdapters: UI_I_Adapter[]
72
- adapterStatus: UI_I_AdapterStatus
73
- adapters: UI_I_ItemsWithTotalCounts<UI_I_SwitchAdapterItem>
74
- initialAdapterStatus: UI_I_AdapterStatus
75
- isDarkMode?: boolean
76
- isManageAdaptersModalLoading?: boolean
77
- }>(),
78
- {
79
- switchName: '',
80
- adapterStatus: () => ({
81
- active: [],
82
- standby: [],
83
- unused: [],
84
- }),
85
- isDarkMode: false,
86
- isManageAdaptersModalLoading: false,
87
- }
88
- )
89
-
90
- // Modal
91
- const emits = defineEmits<{
92
- (event: 'hide'): void
93
- (event: 'get-free-adapters', showModal: () => void): void
94
- (event: 'change-added-adapters', addedAdapters: string[]): void
95
- (event: 'change-adapter-status', adapterStatus: UI_I_AdapterStatus): void
96
- (
97
- event: 'send-manage-physical-adapters-data',
98
- adapterStatus: UI_I_AdapterStatus,
99
- switchName: string,
100
- hideModal: () => void
101
- ): void
102
- }>()
103
-
104
- // UI_I_Localization
105
- const localization = computed<UI_I_Localization>(() => useLocal())
106
-
107
- const addedAdapters = ref<string[]>()
108
-
109
- const onChangeAddedAdapters = (addedAdaptersNew: string[]) => {
110
- addedAdapters.value = addedAdaptersNew
111
- }
112
-
113
- const onChangeAdapterStatus = (adapterStatusNew: UI_I_AdapterStatus) => {
114
- emits('change-adapter-status', adapterStatusNew)
115
- }
116
-
117
- const isShowNoConnectedActiveAdaptersModal = ref(false)
118
- const isShowNoActiveAdaptersModal = ref(false)
119
-
120
- const showNoConnectedActiveAdaptersModal = () => {
121
- isShowNoConnectedActiveAdaptersModal.value = true
122
- }
123
- const onHideNoConnectedActiveAdaptersModal = () => {
124
- isShowNoConnectedActiveAdaptersModal.value = false
125
- }
126
- const showNoActiveAdaptersModal = () => {
127
- isShowNoActiveAdaptersModal.value = true
128
- }
129
- const onHideNoActiveAdaptersModal = () => {
130
- isShowNoActiveAdaptersModal.value = false
131
- }
132
-
133
- const onSendManagePhysicalAdaptersData = (
134
- adapterStatus: UI_I_AdapterStatus,
135
- switchName: string,
136
- hideModal: () => void
137
- ) => {
138
- emits(
139
- 'send-manage-physical-adapters-data',
140
- adapterStatus,
141
- switchName,
142
- hideModal
143
- )
144
- }
145
- const onConfirmNoActiveAdaptersModal = () => {
146
- onSendManagePhysicalAdaptersData(
147
- props.adapterStatus,
148
- props.switchName,
149
- onHideManagePhysicalAdaptersModal
150
- )
151
- onHideNoConnectedActiveAdaptersModal()
152
- onHideNoActiveAdaptersModal()
153
- }
154
-
155
- const onSendManageAdapter = () => {
156
- if (props.adapterStatus.active.length === 0) {
157
- showNoActiveAdaptersModal()
158
- return
159
- }
160
-
161
- const activeAndConnectedAdapters = props.adapterStatus.active.filter(
162
- (adapterName: string) =>
163
- props.adapters.items.find(
164
- (ad: UI_I_SwitchAdapterItem) => ad.name === adapterName
165
- )?.carrier
166
- )
167
- if (activeAndConnectedAdapters.length === 0) {
168
- showNoConnectedActiveAdaptersModal()
169
- return
170
- }
171
-
172
- onSendManagePhysicalAdaptersData(
173
- props.adapterStatus,
174
- props.switchName,
175
- onHideManagePhysicalAdaptersModal
176
- )
177
- }
178
-
179
- const onGetFreeAdapters = (showModal: () => void) => {
180
- emits('get-free-adapters', showModal)
181
- }
182
-
183
- const onHideManagePhysicalAdaptersModal = (): void => {
184
- addedAdapters.value = []
185
- emits('change-adapter-status', props.initialAdapterStatus)
186
- emits('hide')
187
- }
188
- </script>
189
-
190
- <style scoped lang="scss">
191
- :deep(.secondary-title) {
192
- font-size: 18px;
193
- font-weight: 200;
194
- }
195
-
196
- :deep(.modal-body-content.modal-body-content__confirmation) {
197
- display: flex;
198
-
199
- .confirm-icon-container {
200
- margin-right: 20px;
201
- }
202
-
203
- .preserve-newlines {
204
- white-space: pre-line;
205
- font-size: 15px;
206
- }
207
- }
208
-
209
- .loader {
210
- position: absolute;
211
- z-index: var(--z-fixed);
212
- left: 0;
213
- right: 0;
214
- bottom: 0;
215
- top: 0;
216
- display: flex;
217
- align-items: center;
218
- justify-content: center;
219
- background-color: rgba(0, 0, 0, 0.3);
220
-
221
- .spinner {
222
- left: unset;
223
- }
224
- }
225
-
226
- :deep(.table-fixed-height) {
227
- height: 290px;
228
- max-height: 290px;
229
- }
230
-
231
- :deep(.diagram-action__edit.is-dark) {
232
- .property-label-group {
233
- color: var(--main-color-mode2);
234
- }
235
- .flex-property-label-group {
236
- color: var(--main-color-mode2);
237
- }
238
- .flex-property-value-group {
239
- select {
240
- color: #fff;
241
- }
242
- }
243
- .failover-order-master {
244
- .secondary-title label {
245
- color: #fff;
246
- }
247
- }
248
- .k-grid-content {
249
- background-color: var(--modal-bg-color);
250
- }
251
- .vui-action-bar {
252
- background-color: var(--pannel-bg-color);
253
- color: var(--title-color);
254
-
255
- .action-link-container:not(.disabled) {
256
- &:hover {
257
- background-color: #29414e;
258
- border: 1px solid #c7e9ff;
259
- }
260
- }
261
-
262
- svg {
263
- fill: #fff;
264
- }
265
- }
266
-
267
- .k-grid.k-widget .k-grid-content {
268
- border-left: 1px solid #485764;
269
- border-right: 1px solid #485764;
270
- border-top: 1px solid #ddd;
271
- border-bottom: 1px solid #ddd;
272
-
273
- tbody tr {
274
- background-color: var(--modal-bg-color);
275
-
276
- td {
277
- border-bottom: 1px solid #666666;
278
- border-color: #666666;
279
- }
280
-
281
- &:hover {
282
- background-color: #324f61;
283
- color: var(--title-color);
284
-
285
- td {
286
- border-bottom: 1px solid #ffffff;
287
- }
288
- }
289
-
290
- &.k-state-selected {
291
- background-color: #d8e3e9;
292
- box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset;
293
-
294
- td span {
295
- color: #000;
296
- }
297
- }
298
- }
299
- }
300
-
301
- .failover-order-details {
302
- &.relative-container .absolute-container {
303
- background-color: var(--pannel-bg-color);
304
- color: var(--main-color-mode2);
305
-
306
- &:has(.no-items-selected-container) {
307
- background-color: transparent;
308
- }
309
- }
310
-
311
- td span {
312
- color: var(--main-color-mode2);
313
- }
314
- button span {
315
- color: var(--main-color-mode2);
316
-
317
- &:hover:not(.disabled) {
318
- background-color: transparent;
319
- border: 1px solid transparent;
320
- }
321
- }
322
- button.active span {
323
- color: #fff;
324
- }
325
- }
326
-
327
- .select-adapter-info span {
328
- color: var(--main-color-mode2);
329
- }
330
- }
331
- </style>
1
+ <template>
2
+ <div class="manage-physical-adapters">
3
+ <atoms-modal
4
+ width="864px"
5
+ height="510px"
6
+ show
7
+ :title="localization.common.managePhysicalNetworkAdapters"
8
+ :second-title="props.switchName"
9
+ :class="[
10
+ 'diagram-action__edit',
11
+ {
12
+ 'is-dark': props.isDarkMode,
13
+ },
14
+ ]"
15
+ @hide="emits('hide')"
16
+ @submit="emits('send-manage-adapter')"
17
+ >
18
+ <template #modalBody>
19
+ <div class="wizard-content__container">
20
+ <div class="wizard-content">
21
+ <common-adapter-manager
22
+ :adapters="props.adapters"
23
+ :free-adapters="props.freeAdapters"
24
+ :added-adapters="props.addedAdapters"
25
+ :adapter-status="props.adapterStatus"
26
+ :is-dark-mode="props.isDarkMode"
27
+ test-id="manage-physical-adapter"
28
+ :is-active="true"
29
+ :full-mode="true"
30
+ :is-show-no-connected-active-adapters-modal="
31
+ props.isShowNoConnectedActiveAdaptersModal
32
+ "
33
+ :is-show-no-active-adapters-modal="
34
+ props.isShowNoActiveAdaptersModal
35
+ "
36
+ @hide-no-connected-active-adapters-modal="
37
+ emits('hide-no-connected-active-adapters-modal')
38
+ "
39
+ @hide-no-active-adapters-modal="
40
+ emits('hide-no-active-adapters-modal')
41
+ "
42
+ @submit-from-modal="emits('confirm-no-active-adapters-modal')"
43
+ @change-added-adapters="onChangeAddedAdapters"
44
+ @change-adapter-status="onChangeAdapterStatus"
45
+ @get-free-adapters="onGetFreeAdapters"
46
+ />
47
+ </div>
48
+ </div>
49
+ <atoms-loader v-show="props.isManageAdaptersModalLoading" />
50
+ </template>
51
+ </atoms-modal>
52
+ </div>
53
+ </template>
54
+
55
+ <script setup lang="ts">
56
+ import type {
57
+ UI_I_Localization,
58
+ UI_I_ItemsWithTotalCounts,
59
+ } from '~/lib/models/interfaces'
60
+ import type {
61
+ UI_I_Adapter,
62
+ UI_I_AdapterStatus,
63
+ UI_I_SwitchAdapterItem,
64
+ } from '~/components/common/diagramMain/lib/models/interfaces'
65
+
66
+ const props = defineProps<{
67
+ switchName: string
68
+ freeAdapters: UI_I_Adapter[]
69
+ adapterStatus: UI_I_AdapterStatus
70
+ adapters: UI_I_ItemsWithTotalCounts<UI_I_SwitchAdapterItem>
71
+ addedAdapters: string[]
72
+ isDarkMode: boolean
73
+ isManageAdaptersModalLoading: boolean
74
+ isShowNoConnectedActiveAdaptersModal: boolean
75
+ isShowNoActiveAdaptersModal: boolean
76
+ }>()
77
+
78
+ const emits = defineEmits<{
79
+ (event: 'get-free-adapters', showModal: () => void): void
80
+ (event: 'change-added-adapters', addedAdapters: string[]): void
81
+ (event: 'change-adapter-status', adapterStatus: UI_I_AdapterStatus): void
82
+ (event: 'hide-no-connected-active-adapters-modal'): void
83
+ (event: 'hide-no-active-adapters-modal'): void
84
+ (event: 'confirm-no-active-adapters-modal'): void
85
+ (event: 'send-manage-adapter'): void
86
+ (event: 'hide'): void
87
+ }>()
88
+
89
+ const localization = computed<UI_I_Localization>(() => useLocal())
90
+
91
+ const onChangeAddedAdapters = (addedAdaptersNew: string[]) => {
92
+ emits('change-added-adapters', addedAdaptersNew)
93
+ }
94
+
95
+ const onChangeAdapterStatus = (adapterStatusNew: UI_I_AdapterStatus) => {
96
+ emits('change-adapter-status', adapterStatusNew)
97
+ }
98
+
99
+ const onGetFreeAdapters = (showModal: () => void) => {
100
+ emits('get-free-adapters', showModal)
101
+ }
102
+ </script>
103
+
104
+ <style scoped lang="scss">
105
+ :deep(.secondary-title) {
106
+ font-size: 18px;
107
+ font-weight: 200;
108
+ }
109
+
110
+ :deep(.modal-body-content.modal-body-content__confirmation) {
111
+ display: flex;
112
+
113
+ .confirm-icon-container {
114
+ margin-right: 20px;
115
+ }
116
+
117
+ .preserve-newlines {
118
+ white-space: pre-line;
119
+ font-size: 15px;
120
+ }
121
+ }
122
+
123
+ .loader {
124
+ position: absolute;
125
+ z-index: var(--z-fixed);
126
+ left: 0;
127
+ right: 0;
128
+ bottom: 0;
129
+ top: 0;
130
+ display: flex;
131
+ align-items: center;
132
+ justify-content: center;
133
+ background-color: rgba(0, 0, 0, 0.3);
134
+
135
+ .spinner {
136
+ left: unset;
137
+ }
138
+ }
139
+
140
+ :deep(.table-fixed-height) {
141
+ height: 290px;
142
+ max-height: 290px;
143
+ }
144
+
145
+ :deep(.diagram-action__edit.is-dark) {
146
+ .property-label-group {
147
+ color: var(--main-color-mode2);
148
+ }
149
+ .flex-property-label-group {
150
+ color: var(--main-color-mode2);
151
+ }
152
+ .flex-property-value-group {
153
+ select {
154
+ color: #fff;
155
+ }
156
+ }
157
+ .failover-order-master {
158
+ .secondary-title label {
159
+ color: #fff;
160
+ }
161
+ }
162
+ .k-grid-content {
163
+ background-color: var(--modal-bg-color);
164
+ }
165
+ .vui-action-bar {
166
+ background-color: var(--pannel-bg-color);
167
+ color: var(--title-color);
168
+
169
+ .action-link-container:not(.disabled) {
170
+ &:hover {
171
+ background-color: #29414e;
172
+ border: 1px solid #c7e9ff;
173
+ }
174
+ }
175
+
176
+ svg {
177
+ fill: #fff;
178
+ }
179
+ }
180
+
181
+ .k-grid.k-widget .k-grid-content {
182
+ border-left: 1px solid #485764;
183
+ border-right: 1px solid #485764;
184
+ border-top: 1px solid #ddd;
185
+ border-bottom: 1px solid #ddd;
186
+
187
+ tbody tr {
188
+ background-color: var(--modal-bg-color);
189
+
190
+ td {
191
+ border-bottom: 1px solid #666666;
192
+ border-color: #666666;
193
+ }
194
+
195
+ &:hover {
196
+ background-color: #324f61;
197
+ color: var(--title-color);
198
+
199
+ td {
200
+ border-bottom: 1px solid #ffffff;
201
+ }
202
+ }
203
+
204
+ &.k-state-selected {
205
+ background-color: #d8e3e9;
206
+ box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset;
207
+
208
+ td span {
209
+ color: #000;
210
+ }
211
+ }
212
+ }
213
+ }
214
+
215
+ .failover-order-details {
216
+ &.relative-container .absolute-container {
217
+ background-color: var(--pannel-bg-color);
218
+ color: var(--main-color-mode2);
219
+
220
+ &:has(.no-items-selected-container) {
221
+ background-color: transparent;
222
+ }
223
+ }
224
+
225
+ td span {
226
+ color: var(--main-color-mode2);
227
+ }
228
+ button span {
229
+ color: var(--main-color-mode2);
230
+
231
+ &:hover:not(.disabled) {
232
+ background-color: transparent;
233
+ border: 1px solid transparent;
234
+ }
235
+ }
236
+ button.active span {
237
+ color: #fff;
238
+ }
239
+ }
240
+
241
+ .select-adapter-info span {
242
+ color: var(--main-color-mode2);
243
+ }
244
+ }
245
+ </style>
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "bfg-common",
3
3
  "private": false,
4
- "version": "1.6.78",
4
+ "version": "1.6.79",
5
5
  "scripts": {
6
6
  "build": "nuxt build",
7
7
  "dev": "nuxt dev --port=3002",
@@ -18,7 +18,7 @@
18
18
  "@vueuse/core": "10.1.2",
19
19
  "@vueuse/nuxt": "10.1.2",
20
20
  "bfg-nuxt-3-graph": "1.0.28",
21
- "bfg-uikit": "1.1.32",
21
+ "bfg-uikit": "1.1.33",
22
22
  "eslint-config-prettier": "^8.5.0",
23
23
  "eslint-plugin-myrules": "file:./eslint",
24
24
  "nuxt": "3.11.2",
@@ -1,22 +0,0 @@
1
- import type { UI_I_Localization } from '~/lib/models/interfaces'
2
- import type { UI_I_CollapseNavItem } from '~/components/atoms/collapse/lib/models/interfaces'
3
-
4
- export const certificateTabsFunc = (
5
- localization: UI_I_Localization
6
- ): UI_I_CollapseNavItem[] => {
7
- return [
8
- {
9
- text: localization.common.renew,
10
- value: 'renew',
11
- disabled: false,
12
- testId: 'certificate-renew',
13
- },
14
- {
15
- text: localization.common.certificateRefreshTitle,
16
- value: 'refreshCaCertificates',
17
- disabled: true,
18
- testId: 'certificate-refresh',
19
- development: true,
20
- },
21
- ]
22
- }