bfg-common 1.6.10 → 1.6.12

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 (33) hide show
  1. package/assets/localization/local_be.json +3 -1
  2. package/assets/localization/local_en.json +3 -1
  3. package/assets/localization/local_hy.json +3 -1
  4. package/assets/localization/local_kk.json +3 -1
  5. package/assets/localization/local_ru.json +3 -1
  6. package/assets/localization/local_zh.json +3 -1
  7. package/components/common/monitor/lib/utils/local_be.json +3 -1
  8. package/components/common/monitor/lib/utils/local_en.json +3 -1
  9. package/components/common/monitor/lib/utils/local_hy.json +3 -1
  10. package/components/common/monitor/lib/utils/local_kk.json +3 -1
  11. package/components/common/monitor/lib/utils/local_ru.json +3 -1
  12. package/components/common/monitor/lib/utils/local_zh.json +3 -1
  13. package/components/common/monitor/utilization/New.vue +5 -0
  14. package/components/common/monitor/utilization/Old.vue +79 -0
  15. package/components/common/monitor/utilization/Utilization.vue +51 -0
  16. package/components/common/monitor/utilization/infoBlock/InfoBlock.vue +23 -0
  17. package/components/common/monitor/utilization/infoBlock/New.vue +5 -0
  18. package/components/common/monitor/utilization/infoBlock/Old.vue +185 -0
  19. package/components/common/monitor/utilization/lib/models/enums.ts +4 -0
  20. package/components/common/monitor/utilization/lib/models/interfaces.ts +25 -0
  21. package/components/common/monitor/utilization/lib/utils/index.ts +31 -0
  22. package/components/common/vm/actions/consolidate/New.vue +1 -1
  23. package/components/common/vm/actions/consolidate/Old.vue +2 -2
  24. package/components/common/vm/actions/register/New.vue +271 -271
  25. package/components/common/vm/actions/rename/New.vue +11 -1
  26. package/components/common/vm/actions/rename/Rename.vue +6 -0
  27. package/components/common/vm/snapshots/lib/models/types.ts +1 -0
  28. package/components/common/vm/snapshots/modals/confirm/New.vue +2 -1
  29. package/components/common/vm/snapshots/modals/confirm/Old.vue +1 -1
  30. package/components/common/vm/snapshots/modals/confirm/lib/models/enums.ts +2 -0
  31. package/components/common/vm/snapshots/modals/lib/config/modalTexts.ts +1 -0
  32. package/components/common/wizards/common/steps/name/New.vue +302 -302
  33. package/package.json +1 -1
@@ -3440,7 +3440,9 @@
3440
3440
  "snapshotHasNoDescriptionYet": "Гэты здымак яшчэ не мае апісання.",
3441
3441
  "takeSnapshot": "Зрабіце здымак",
3442
3442
  "newSnapshot": "Новы здымак",
3443
- "editSnapshot": "Рэдагаваць здымак"
3443
+ "editSnapshot": "Рэдагаваць здымак",
3444
+ "revertLatestSnapshot": "Вярнуцца да апошняга здымка",
3445
+ "consolidateSnapshots": "Кансолідаваць здымкі"
3444
3446
  },
3445
3447
  "importVms": {
3446
3448
  "selectSourceTooltipDesc": "Правы карыстальніка esxi павінны адпавядаць ролях Administrator, крэдыт прымаюцца ад esxi і vSphere",
@@ -3444,7 +3444,9 @@
3444
3444
  "snapshotHasNoDescriptionYet": "This snapshot has no description yet.",
3445
3445
  "takeSnapshot": "Take Snapshot",
3446
3446
  "newSnapshot": "New Snapshot",
3447
- "editSnapshot": "Edit snapshot"
3447
+ "editSnapshot": "Edit snapshot",
3448
+ "revertLatestSnapshot": "Revert to Latest Snapshot",
3449
+ "consolidateSnapshots": "Consolidate Snapshots"
3448
3450
  },
3449
3451
  "importVms": {
3450
3452
  "selectSourceTooltipDesc": "No Trusted infrastructure Administrator, credits are accepted from esxi and vSphere",
@@ -3444,7 +3444,9 @@
3444
3444
  "snapshotHasNoDescriptionYet": "Այս պահպանումը դեռևս չունի նկարագրություն։",
3445
3445
  "takeSnapshot": "Ակնթարթ նկար",
3446
3446
  "newSnapshot": "Նոր սքրինշոթ",
3447
- "editSnapshot": "Խմբագրել սքրինշոթը"
3447
+ "editSnapshot": "Խմբագրել սքրինշոթը",
3448
+ "revertLatestSnapshot": "Վերադառնալ վերջին նկարին",
3449
+ "consolidateSnapshots": "Միավորել լուսանկարները"
3448
3450
  },
3449
3451
  "importVms": {
3450
3452
  "selectSourceTooltipDesc": "Esxi օգտագործողի իրավունքները պետք է համապատասխանեն Administrator-ի դերերին, կրեդիտներն ընդունվում են esxi-ից և vSphere-ից",
@@ -3443,7 +3443,9 @@
3443
3443
  "snapshotHasNoDescriptionYet": "Бұл суретке әлі сипаттама қосылмаған.",
3444
3444
  "takeSnapshot": "сурет",
3445
3445
  "newSnapshot": "Жаңа снимок",
3446
- "editSnapshot": "Снимокты өңдеу"
3446
+ "editSnapshot": "Снимокты өңдеу",
3447
+ "revertLatestSnapshot": "Варнузза және түтіннің тұманы",
3448
+ "consolidateSnapshots": "Суреттерді біріктіру"
3447
3449
  },
3448
3450
  "importVms": {
3449
3451
  "selectSourceTooltipDesc": "Esxi пайдаланушы құқықтары әкімші рөлдеріне сәйкес келуі керек, несиелер esxi және vSphere - ден алынады",
@@ -3443,7 +3443,9 @@
3443
3443
  "snapshotHasNoDescriptionYet": "У этого снимка пока нет описания.",
3444
3444
  "takeSnapshot": "Сделать снимок",
3445
3445
  "newSnapshot": "Новый снимок",
3446
- "editSnapshot": "Редактировать снимок"
3446
+ "editSnapshot": "Редактировать снимок",
3447
+ "revertLatestSnapshot": "Вернуться к последнему снимку",
3448
+ "consolidateSnapshots": "Консолидация снимков"
3447
3449
  },
3448
3450
  "importVms": {
3449
3451
  "selectSourceTooltipDesc": "Права пользователя vmware дожны соответствовать ролям Administrator, креды принимаются от esxi и vSphere",
@@ -3441,7 +3441,9 @@
3441
3441
  "snapshotHasNoDescriptionYet": "此快照尚无描述。",
3442
3442
  "takeSnapshot": "快照",
3443
3443
  "newSnapshot": "新快照",
3444
- "editSnapshot": "编辑快照"
3444
+ "editSnapshot": "编辑快照",
3445
+ "revertLatestSnapshot": "回到上一张照片",
3446
+ "consolidateSnapshots": "合并快照"
3445
3447
  },
3446
3448
  "importVms": {
3447
3449
  "selectSourceTooltipDesc": "Esxi用户权限必须对应于管理员角色. esxi和vSphere接受积分",
@@ -684,5 +684,7 @@
684
684
  "multicastTx": "Перададзеныя multicast",
685
685
  "multicastTxDesc": "Колькасць перададзеных multicast пакетаў",
686
686
  "multicastRx": "Атрыманыя multicast",
687
- "multicastRxDesc": "Колькасць атрыманых multicast пакетаў"
687
+ "multicastRxDesc": "Колькасць атрыманых multicast пакетаў",
688
+ "memSharedcommon": "Выкарыстанне агульнай памяці",
689
+ "memSharedcommonDesc": "Аб'ём памяці, якая падзяляецца паміж працэсамі (выкарыстанне агульнага сегмента агульнай памяці)"
688
690
  }
@@ -684,5 +684,7 @@
684
684
  "multicastTx": "Multicast transmitted",
685
685
  "multicastTxDesc": "Number of multicast packets transmitted",
686
686
  "multicastRx": "Multicast received",
687
- "multicastRxDesc": "Number of multicast packets received"
687
+ "multicastRxDesc": "Number of multicast packets received",
688
+ "memSharedcommon": "Shared Memory Usage",
689
+ "memSharedcommonDesc": "Amount of memory shared between processes (common shared memory segment usage)"
688
690
  }
@@ -684,5 +684,7 @@
684
684
  "multicastTx": "Փոխանցված multicast",
685
685
  "multicastTxDesc": "Փոխանցված multicast փաթեթների քանակը",
686
686
  "multicastRx": "Ստացված multicast",
687
- "multicastRxDesc": "Ստացված multicast փաթեթների քանակը"
687
+ "multicastRxDesc": "Ստացված multicast փաթեթների քանակը",
688
+ "memSharedcommon": "Համօգտագործվող հիշողության օգտագործում",
689
+ "memSharedcommonDesc": "Պրոցեսների միջև համօգտագործվող հիշողության ծավալը (ընդհանուր համօգտագործվող հիշողության սեգմենտի օգտագործում)"
688
690
  }
@@ -684,5 +684,7 @@
684
684
  "multicastTx": "Жіберілген мультикаст",
685
685
  "multicastTxDesc": "Жіберілген мультикаст пакеттерінің саны",
686
686
  "multicastRx": "Қабылданған мультикаст",
687
- "multicastRxDesc": "Қабылданған мультикаст пакеттерінің саны"
687
+ "multicastRxDesc": "Қабылданған мультикаст пакеттерінің саны",
688
+ "memSharedcommon": "Ортақ жадты пайдалану",
689
+ "memSharedcommonDesc": "Процестер арасында бөлісетін жад көлемі (ортақ бөлісетін жад сегментін пайдалану)"
688
690
  }
@@ -684,5 +684,7 @@
684
684
  "multicastTx": "Multicast отправлено",
685
685
  "multicastTxDesc": "Количество отправленных групповых пакетов",
686
686
  "multicastRx": "Multicast получено",
687
- "multicastRxDesc": "Количество полученных групповых пакетов"
687
+ "multicastRxDesc": "Количество полученных групповых пакетов",
688
+ "memSharedcommon": "Использование разделяемой памяти",
689
+ "memSharedcommonDesc": "Объём памяти, совместно используемой процессами (общие сегменты разделяемой памяти)"
688
690
  }
@@ -684,5 +684,7 @@
684
684
  "multicastTx": "已发送组播",
685
685
  "multicastTxDesc": "已发送的组播数据包数",
686
686
  "multicastRx": "已接收组播",
687
- "multicastRxDesc": "已接收的组播数据包数"
687
+ "multicastRxDesc": "已接收的组播数据包数",
688
+ "memSharedcommon": "共享内存使用情况",
689
+ "memSharedcommonDesc": "进程之间共享的内存量(公共共享内存段使用情况)"
688
690
  }
@@ -0,0 +1,5 @@
1
+ <template>New</template>
2
+
3
+ <script setup lang="ts"></script>
4
+
5
+ <style scoped lang="scss"></style>
@@ -0,0 +1,79 @@
1
+ <template>
2
+ <div class="logs__wrapper flex flex-col h-full">
3
+ <common-headline :headline="localization.common.utilization" class="mb-1" />
4
+
5
+ <div class="utilization-body-container">
6
+ <div class="utilization-info-block-flex-container">
7
+ <template v-for="(item, key) in allDataLocal" :key="key">
8
+ <common-monitor-utilization-info-block
9
+ v-if="item.isShow"
10
+ :info-data="item"
11
+ />
12
+ </template>
13
+ </div>
14
+
15
+ <div class="utilization-column-manage-container relative">
16
+ <ui-icon
17
+ name="settings"
18
+ width="24px"
19
+ height="24px"
20
+ @click="isShowColumnManage = !isShowColumnManage"
21
+ />
22
+
23
+ <atoms-popup-simple-popup
24
+ v-model="isShowColumnManage"
25
+ test-id="utilization-column-manage-popup"
26
+ top="0"
27
+ right="0"
28
+ >
29
+ <li v-for="(item, key) in allDataLocal" :key="key" class="list-item">
30
+ <input
31
+ v-model="item.isShow"
32
+ :id="`utilization-column-manage-${item.id}`"
33
+ type="checkbox"
34
+ />
35
+ <label :for="`utilization-column-manage-${item.id}`">{{
36
+ item.title
37
+ }}</label>
38
+ </li>
39
+ </atoms-popup-simple-popup>
40
+ </div>
41
+ </div>
42
+ </div>
43
+ </template>
44
+
45
+ <script setup lang="ts">
46
+ import type { UI_I_UtilizationDataItem } from '~/components/common/monitor/utilization/lib/models/interfaces'
47
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
48
+
49
+ const allDataLocal = defineModel<UI_I_UtilizationDataItem[]>('all-data')
50
+
51
+ const localization = computed<UI_I_Localization>(() => useLocal())
52
+
53
+ const isShowColumnManage = ref<boolean>(false)
54
+ </script>
55
+
56
+ <style scoped lang="scss">
57
+ .utilization-body-container {
58
+ display: flex;
59
+ align-items: flex-start;
60
+ justify-content: space-between;
61
+
62
+ .utilization-info-block-flex-container {
63
+ display: flex;
64
+ flex-wrap: wrap;
65
+ gap: 20px;
66
+ }
67
+ .utilization-column-manage-container {
68
+ :deep(.close-wrapper) {
69
+ display: none;
70
+ }
71
+ .list-item {
72
+ white-space: nowrap;
73
+ display: flex;
74
+ align-items: center;
75
+ gap: 5px;
76
+ }
77
+ }
78
+ }
79
+ </style>
@@ -0,0 +1,51 @@
1
+ <template>
2
+ <component :is="currentComponent" v-model:all-data="constructedData" />
3
+ </template>
4
+
5
+ <script setup lang="ts">
6
+ import type {
7
+ API_UI_I_UtilizationData,
8
+ UI_I_UtilizationDataItem,
9
+ } from '~/components/common/monitor/utilization/lib/models/interfaces'
10
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
11
+ import { constructApiData } from '~/components/common/monitor/utilization/lib/utils'
12
+
13
+ const props = defineProps<{
14
+ apiData: API_UI_I_UtilizationData
15
+ }>()
16
+
17
+ const { $store }: any = useNuxtApp()
18
+
19
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
20
+
21
+ const currentComponent = computed(() =>
22
+ isNewView.value
23
+ ? defineAsyncComponent(() => import('./New.vue'))
24
+ : defineAsyncComponent(() => import('./Old.vue'))
25
+ )
26
+
27
+ const localization = computed<UI_I_Localization>(() => useLocal())
28
+
29
+ const constructedData = ref<UI_I_UtilizationDataItem[]>([])
30
+
31
+ watch(
32
+ () => props.apiData,
33
+ () => {
34
+ !constructedData.value.length &&
35
+ (constructedData.value = constructApiData(
36
+ props.apiData,
37
+ localization.value
38
+ ))
39
+ },
40
+ { immediate: true, deep: true }
41
+ )
42
+ watch(
43
+ () => localization.value,
44
+ () => {
45
+ constructedData.value = constructApiData(props.apiData, localization.value)
46
+ },
47
+ { deep: true }
48
+ )
49
+ </script>
50
+
51
+ <style scoped lang="scss"></style>
@@ -0,0 +1,23 @@
1
+ <template>
2
+ <component :is="currentComponent" :info-data="props.infoData" />
3
+ </template>
4
+
5
+ <script setup lang="ts">
6
+ import type { UI_I_UtilizationDataItem } from '~/components/common/monitor/utilization/lib/models/interfaces'
7
+
8
+ const props = defineProps<{
9
+ infoData: UI_I_UtilizationDataItem
10
+ }>()
11
+
12
+ const { $store }: any = useNuxtApp()
13
+
14
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
15
+
16
+ const currentComponent = computed(() =>
17
+ isNewView.value
18
+ ? defineAsyncComponent(() => import('./New.vue'))
19
+ : defineAsyncComponent(() => import('./Old.vue'))
20
+ )
21
+ </script>
22
+
23
+ <style scoped lang="scss"></style>
@@ -0,0 +1,5 @@
1
+ <template>New</template>
2
+
3
+ <script setup lang="ts"></script>
4
+
5
+ <style scoped lang="scss"></style>
@@ -0,0 +1,185 @@
1
+ <template>
2
+ <div class="utilization-info-block">
3
+ <div class="header-block">
4
+ <p class="title">{{ props.infoData.title }}</p>
5
+ </div>
6
+ <div class="body-block">
7
+ <div class="bar">
8
+ <div :title="currentTitle" class="track">
9
+ <div
10
+ :style="{
11
+ width: animated ? barPercent + '%' : '0%',
12
+ background: consumedItem?.color,
13
+ boxShadow: `0 0 6px ${consumedItem?.color}88`,
14
+ }"
15
+ class="fill"
16
+ />
17
+ </div>
18
+ </div>
19
+ <div class="footer-body-block">
20
+ <p>{{ consumedItem?.value }}</p>
21
+ <p>{{ maxItem?.value }}</p>
22
+ </div>
23
+ </div>
24
+ <div class="footer-block">
25
+ <div
26
+ v-for="(item, key) in props.infoData.data"
27
+ :key="key"
28
+ class="footer-item"
29
+ >
30
+ <div class="left-block">
31
+ <div
32
+ v-if="item.color"
33
+ :style="`background-color: ${item.color}`"
34
+ class="color-block"
35
+ ></div>
36
+ <p class="name">{{ item.label }}</p>
37
+ </div>
38
+ <p class="value">{{ item.value }}</p>
39
+ </div>
40
+ </div>
41
+ </div>
42
+ </template>
43
+
44
+ <script setup lang="ts">
45
+ import type {
46
+ UI_I_UtilizationDataItem,
47
+ UI_I_UtilizationDataItems,
48
+ } from '~/components/common/monitor/utilization/lib/models/interfaces'
49
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
50
+
51
+ const props = defineProps<{
52
+ infoData: UI_I_UtilizationDataItem
53
+ }>()
54
+
55
+ const localization = computed<UI_I_Localization>(() => useLocal())
56
+
57
+ const animated = ref<boolean>(false)
58
+
59
+ const maxItem = computed<UI_I_UtilizationDataItems | null>(
60
+ () =>
61
+ props.infoData.data.find((item) =>
62
+ item.label.toLowerCase().includes('capacity')
63
+ ) || null
64
+ )
65
+
66
+ const consumedItem = computed<UI_I_UtilizationDataItems | null>(
67
+ () =>
68
+ props.infoData.data.find((item) =>
69
+ item.label.toLowerCase().includes('consumed')
70
+ ) || null
71
+ )
72
+
73
+ const usageItem = computed<UI_I_UtilizationDataItems | null>(
74
+ () =>
75
+ props.infoData.data.find((item) =>
76
+ item.label.toLowerCase().includes('usagepercent')
77
+ ) || null
78
+ )
79
+ const currentTitle = computed<string>(
80
+ () =>
81
+ `${consumedItem.value?.value} / ${maxItem.value?.value} - ${usageItem.value?.value}`
82
+ )
83
+
84
+ const barPercent = computed<string>(() => {
85
+ const parse = (v: string) => parseFloat(v.replace(/[^\d.]/g, '')) || 0
86
+ if (!maxItem.value || !consumedItem.value) return '0'
87
+ return String(
88
+ Math.min(
89
+ (parse(consumedItem.value.value) / parse(maxItem.value.value)) * 100,
90
+ 100
91
+ )
92
+ )
93
+ })
94
+
95
+ onMounted(() => {
96
+ setTimeout(() => (animated.value = true), 100)
97
+ })
98
+ </script>
99
+
100
+ <style scoped lang="scss">
101
+ .utilization-info-block {
102
+ width: 522px;
103
+ padding: 20px;
104
+ border: 1px solid #ccc;
105
+ border-radius: 4px;
106
+ box-shadow: 0px 0px 2px #ccc;
107
+
108
+ .header-block {
109
+ margin-bottom: 20px;
110
+
111
+ .title {
112
+ font-size: 16px;
113
+ font-weight: 500;
114
+ }
115
+ }
116
+
117
+ .body-block {
118
+ display: flex;
119
+ flex-direction: column;
120
+ gap: 8px;
121
+ margin-bottom: 20px;
122
+
123
+ .bar {
124
+ .track {
125
+ height: 18px;
126
+ background: #e5e7eb;
127
+ border-radius: 4px;
128
+ overflow: hidden;
129
+ border: 1px solid gray;
130
+ }
131
+
132
+ .fill {
133
+ height: 100%;
134
+ border-radius: 2px;
135
+ transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
136
+ }
137
+ }
138
+ .footer-body-block {
139
+ display: flex;
140
+ align-items: center;
141
+ justify-content: space-between;
142
+
143
+ p {
144
+ font-size: 11px;
145
+ }
146
+ }
147
+ }
148
+
149
+ .footer-block {
150
+ display: grid;
151
+ grid-row-gap: 5px;
152
+ width: 70%;
153
+
154
+ .footer-item {
155
+ display: grid;
156
+ align-items: center;
157
+ gap: 5px;
158
+ grid-template-columns: 70% 30%;
159
+
160
+ .left-block {
161
+ display: flex;
162
+ align-items: center;
163
+ gap: 5px;
164
+
165
+ .color-block {
166
+ width: 15px;
167
+ height: 15px;
168
+ border: 1px solid black;
169
+ border-radius: 4px;
170
+ }
171
+
172
+ .name {
173
+ font-size: 14px;
174
+ font-weight: 500;
175
+ }
176
+ }
177
+
178
+ .value {
179
+ font-size: 14px;
180
+ font-weight: 500;
181
+ }
182
+ }
183
+ }
184
+ }
185
+ </style>
@@ -0,0 +1,4 @@
1
+ export enum UI_E_UtilizationBlockCurrentKeys {
2
+ cpuUtilization = 'hostCpu',
3
+ hostMemoryUtilization = 'hostMem',
4
+ }
@@ -0,0 +1,25 @@
1
+ export interface API_UI_I_UtilizationDataItems {
2
+ label: string
3
+ value: string
4
+ }
5
+
6
+ export interface API_UI_I_UtilizationDataItem {
7
+ items: API_UI_I_UtilizationDataItems[]
8
+ }
9
+
10
+ export interface API_UI_I_UtilizationData {
11
+ [key: string]: API_UI_I_UtilizationDataItem
12
+ }
13
+
14
+ export interface UI_I_UtilizationDataItems {
15
+ label: string
16
+ value: string
17
+ color: string
18
+ }
19
+
20
+ export interface UI_I_UtilizationDataItem {
21
+ id: string
22
+ isShow: boolean
23
+ title: string
24
+ data: UI_I_UtilizationDataItems[]
25
+ }
@@ -0,0 +1,31 @@
1
+ import type {
2
+ API_UI_I_UtilizationData,
3
+ UI_I_UtilizationDataItem,
4
+ } from '~/components/common/monitor/utilization/lib/models/interfaces'
5
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
6
+ import { UI_E_UtilizationBlockCurrentKeys } from '~/components/common/monitor/utilization/lib/models/enums'
7
+
8
+ export const constructApiData = (
9
+ apiData: API_UI_I_UtilizationData,
10
+ localization: UI_I_Localization
11
+ ): UI_I_UtilizationDataItem[] => {
12
+ const result: UI_I_UtilizationDataItem[] = []
13
+ Object.keys(apiData).forEach((key) => {
14
+ result.push({
15
+ id: key,
16
+ isShow: true,
17
+ title: localization.common[UI_E_UtilizationBlockCurrentKeys[key]],
18
+ data: apiData[key].items.map((item) => {
19
+ item.color = !item.label.toLowerCase().includes('capacity')
20
+ ? '#' +
21
+ Math.floor(Math.random() * 0xffffff)
22
+ .toString(16)
23
+ .padStart(6, '0')
24
+ : ''
25
+
26
+ return item
27
+ }),
28
+ })
29
+ })
30
+ return result
31
+ }
@@ -1,6 +1,6 @@
1
1
  <template>
2
2
  <common-modals-confirmation
3
- :headline="localization.common.consolidateConfirmation"
3
+ :headline="localization.snapshots.consolidateSnapshots"
4
4
  :description="localization.common.consolidateConfirmationDesc"
5
5
  :modal-texts="modalTexts"
6
6
  @hide-modal="emits('hide-modal')"
@@ -1,7 +1,7 @@
1
1
  <template>
2
2
  <common-modals-confirmation
3
- :headline="localization.common.consolidate"
4
- :description="localization.common.consolidateConfirmationDescOld"
3
+ :headline="localization.snapshots.consolidateSnapshots"
4
+ :description="localization.common.consolidateConfirmationDesc"
5
5
  @hide-modal="emits('hide-modal')"
6
6
  @confirm="emits('confirm')"
7
7
  />