bfg-common 1.5.727 → 1.5.728

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 (112) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  3. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  4. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  5. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  6. package/assets/localization/local_be.json +2 -0
  7. package/assets/localization/local_en.json +2 -0
  8. package/assets/localization/local_hy.json +2 -0
  9. package/assets/localization/local_kk.json +2 -0
  10. package/assets/localization/local_ru.json +2 -0
  11. package/assets/localization/local_zh.json +2 -0
  12. package/components/atoms/TheIcon3.vue +50 -50
  13. package/components/atoms/collapse/CollapseNav.vue +170 -170
  14. package/components/atoms/perPage/PerPage.vue +58 -58
  15. package/components/atoms/table/dataGrid/DataGrid.vue +1718 -1718
  16. package/components/atoms/table/dataGrid/DataGridPagination.vue +97 -97
  17. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  18. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  19. package/components/common/backup/storage/actions/add/lib/utils.ts +51 -51
  20. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  21. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  22. package/components/common/diagramMain/port/Port.vue +580 -580
  23. package/components/common/layout/console/Console.vue +70 -70
  24. package/components/common/layout/theHeader/New.vue +301 -301
  25. package/components/common/layout/theHeader/Old.vue +252 -252
  26. package/components/common/layout/theHeader/TheHeader.vue +152 -152
  27. package/components/common/layout/theHeader/userMenu/UserMenu.vue +104 -104
  28. package/components/common/layout/theHeader/userMenu/modals/preferences/lib/models/types.ts +7 -7
  29. package/components/common/pages/backups/DetailView.vue +52 -52
  30. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  31. package/components/common/pages/backups/modals/Modals.vue +243 -243
  32. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  33. package/components/common/pages/backups/modals/createBackup/lib/config/readyToCompleteOptions.ts +69 -69
  34. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  35. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  36. package/components/common/pages/backups/modals/restore/Restore.vue +289 -303
  37. package/components/common/pages/backups/modals/restore/lib/config/readyToCompleteOptions.ts +84 -84
  38. package/components/common/pages/backups/modals/restore/lib/config/restoreCodes.ts +2 -1
  39. package/components/common/pages/backups/modals/restore/lib/config/steps.ts +121 -113
  40. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  41. package/components/common/pages/backups/modals/restore/types/{TypesNew.vue → New.vue} +95 -95
  42. package/components/common/pages/backups/modals/restore/types/{TypesOld.vue → Old.vue} +62 -61
  43. package/components/common/pages/backups/modals/restore/types/Types.vue +31 -19
  44. package/components/common/pages/backups/modals/restore/types/lib/config/descriptions.ts +1 -0
  45. package/components/common/pages/backups/modals/restore/types/lib/config/typeOptions.ts +5 -0
  46. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  47. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  48. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  49. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  50. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  51. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  52. package/components/common/pages/tasks/Tasks.vue +125 -125
  53. package/components/common/pages/tasks/table/Table.vue +373 -373
  54. package/components/common/pages/tasks/table/lib/config/config.ts +279 -279
  55. package/components/common/pages/tasks/table/lib/models/interfaces.ts +9 -9
  56. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  57. package/components/common/select/radio/RadioGroup.vue +137 -137
  58. package/components/common/spiceConsole/Drawer.vue +420 -420
  59. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  60. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  61. package/components/common/tools/Actions.vue +207 -207
  62. package/components/common/treeView/TreeView.vue +52 -52
  63. package/components/common/vm/actions/clone/lib/config/steps.ts +295 -295
  64. package/components/common/vm/actions/clone/new/New.vue +438 -438
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +283 -283
  67. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +156 -156
  68. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  69. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  70. package/components/common/vm/actions/common/select/options/New.vue +264 -264
  71. package/components/common/vm/actions/common/select/options/Options.vue +58 -58
  72. package/components/common/vm/actions/common/select/storage/Old.vue +125 -125
  73. package/components/common/vm/actions/common/select/storage/new/New.vue +311 -311
  74. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  75. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  76. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  77. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  78. package/components/common/wizards/common/compatibility/Compatibility.vue +35 -35
  79. package/components/common/wizards/common/steps/computeResource/New.vue +93 -93
  80. package/components/common/wizards/common/steps/name/Name.vue +178 -178
  81. package/components/common/wizards/common/steps/name/New.vue +221 -221
  82. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  83. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  84. package/components/common/wizards/common/steps/name/location/New.vue +40 -40
  85. package/components/common/wizards/datastore/add/Add.vue +228 -228
  86. package/components/common/wizards/datastore/add/lib/utils.ts +85 -85
  87. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  88. package/composables/useAppVersion.ts +21 -21
  89. package/composables/useBrowse.ts +24 -24
  90. package/composables/useLocal.ts +6 -6
  91. package/composables/useLocalCommon.ts +39 -39
  92. package/lib/models/types.ts +59 -59
  93. package/package.json +2 -2
  94. package/plugins/console.ts +21 -21
  95. package/plugins/mouse.ts +21 -21
  96. package/plugins/panelStates.ts +70 -70
  97. package/plugins/text.ts +59 -59
  98. package/public/spice-console/application/clientgui.js +854 -854
  99. package/public/spice-console/application/packetfactory.js +211 -211
  100. package/public/spice-console/application/virtualmouse.js +147 -147
  101. package/public/spice-console/lib/images/bitmap.js +203 -203
  102. package/public/spice-console/network/spicechannel.js +440 -440
  103. package/public/spice-console/process/cursorprocess.js +128 -128
  104. package/public/spice-console/process/inputprocess.js +227 -227
  105. package/public/spice-console/process/mainprocess.js +212 -212
  106. package/public/spice-console/run.js +210 -210
  107. package/store/main/mutations.ts +7 -7
  108. package/store/main/state.ts +7 -7
  109. package/store/tasks/mappers/recentTasks.ts +123 -123
  110. package/store/tasks/mutations.ts +82 -82
  111. /package/components/common/pages/backups/modals/restore/{RestoreNew.vue → New.vue} +0 -0
  112. /package/components/common/pages/backups/modals/restore/{RestoreOld.vue → Old.vue} +0 -0
@@ -1,303 +1,289 @@
1
- <template>
2
- <common-pages-backups-modals-restore-new
3
- v-if="isNewView"
4
- v-model="model"
5
- v-model:is-show-confirm="isShowConfirm"
6
- :wizard="wizard"
7
- :selected-scheme="selectedScheme"
8
- :alert-messages="alertMessages"
9
- :storage-submit="storageSubmit"
10
- :datastore="props.datastore"
11
- :datastore-loading="props.datastoreLoading"
12
- :networks="props.networks"
13
- :ready-complete-data="readyToCompleteInfo"
14
- :selected-storage="selectedStorage"
15
- @change-storage="onChangeStorage"
16
- @get-datastore="getDatastoreTableFunc"
17
- @get-networks="onGetNetworks"
18
- @change-steps="onChangeSteps"
19
- @submit-confirm="onFinish"
20
- @hide="onHideModal"
21
- @submit-wizard="onSubmitWizard"
22
- />
23
- <common-pages-backups-modals-restore-old
24
- v-else
25
- v-model="model"
26
- v-model:is-show-confirm="isShowConfirm"
27
- :wizard="wizard"
28
- :selected-scheme="selectedScheme"
29
- :ready-complete-data="readyToCompleteInfo"
30
- :storage-submit="storageSubmit"
31
- :is-loading="isLoading"
32
- :errors="errors"
33
- :datastore="props.datastore"
34
- :datastore-loading="props.datastoreLoading"
35
- :networks="props.networks"
36
- @remove-validation-errors="onRemoveValidationErrors"
37
- @change-storage="onChangeStorage"
38
- @get-datastore="getDatastoreTableFunc"
39
- @get-networks="onGetNetworks"
40
- @change-steps="onChangeSteps"
41
- @submit-confirm="onFinish"
42
- @hide="onHideModal"
43
- @submit-wizard="onSubmitWizard"
44
- />
45
- </template>
46
-
47
- <script setup lang="ts">
48
- import type {
49
- UI_I_WizardStep,
50
- UI_I_ValidationReturn,
51
- } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/interfaces'
52
- import Wizard from '~/node_modules/bfg-uikit/components/ui/wizard/lib/utils/utils'
53
- import type { UI_I_Localization } from '~/lib/models/interfaces'
54
- import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
55
- import type { UI_I_TableInfoItem } from '~/components/atoms/table/info/lib/models/interfaces'
56
- import type { UI_I_NetworkTableItem } from '~/lib/models/store/network/interfaces'
57
- import type { UI_I_NameCheck } from '~/components/common/pages/backups/modals/restore/name/lib/models/interfaces'
58
- import type { UI_I_RestoreForm } from '~/components/common/pages/backups/modals/lib/models/interfaces'
59
- import {
60
- stepsSchemeInitial,
61
- stepsFunc,
62
- dynamicSteps,
63
- } from '~/components/common/pages/backups/modals/restore/lib/config/steps'
64
- import { restoreCodes } from '~/components/common/pages/backups/modals/restore/lib/config/restoreCodes'
65
- import { readyToCompleteOptions } from '~/components/common/pages/backups/modals/restore/lib/config/readyToCompleteOptions'
66
- import {
67
- checkDisksValidation,
68
- checkNameValidation,
69
- } from '~/components/common/pages/backups/modals/restore/validation/validation'
70
-
71
- const model = defineModel<UI_I_RestoreForm>({ required: true })
72
-
73
- const props = defineProps<{
74
- datastore: UI_I_DatastoreTableItem[]
75
- datastoreLoading: boolean
76
- networks: UI_I_NetworkTableItem[]
77
- }>()
78
- const emits = defineEmits<{
79
- (event: 'get-datastore', value: string): void
80
- (event: 'get-networks', value: string): void
81
- (event: 'check-name', value: UI_I_NameCheck): void
82
- (event: 'finish'): void
83
- (event: 'hide'): void
84
- }>()
85
-
86
- const { $store }: any = useNuxtApp()
87
-
88
- const localization = computed<UI_I_Localization>(() => useLocal())
89
-
90
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
91
-
92
- const wizard: Wizard = new Wizard(
93
- stepsFunc(localization.value),
94
- stepsSchemeInitial
95
- )
96
- const alertMessages = computed<string[][]>(() => wizard.alertMessages.value)
97
-
98
- watch(
99
- () => model.value.restore_code,
100
- (newValue) => {
101
- wizard.changeScheme(newValue - 1)
102
- },
103
- { immediate: true }
104
- )
105
- const selectedScheme = computed<number[]>(() => wizard.selectedScheme.value)
106
- const onChangeSteps = async (value: UI_I_WizardStep[]): Promise<void> => {
107
- wizard.changeSteps(value, validationFunc)
108
- }
109
-
110
- const storageSubmit = ref<null | Function>(null)
111
-
112
- const validationFunc = async (
113
- value: UI_I_WizardStep[],
114
- currentStep: UI_I_WizardStep,
115
- nextStep: UI_I_WizardStep
116
- ): Promise<UI_I_ValidationReturn> => {
117
- let stepHasError = false
118
- const stepShouldStop = {
119
- ifOnCurrentStep: false,
120
- ifFromAnyStep: false,
121
- stoppageStepId: -1,
122
- }
123
-
124
- wizard.setLoader(true)
125
-
126
- if (
127
- wizard.isValidateForStep(
128
- dynamicSteps.selectName,
129
- currentStep.id,
130
- nextStep.id
131
- )
132
- ) {
133
- const nameValidation = await checkNameValidation(
134
- value,
135
- model.value.pvm.name,
136
- wizard,
137
- localization.value,
138
- showValidationErrors,
139
- onRemoveValidationErrors,
140
- emits
141
- )
142
-
143
- value = nameValidation.newValue
144
- stepHasError = stepHasError || nameValidation.stepHasError
145
- }
146
-
147
- if (
148
- wizard.isValidateForStep(
149
- dynamicSteps.selectStorage,
150
- currentStep.id,
151
- nextStep.id
152
- )
153
- ) {
154
- const validation = await checkStorage(value)
155
-
156
- value = validation.newValue
157
- stepHasError = stepHasError || validation.stepHasError
158
- }
159
-
160
- if (
161
- wizard.isValidateForStep(
162
- dynamicSteps.selectDisks,
163
- currentStep.id,
164
- nextStep.id
165
- )
166
- ) {
167
- const validation = checkDisksValidation(
168
- value,
169
- !!model.value?.pvm.disk_devices.length,
170
- wizard,
171
- localization.value,
172
- showValidationErrors,
173
- onRemoveValidationErrors
174
- )
175
-
176
- value = validation.newValue
177
- stepHasError = stepHasError || validation.stepHasError
178
- }
179
-
180
- wizard.setLoader(false)
181
-
182
- return {
183
- newValue: value,
184
- stepHasError,
185
- stepShouldStop,
186
- }
187
- }
188
-
189
- const checkStorage = async (
190
- value: UI_I_WizardStep[]
191
- ): Promise<UI_I_ValidationReturn> => {
192
- let stepHasError = false
193
-
194
- return new Promise((resolve) => {
195
- storageSubmit.value = (isValid: boolean): void => {
196
- if (!isValid) {
197
- stepHasError = wizard.setValidation(
198
- dynamicSteps.selectStorage,
199
- 'storage',
200
- {
201
- fieldMessage: localization.value.common.selectStorage,
202
- alertMessage:
203
- localization.value.common.selectValidDestinationStorage,
204
- }
205
- )
206
- } else if (wizard.hasMessage(dynamicSteps.selectStorage, 'storage')) {
207
- value = wizard.removeValidation(
208
- dynamicSteps.selectStorage,
209
- 'storage',
210
- value
211
- )
212
- }
213
-
214
- resolve({
215
- stepHasError,
216
- newValue: value,
217
- })
218
- storageSubmit.value = null
219
- }
220
- })
221
- }
222
-
223
- const getDatastoreTableFunc = async (): Promise<void> => {
224
- emits('get-datastore', model.value.bucket)
225
- }
226
-
227
- const selectedStorageName = ref<string>('')
228
- const selectedStorage = ref<UI_I_DatastoreTableItem | null>(null)
229
- const onChangeStorage = (storage: UI_I_DatastoreTableItem | null): void => {
230
- if (!storage) return
231
-
232
- selectedStorageName.value = storage.name
233
- selectedStorage.value = storage
234
- model.value.pvm.storage = {
235
- id: storage.id,
236
- folder: '',
237
- }
238
- }
239
-
240
- const isLoading = ref<boolean>(true)
241
- // В Сфере и Прокураторе одно и тоже
242
- const getPvm = async (): Promise<void> => {
243
- await $store.dispatch('backup/A_GET_PVM', {
244
- target: model.value.backup_storage,
245
- bucketId: model.value.bucket, // TODO bucket поменять на vm так как это сейчас vm
246
- backupId: model.value.backup,
247
- })
248
-
249
- model.value.pvm = useDeepCopy($store.getters['backup/getPvm'])
250
- model.value.pvm.disk_devices = [] // ToDo если не обнулить тогда в форме всегда будет выбранны диски
251
- isLoading.value = false
252
- }
253
- getPvm()
254
-
255
- const readyToCompleteInfo = computed<UI_I_TableInfoItem[]>(() =>
256
- readyToCompleteOptions(
257
- model.value,
258
- localization.value,
259
- selectedStorageName.value
260
- )
261
- )
262
-
263
- const errors = ref<string[]>([])
264
- const showValidationErrors = (data: string[]): void => {
265
- errors.value = data
266
- }
267
- const onRemoveValidationErrors = (): void => {
268
- errors.value = []
269
- }
270
-
271
- const onFinish = (): void => {
272
- emits('finish')
273
- }
274
- const onHideModal = (): void => {
275
- emits('hide')
276
- }
277
-
278
- const isShowConfirm = ref<boolean>(false)
279
-
280
- const onSubmitWizard = (): void => {
281
- if (model.value.restore_code === restoreCodes.existing) {
282
- isShowConfirm.value = true
283
- } else {
284
- onFinish()
285
- }
286
- }
287
-
288
- const onGetNetworks = (hostId: string): void => {
289
- emits('get-networks', hostId)
290
- }
291
- </script>
292
-
293
- <style scoped lang="scss">
294
- :deep(.modal-body) {
295
- display: flex;
296
- flex-direction: column;
297
- }
298
-
299
- .loader-wrap {
300
- background-color: rgba(0, 0, 0, 0.3);
301
- z-index: var(--z-fixed);
302
- }
303
- </style>
1
+ <template>
2
+ <component
3
+ :is="currentComponent"
4
+ v-model="model"
5
+ v-model:is-show-confirm="isShowConfirm"
6
+ :wizard="wizard"
7
+ :selected-scheme="selectedScheme"
8
+ :alert-messages="alertMessages"
9
+ :storage-submit="storageSubmit"
10
+ :datastore="props.datastore"
11
+ :datastore-loading="props.datastoreLoading"
12
+ :networks="props.networks"
13
+ :ready-complete-data="readyToCompleteInfo"
14
+ :selected-storage="selectedStorage"
15
+ :is-loading="isLoading"
16
+ :errors="errors"
17
+ @change-storage="onChangeStorage"
18
+ @get-datastore="getDatastoreTableFunc"
19
+ @get-networks="onGetNetworks"
20
+ @change-steps="onChangeSteps"
21
+ @submit-confirm="onFinish"
22
+ @hide="onHideModal"
23
+ @submit-wizard="onSubmitWizard"
24
+ @remove-validation-errors="onRemoveValidationErrors"
25
+ />
26
+ </template>
27
+
28
+ <script setup lang="ts">
29
+ import type {
30
+ UI_I_WizardStep,
31
+ UI_I_ValidationReturn,
32
+ } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/interfaces'
33
+ import Wizard from '~/node_modules/bfg-uikit/components/ui/wizard/lib/utils/utils'
34
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
35
+ import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
36
+ import type { UI_I_TableInfoItem } from '~/components/atoms/table/info/lib/models/interfaces'
37
+ import type { UI_I_NetworkTableItem } from '~/lib/models/store/network/interfaces'
38
+ import type { UI_I_NameCheck } from '~/components/common/pages/backups/modals/restore/name/lib/models/interfaces'
39
+ import type { UI_I_RestoreForm } from '~/components/common/pages/backups/modals/lib/models/interfaces'
40
+ import {
41
+ stepsSchemeInitial,
42
+ stepsFunc,
43
+ dynamicSteps,
44
+ } from '~/components/common/pages/backups/modals/restore/lib/config/steps'
45
+ import { restoreCodes } from '~/components/common/pages/backups/modals/restore/lib/config/restoreCodes'
46
+ import { readyToCompleteOptions } from '~/components/common/pages/backups/modals/restore/lib/config/readyToCompleteOptions'
47
+ import {
48
+ checkDisksValidation,
49
+ checkNameValidation,
50
+ } from '~/components/common/pages/backups/modals/restore/validation/validation'
51
+
52
+ const model = defineModel<UI_I_RestoreForm>({ required: true })
53
+
54
+ const props = defineProps<{
55
+ datastore: UI_I_DatastoreTableItem[]
56
+ datastoreLoading: boolean
57
+ networks: UI_I_NetworkTableItem[]
58
+ }>()
59
+ const emits = defineEmits<{
60
+ (event: 'get-datastore', value: string): void
61
+ (event: 'get-networks', value: string): void
62
+ (event: 'check-name', value: UI_I_NameCheck): void
63
+ (event: 'finish'): void
64
+ (event: 'hide'): void
65
+ }>()
66
+
67
+ const { $store }: any = useNuxtApp()
68
+
69
+ const localization = computed<UI_I_Localization>(() => useLocal())
70
+
71
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
72
+ const currentComponent = computed(() =>
73
+ isNewView.value
74
+ ? defineAsyncComponent(() => import('./New.vue'))
75
+ : defineAsyncComponent(() => import('./Old.vue'))
76
+ )
77
+
78
+ const wizard: Wizard = new Wizard(
79
+ stepsFunc(localization.value),
80
+ stepsSchemeInitial
81
+ )
82
+ const alertMessages = computed<string[][]>(() => wizard.alertMessages.value)
83
+
84
+ watch(
85
+ () => model.value.restore_code,
86
+ (newValue) => {
87
+ wizard.changeScheme(newValue - 1)
88
+ },
89
+ { immediate: true }
90
+ )
91
+ const selectedScheme = computed<number[]>(() => wizard.selectedScheme.value)
92
+ const onChangeSteps = async (value: UI_I_WizardStep[]): Promise<void> => {
93
+ wizard.changeSteps(value, validationFunc)
94
+ }
95
+
96
+ const storageSubmit = ref<null | Function>(null)
97
+
98
+ const validationFunc = async (
99
+ value: UI_I_WizardStep[],
100
+ currentStep: UI_I_WizardStep,
101
+ nextStep: UI_I_WizardStep
102
+ ): Promise<UI_I_ValidationReturn> => {
103
+ let stepHasError = false
104
+ const stepShouldStop = {
105
+ ifOnCurrentStep: false,
106
+ ifFromAnyStep: false,
107
+ stoppageStepId: -1,
108
+ }
109
+
110
+ wizard.setLoader(true)
111
+
112
+ if (
113
+ wizard.isValidateForStep(
114
+ dynamicSteps.selectName,
115
+ currentStep.id,
116
+ nextStep.id
117
+ )
118
+ ) {
119
+ const nameValidation = await checkNameValidation(
120
+ value,
121
+ model.value.pvm.name,
122
+ wizard,
123
+ localization.value,
124
+ showValidationErrors,
125
+ onRemoveValidationErrors,
126
+ emits
127
+ )
128
+
129
+ value = nameValidation.newValue
130
+ stepHasError = stepHasError || nameValidation.stepHasError
131
+ }
132
+
133
+ if (
134
+ wizard.isValidateForStep(
135
+ dynamicSteps.selectStorage,
136
+ currentStep.id,
137
+ nextStep.id
138
+ )
139
+ ) {
140
+ const validation = await checkStorage(value)
141
+
142
+ value = validation.newValue
143
+ stepHasError = stepHasError || validation.stepHasError
144
+ }
145
+
146
+ if (
147
+ wizard.isValidateForStep(
148
+ dynamicSteps.selectDisks,
149
+ currentStep.id,
150
+ nextStep.id
151
+ )
152
+ ) {
153
+ const validation = checkDisksValidation(
154
+ value,
155
+ !!model.value?.pvm.disk_devices.length,
156
+ wizard,
157
+ localization.value,
158
+ showValidationErrors,
159
+ onRemoveValidationErrors
160
+ )
161
+
162
+ value = validation.newValue
163
+ stepHasError = stepHasError || validation.stepHasError
164
+ }
165
+
166
+ wizard.setLoader(false)
167
+
168
+ return {
169
+ newValue: value,
170
+ stepHasError,
171
+ stepShouldStop,
172
+ }
173
+ }
174
+
175
+ const checkStorage = async (
176
+ value: UI_I_WizardStep[]
177
+ ): Promise<UI_I_ValidationReturn> => {
178
+ let stepHasError = false
179
+
180
+ return new Promise((resolve) => {
181
+ storageSubmit.value = (isValid: boolean): void => {
182
+ if (!isValid) {
183
+ stepHasError = wizard.setValidation(
184
+ dynamicSteps.selectStorage,
185
+ 'storage',
186
+ {
187
+ fieldMessage: localization.value.common.selectStorage,
188
+ alertMessage:
189
+ localization.value.common.selectValidDestinationStorage,
190
+ }
191
+ )
192
+ } else if (wizard.hasMessage(dynamicSteps.selectStorage, 'storage')) {
193
+ value = wizard.removeValidation(
194
+ dynamicSteps.selectStorage,
195
+ 'storage',
196
+ value
197
+ )
198
+ }
199
+
200
+ resolve({
201
+ stepHasError,
202
+ newValue: value,
203
+ })
204
+ storageSubmit.value = null
205
+ }
206
+ })
207
+ }
208
+
209
+ const getDatastoreTableFunc = async (): Promise<void> => {
210
+ emits('get-datastore', model.value.bucket)
211
+ }
212
+
213
+ const selectedStorageName = ref<string>('')
214
+ const selectedStorage = ref<UI_I_DatastoreTableItem | null>(null)
215
+ const onChangeStorage = (storage: UI_I_DatastoreTableItem | null): void => {
216
+ if (!storage) return
217
+
218
+ selectedStorageName.value = storage.name
219
+ selectedStorage.value = storage
220
+ model.value.pvm.storage = {
221
+ id: storage.id,
222
+ folder: '',
223
+ }
224
+ }
225
+
226
+ const isLoading = ref<boolean>(true)
227
+ // В Сфере и Прокураторе одно и тоже
228
+ const getPvm = async (): Promise<void> => {
229
+ await $store.dispatch('backup/A_GET_PVM', {
230
+ target: model.value.backup_storage,
231
+ bucketId: model.value.bucket, // TODO bucket поменять на vm так как это сейчас vm
232
+ backupId: model.value.backup,
233
+ })
234
+
235
+ model.value.pvm = useDeepCopy($store.getters['backup/getPvm'])
236
+ model.value.pvm.disk_devices = [] // ToDo если не обнулить тогда в форме всегда будет выбранны диски
237
+ isLoading.value = false
238
+ }
239
+ getPvm()
240
+
241
+ const readyToCompleteInfo = computed<UI_I_TableInfoItem[]>(() =>
242
+ readyToCompleteOptions(
243
+ model.value,
244
+ localization.value,
245
+ selectedStorageName.value
246
+ )
247
+ )
248
+
249
+ const errors = ref<string[]>([])
250
+ const showValidationErrors = (data: string[]): void => {
251
+ errors.value = data
252
+ }
253
+ const onRemoveValidationErrors = (): void => {
254
+ errors.value = []
255
+ }
256
+
257
+ const onFinish = (): void => {
258
+ emits('finish')
259
+ }
260
+ const onHideModal = (): void => {
261
+ emits('hide')
262
+ }
263
+
264
+ const isShowConfirm = ref<boolean>(false)
265
+
266
+ const onSubmitWizard = (): void => {
267
+ if (model.value.restore_code === restoreCodes.existing) {
268
+ isShowConfirm.value = true
269
+ } else {
270
+ onFinish()
271
+ }
272
+ }
273
+
274
+ const onGetNetworks = (hostId: string): void => {
275
+ emits('get-networks', hostId)
276
+ }
277
+ </script>
278
+
279
+ <style scoped lang="scss">
280
+ :deep(.modal-body) {
281
+ display: flex;
282
+ flex-direction: column;
283
+ }
284
+
285
+ .loader-wrap {
286
+ background-color: rgba(0, 0, 0, 0.3);
287
+ z-index: var(--z-fixed);
288
+ }
289
+ </style>