bfg-common 1.5.524 → 1.5.525

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 (115) 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/components/atoms/TheIcon3.vue +50 -50
  7. package/components/atoms/collapse/CollapseNav.vue +170 -170
  8. package/components/atoms/perPage/PerPage.vue +58 -58
  9. package/components/atoms/table/dataGrid/DataGridPagination.vue +97 -97
  10. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  11. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  12. package/components/common/backup/storage/actions/add/Add.vue +251 -251
  13. package/components/common/backup/storage/actions/add/lib/utils.ts +51 -51
  14. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  15. package/components/common/diagramMain/modals/lib/config/portModal.ts +251 -251
  16. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  17. package/components/common/diagramMain/port/Port.vue +580 -580
  18. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  19. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  20. package/components/common/pages/backups/DetailView.vue +52 -52
  21. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  22. package/components/common/pages/backups/modals/Modals.vue +243 -243
  23. package/components/common/pages/backups/modals/createBackup/CreateBackup.vue +195 -195
  24. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  25. package/components/common/pages/backups/modals/createBackup/lib/config/readyToCompleteOptions.ts +69 -69
  26. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  27. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  28. package/components/common/pages/backups/modals/restore/disks/Disks.vue +27 -27
  29. package/components/common/pages/backups/modals/restore/disks/tableView/lib/config/table.ts +117 -117
  30. package/components/common/pages/backups/modals/restore/name/Name.vue +166 -166
  31. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  32. package/components/common/pages/backups/modals/restore/networks/Networks.vue +67 -67
  33. package/components/common/pages/backups/modals/restore/networks/table/Table.vue +214 -214
  34. package/components/common/pages/backups/modals/restore/types/lib/config/typeOptions.ts +25 -25
  35. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  36. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  37. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  38. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  39. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  40. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  41. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  42. package/components/common/select/radio/RadioGroup.vue +137 -137
  43. package/components/common/spiceConsole/Drawer.vue +420 -420
  44. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  45. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  46. package/components/common/tools/Actions.vue +207 -207
  47. package/components/common/treeView/TreeView.vue +52 -52
  48. package/components/common/vm/actions/add/Add.vue +895 -895
  49. package/components/common/vm/actions/add/New.vue +695 -695
  50. package/components/common/vm/actions/add/Old.vue +414 -414
  51. package/components/common/vm/actions/add/lib/config/steps.ts +347 -347
  52. package/components/common/vm/actions/clone/Clone.vue +754 -863
  53. package/components/common/vm/actions/clone/cloneNew/CloneNew.vue +434 -0
  54. package/components/common/vm/actions/clone/cloneOld/CloneOld.vue +382 -0
  55. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +368 -368
  56. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  57. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  58. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +427 -427
  59. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  60. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/Table.vue +99 -99
  61. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  62. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  63. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  64. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  65. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  66. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  67. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  68. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  69. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  70. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  71. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  72. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +143 -143
  73. package/components/common/vm/actions/common/select/computeResource/New.vue +184 -184
  74. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +131 -131
  75. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  76. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  77. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  78. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  79. package/components/common/vm/actions/common/select/storage/new/New.vue +330 -320
  80. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  81. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  82. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  83. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  84. package/components/common/vm/actions/register/Register.vue +285 -285
  85. package/components/common/vm/actions/register/lib/config/steps.ts +86 -86
  86. package/components/common/wizards/common/steps/name/Name.vue +179 -179
  87. package/components/common/wizards/common/steps/name/New.vue +221 -221
  88. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  89. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  90. package/components/common/wizards/common/steps/name/location/Location.vue +85 -85
  91. package/components/common/wizards/common/steps/name/location/New.vue +40 -40
  92. package/components/common/wizards/datastore/add/Add.vue +228 -228
  93. package/components/common/wizards/datastore/add/lib/utils.ts +85 -85
  94. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  95. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  96. package/composables/useAppVersion.ts +21 -21
  97. package/composables/useLocal.ts +6 -6
  98. package/composables/useLocalCommon.ts +39 -39
  99. package/package.json +1 -1
  100. package/plugins/console.ts +21 -21
  101. package/plugins/date.ts +233 -233
  102. package/plugins/mouse.ts +21 -21
  103. package/plugins/panelStates.ts +70 -70
  104. package/plugins/text.ts +59 -59
  105. package/public/spice-console/application/clientgui.js +854 -854
  106. package/public/spice-console/application/packetfactory.js +211 -211
  107. package/public/spice-console/application/virtualmouse.js +147 -147
  108. package/public/spice-console/lib/images/bitmap.js +203 -203
  109. package/public/spice-console/network/spicechannel.js +440 -440
  110. package/public/spice-console/process/cursorprocess.js +121 -121
  111. package/public/spice-console/process/inputprocess.js +227 -227
  112. package/public/spice-console/process/mainprocess.js +210 -210
  113. package/public/spice-console/run.js +210 -210
  114. package/store/main/mutations.ts +7 -7
  115. package/store/main/state.ts +7 -7
@@ -1,251 +1,251 @@
1
- <template>
2
- <common-backup-storage-actions-add-new
3
- v-if="isNewView"
4
- v-model="form"
5
- :project="props.project"
6
- :wizard="wizard"
7
- :selected-scheme="selectedScheme"
8
- :alert-messages="alertMessages"
9
- :title="title"
10
- :hosts="props.hosts"
11
- :datastore="props.datastore"
12
- :is-datastore-loading="props.isDatastoreLoading"
13
- :get-datastore-table-func="props.getDatastoreTableFunc"
14
- @change-steps="onChangeSteps"
15
- @change-storage="onChangeStorage"
16
- @submit="onCreate"
17
- @hide="onHideModal"
18
- />
19
- <common-backup-storage-actions-add-old
20
- v-else
21
- v-model="form"
22
- :project="props.project"
23
- :wizard="wizard"
24
- :selected-scheme="selectedScheme"
25
- :alert-messages="alertMessages"
26
- :title="title"
27
- :hosts="props.hosts"
28
- :datastore="props.datastore"
29
- :is-datastore-loading="props.isDatastoreLoading"
30
- :get-datastore-table-func="props.getDatastoreTableFunc"
31
- @change-steps="onChangeSteps"
32
- @change-storage="onChangeStorage"
33
- @submit="onCreate"
34
- @hide="onHideModal"
35
- />
36
- </template>
37
-
38
- <script setup lang="ts">
39
- import type {
40
- UI_I_ValidationReturn,
41
- UI_I_WizardStep,
42
- } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/interfaces'
43
- import Wizard from '~/node_modules/bfg-uikit/components/ui/wizard/lib/utils/utils'
44
- import type { UI_T_Project } from '~/lib/models/types'
45
- import type { UI_I_CreateDatastoreForm } from '~/components/common/backup/storage/actions/add/lib/models/interfaces'
46
- import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
47
- import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
48
- import type { UI_I_Localization } from '~/lib/models/interfaces'
49
- import type { UI_T_DatastoreTypeCode } from '~/components/common/backup/storage/actions/add/lib/models/types'
50
- // TODO use from uikit
51
- import {
52
- stepsFunc,
53
- stepsSchemeInitial,
54
- } from '~/components/common/backup/storage/actions/add/lib/config/steps'
55
- import { datastoreDefaultFormFunc } from '~/components/common/backup/storage/actions/add/lib/config/createDatastore'
56
- import {
57
- dynamicSteps,
58
- getStepScheme,
59
- } from '~/components/common/backup/storage/actions/add/lib/config/steps'
60
- import * as validation from '~/components/common/backup/storage/actions/add/lib/validations'
61
-
62
- const props = withDefaults(
63
- defineProps<{
64
- project: UI_T_Project
65
- datastore: UI_I_DatastoreTableItem[]
66
- isDatastoreLoading: boolean
67
- getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
68
- hosts?: any[]
69
- datacenterId?: string
70
- }>(),
71
- { hosts: [], datacenterId: '' }
72
- )
73
- const emits = defineEmits<{
74
- (event: 'create', value: UI_I_CreateDatastoreForm): void
75
- (event: 'hide'): void
76
- }>()
77
-
78
- const { $store }: any = useNuxtApp()
79
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
80
-
81
- const localization = computed<UI_I_Localization>(() => useLocal())
82
-
83
- const title = ref(localization.value.common.newBackupStorage)
84
-
85
- const wizard: Wizard = new Wizard(
86
- stepsFunc(localization.value),
87
- stepsSchemeInitial
88
- )
89
-
90
- const selectedScheme = computed<number[]>(() => wizard.selectedScheme.value)
91
- const alertMessages = computed<string[][]>(() => wizard.alertMessages.value)
92
-
93
- const form = ref<UI_I_CreateDatastoreForm>(
94
- useDeepCopy(datastoreDefaultFormFunc())
95
- )
96
-
97
- const validationFunc = async (
98
- value: UI_I_WizardStep[],
99
- currentStep: UI_I_WizardStep,
100
- nextStep: UI_I_WizardStep
101
- ): Promise<UI_I_ValidationReturn> => {
102
- let stepHasError = false
103
-
104
- if (
105
- wizard.isValidateForStep(dynamicSteps.name, currentStep.id, nextStep.id)
106
- ) {
107
- const nameValidation = await validation.checkDatastoreNameAsync(
108
- localization.value,
109
- value,
110
- form.value,
111
- dynamicSteps.name,
112
- 'name',
113
- wizard,
114
- props.project,
115
- props.datacenterId
116
- )
117
-
118
- value = nameValidation.newValue
119
-
120
- stepHasError = nameValidation.stepHasError
121
- }
122
-
123
- if (
124
- wizard.isValidateForStep(
125
- dynamicSteps.nameAndConfigure,
126
- currentStep.id,
127
- nextStep.id
128
- )
129
- ) {
130
- const nameValidation = await validation.checkDatastoreNameAsync(
131
- localization.value,
132
- value,
133
- form.value,
134
- dynamicSteps.nameAndConfigure,
135
- 'name',
136
- wizard,
137
- props.project,
138
- props.datacenterId
139
- )
140
- value = nameValidation.newValue
141
-
142
- const folderValidation = validation.checkFolderSync(
143
- localization.value,
144
- form.value.folder,
145
- wizard,
146
- value
147
- )
148
- value = folderValidation.newValue
149
-
150
- const serverValidation = validation.checkServerSync(
151
- localization.value,
152
- form.value.server,
153
- wizard,
154
- value
155
- )
156
- value = serverValidation.newValue
157
-
158
- // PC-2542
159
- // const usernameValidation = validation.checkUsernameSync(
160
- // localization.value,
161
- // form.value.user,
162
- // wizard,
163
- // value
164
- // )
165
- // value = usernameValidation.newValue
166
-
167
- // const passwordValidation = validation.checkPasswordSync(
168
- // localization.value,
169
- // form.value.password,
170
- // wizard,
171
- // value
172
- // )
173
- // value = passwordValidation.newValue
174
-
175
- stepHasError =
176
- nameValidation.stepHasError ||
177
- folderValidation.stepHasError ||
178
- serverValidation.stepHasError
179
- }
180
-
181
- if (
182
- wizard.isValidateForStep(
183
- dynamicSteps.hostAccessibility,
184
- currentStep.id,
185
- nextStep.id
186
- )
187
- ) {
188
- const hostsValidation = await validation.checkHostsAccessibilitySync(
189
- localization.value,
190
- form.value.hosts,
191
- wizard,
192
- value
193
- )
194
-
195
- value = hostsValidation.newValue
196
-
197
- stepHasError = hostsValidation.stepHasError
198
- }
199
-
200
- if (
201
- wizard.isValidateForStep(dynamicSteps.storage, currentStep.id, nextStep.id)
202
- ) {
203
- const storageValidation = await validation.checkStorageSync(
204
- localization.value,
205
- form.value.storm_id,
206
- wizard,
207
- value
208
- )
209
-
210
- value = storageValidation.newValue
211
-
212
- stepHasError = storageValidation.stepHasError
213
- }
214
-
215
- return {
216
- newValue: value,
217
- stepHasError,
218
- }
219
- }
220
-
221
- const onChangeSteps = async (value: UI_I_WizardStep[]): Promise<void> =>
222
- wizard.changeSteps(value, validationFunc)
223
-
224
- // Choosing Scheme
225
- watch(
226
- () => form.value.type_code,
227
- (newValue: UI_T_DatastoreTypeCode) => {
228
- const step = getStepScheme(props.project, newValue)
229
- if (step !== undefined) {
230
- wizard.changeScheme(step)
231
- }
232
- },
233
- { immediate: true }
234
- )
235
-
236
- const onChangeStorage = (storage: UI_I_DatastoreTableItem | null): void => {
237
- if (!storage) return
238
-
239
- form.value.storm_id = storage.id
240
- }
241
-
242
- const onCreate = async (): Promise<void> => {
243
- emits('create', form.value)
244
- }
245
-
246
- const onHideModal = (): void => {
247
- emits('hide')
248
- }
249
- </script>
250
-
251
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <common-backup-storage-actions-add-new
3
+ v-if="isNewView"
4
+ v-model="form"
5
+ :project="props.project"
6
+ :wizard="wizard"
7
+ :selected-scheme="selectedScheme"
8
+ :alert-messages="alertMessages"
9
+ :title="title"
10
+ :hosts="props.hosts"
11
+ :datastore="props.datastore"
12
+ :is-datastore-loading="props.isDatastoreLoading"
13
+ :get-datastore-table-func="props.getDatastoreTableFunc"
14
+ @change-steps="onChangeSteps"
15
+ @change-storage="onChangeStorage"
16
+ @submit="onCreate"
17
+ @hide="onHideModal"
18
+ />
19
+ <common-backup-storage-actions-add-old
20
+ v-else
21
+ v-model="form"
22
+ :project="props.project"
23
+ :wizard="wizard"
24
+ :selected-scheme="selectedScheme"
25
+ :alert-messages="alertMessages"
26
+ :title="title"
27
+ :hosts="props.hosts"
28
+ :datastore="props.datastore"
29
+ :is-datastore-loading="props.isDatastoreLoading"
30
+ :get-datastore-table-func="props.getDatastoreTableFunc"
31
+ @change-steps="onChangeSteps"
32
+ @change-storage="onChangeStorage"
33
+ @submit="onCreate"
34
+ @hide="onHideModal"
35
+ />
36
+ </template>
37
+
38
+ <script setup lang="ts">
39
+ import type {
40
+ UI_I_ValidationReturn,
41
+ UI_I_WizardStep,
42
+ } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/interfaces'
43
+ import Wizard from '~/node_modules/bfg-uikit/components/ui/wizard/lib/utils/utils'
44
+ import type { UI_T_Project } from '~/lib/models/types'
45
+ import type { UI_I_CreateDatastoreForm } from '~/components/common/backup/storage/actions/add/lib/models/interfaces'
46
+ import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
47
+ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
48
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
49
+ import type { UI_T_DatastoreTypeCode } from '~/components/common/backup/storage/actions/add/lib/models/types'
50
+ // TODO use from uikit
51
+ import {
52
+ stepsFunc,
53
+ stepsSchemeInitial,
54
+ } from '~/components/common/backup/storage/actions/add/lib/config/steps'
55
+ import { datastoreDefaultFormFunc } from '~/components/common/backup/storage/actions/add/lib/config/createDatastore'
56
+ import {
57
+ dynamicSteps,
58
+ getStepScheme,
59
+ } from '~/components/common/backup/storage/actions/add/lib/config/steps'
60
+ import * as validation from '~/components/common/backup/storage/actions/add/lib/validations'
61
+
62
+ const props = withDefaults(
63
+ defineProps<{
64
+ project: UI_T_Project
65
+ datastore: UI_I_DatastoreTableItem[]
66
+ isDatastoreLoading: boolean
67
+ getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
68
+ hosts?: any[]
69
+ datacenterId?: string
70
+ }>(),
71
+ { hosts: [], datacenterId: '' }
72
+ )
73
+ const emits = defineEmits<{
74
+ (event: 'create', value: UI_I_CreateDatastoreForm): void
75
+ (event: 'hide'): void
76
+ }>()
77
+
78
+ const { $store }: any = useNuxtApp()
79
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
80
+
81
+ const localization = computed<UI_I_Localization>(() => useLocal())
82
+
83
+ const title = ref(localization.value.common.newBackupStorage)
84
+
85
+ const wizard: Wizard = new Wizard(
86
+ stepsFunc(localization.value),
87
+ stepsSchemeInitial
88
+ )
89
+
90
+ const selectedScheme = computed<number[]>(() => wizard.selectedScheme.value)
91
+ const alertMessages = computed<string[][]>(() => wizard.alertMessages.value)
92
+
93
+ const form = ref<UI_I_CreateDatastoreForm>(
94
+ useDeepCopy(datastoreDefaultFormFunc())
95
+ )
96
+
97
+ const validationFunc = async (
98
+ value: UI_I_WizardStep[],
99
+ currentStep: UI_I_WizardStep,
100
+ nextStep: UI_I_WizardStep
101
+ ): Promise<UI_I_ValidationReturn> => {
102
+ let stepHasError = false
103
+
104
+ if (
105
+ wizard.isValidateForStep(dynamicSteps.name, currentStep.id, nextStep.id)
106
+ ) {
107
+ const nameValidation = await validation.checkDatastoreNameAsync(
108
+ localization.value,
109
+ value,
110
+ form.value,
111
+ dynamicSteps.name,
112
+ 'name',
113
+ wizard,
114
+ props.project,
115
+ props.datacenterId
116
+ )
117
+
118
+ value = nameValidation.newValue
119
+
120
+ stepHasError = nameValidation.stepHasError
121
+ }
122
+
123
+ if (
124
+ wizard.isValidateForStep(
125
+ dynamicSteps.nameAndConfigure,
126
+ currentStep.id,
127
+ nextStep.id
128
+ )
129
+ ) {
130
+ const nameValidation = await validation.checkDatastoreNameAsync(
131
+ localization.value,
132
+ value,
133
+ form.value,
134
+ dynamicSteps.nameAndConfigure,
135
+ 'name',
136
+ wizard,
137
+ props.project,
138
+ props.datacenterId
139
+ )
140
+ value = nameValidation.newValue
141
+
142
+ const folderValidation = validation.checkFolderSync(
143
+ localization.value,
144
+ form.value.folder,
145
+ wizard,
146
+ value
147
+ )
148
+ value = folderValidation.newValue
149
+
150
+ const serverValidation = validation.checkServerSync(
151
+ localization.value,
152
+ form.value.server,
153
+ wizard,
154
+ value
155
+ )
156
+ value = serverValidation.newValue
157
+
158
+ // PC-2542
159
+ // const usernameValidation = validation.checkUsernameSync(
160
+ // localization.value,
161
+ // form.value.user,
162
+ // wizard,
163
+ // value
164
+ // )
165
+ // value = usernameValidation.newValue
166
+
167
+ // const passwordValidation = validation.checkPasswordSync(
168
+ // localization.value,
169
+ // form.value.password,
170
+ // wizard,
171
+ // value
172
+ // )
173
+ // value = passwordValidation.newValue
174
+
175
+ stepHasError =
176
+ nameValidation.stepHasError ||
177
+ folderValidation.stepHasError ||
178
+ serverValidation.stepHasError
179
+ }
180
+
181
+ if (
182
+ wizard.isValidateForStep(
183
+ dynamicSteps.hostAccessibility,
184
+ currentStep.id,
185
+ nextStep.id
186
+ )
187
+ ) {
188
+ const hostsValidation = await validation.checkHostsAccessibilitySync(
189
+ localization.value,
190
+ form.value.hosts,
191
+ wizard,
192
+ value
193
+ )
194
+
195
+ value = hostsValidation.newValue
196
+
197
+ stepHasError = hostsValidation.stepHasError
198
+ }
199
+
200
+ if (
201
+ wizard.isValidateForStep(dynamicSteps.storage, currentStep.id, nextStep.id)
202
+ ) {
203
+ const storageValidation = await validation.checkStorageSync(
204
+ localization.value,
205
+ form.value.storm_id,
206
+ wizard,
207
+ value
208
+ )
209
+
210
+ value = storageValidation.newValue
211
+
212
+ stepHasError = storageValidation.stepHasError
213
+ }
214
+
215
+ return {
216
+ newValue: value,
217
+ stepHasError,
218
+ }
219
+ }
220
+
221
+ const onChangeSteps = async (value: UI_I_WizardStep[]): Promise<void> =>
222
+ wizard.changeSteps(value, validationFunc)
223
+
224
+ // Choosing Scheme
225
+ watch(
226
+ () => form.value.type_code,
227
+ (newValue: UI_T_DatastoreTypeCode) => {
228
+ const step = getStepScheme(props.project, newValue)
229
+ if (step !== undefined) {
230
+ wizard.changeScheme(step)
231
+ }
232
+ },
233
+ { immediate: true }
234
+ )
235
+
236
+ const onChangeStorage = (storage: UI_I_DatastoreTableItem | null): void => {
237
+ if (!storage) return
238
+
239
+ form.value.storm_id = storage.id
240
+ }
241
+
242
+ const onCreate = async (): Promise<void> => {
243
+ emits('create', form.value)
244
+ }
245
+
246
+ const onHideModal = (): void => {
247
+ emits('hide')
248
+ }
249
+ </script>
250
+
251
+ <style scoped lang="scss"></style>
@@ -1,51 +1,51 @@
1
- import type Wizard from '~/node_modules/bfg-uikit/components/ui/wizard/lib/utils/utils'
2
- import type { API_UI_I_Error } from '~/lib/models/store/interfaces'
3
- import type { UI_T_Project } from '~/lib/models/types'
4
- import { UI_E_Kind } from '~/lib/models/enums'
5
-
6
- export const checkValidityName = async ({
7
- name,
8
- wizard,
9
- project,
10
- sendMessage,
11
- datacenterId,
12
- }: {
13
- name: string
14
- wizard: Wizard
15
- project: UI_T_Project
16
- sendMessage: (message: string) => void
17
- datacenterId?: string
18
- }): Promise<void> => {
19
- wizard.setLoader(true)
20
-
21
- const url = buildValidationUrl(name, project, datacenterId)
22
- const { error } = await useMyFetch<null, API_UI_I_Error>(url, {
23
- method: 'GET',
24
- })
25
- wizard.setLoader(false)
26
-
27
- if (error.value && error.value.data.error_code !== 0) {
28
- const existError = error.value.data?.error_message || error.value.data
29
- sendMessage(existError)
30
- return
31
- }
32
- sendMessage('')
33
- }
34
-
35
- const buildValidationUrl = (
36
- name: string,
37
- project: UI_T_Project,
38
- datacenterId?: string
39
- ): string => {
40
- if (project === 'procurator') {
41
- const params = new URLSearchParams({ name })
42
- return `/ui/ds/validate?${params.toString()}`
43
- }
44
-
45
- const params = new URLSearchParams()
46
- params.set('name', name)
47
- params.set('kind', String(UI_E_Kind.STORAGE_VALIDATION_NAME))
48
- if (datacenterId) params.set('datacenter', datacenterId)
49
-
50
- return `/ui/object/validate_name?${params.toString()}`
51
- }
1
+ import type Wizard from '~/node_modules/bfg-uikit/components/ui/wizard/lib/utils/utils'
2
+ import type { API_UI_I_Error } from '~/lib/models/store/interfaces'
3
+ import type { UI_T_Project } from '~/lib/models/types'
4
+ import { UI_E_Kind } from '~/lib/models/enums'
5
+
6
+ export const checkValidityName = async ({
7
+ name,
8
+ wizard,
9
+ project,
10
+ sendMessage,
11
+ datacenterId,
12
+ }: {
13
+ name: string
14
+ wizard: Wizard
15
+ project: UI_T_Project
16
+ sendMessage: (message: string) => void
17
+ datacenterId?: string
18
+ }): Promise<void> => {
19
+ wizard.setLoader(true)
20
+
21
+ const url = buildValidationUrl(name, project, datacenterId)
22
+ const { error } = await useMyFetch<null, API_UI_I_Error>(url, {
23
+ method: 'GET',
24
+ })
25
+ wizard.setLoader(false)
26
+
27
+ if (error.value && error.value.data.error_code !== 0) {
28
+ const existError = error.value.data?.error_message || error.value.data
29
+ sendMessage(existError)
30
+ return
31
+ }
32
+ sendMessage('')
33
+ }
34
+
35
+ const buildValidationUrl = (
36
+ name: string,
37
+ project: UI_T_Project,
38
+ datacenterId?: string
39
+ ): string => {
40
+ if (project === 'procurator') {
41
+ const params = new URLSearchParams({ name })
42
+ return `/ui/ds/validate?${params.toString()}`
43
+ }
44
+
45
+ const params = new URLSearchParams()
46
+ params.set('name', name)
47
+ params.set('kind', String(UI_E_Kind.STORAGE_VALIDATION_NAME))
48
+ if (datacenterId) params.set('datacenter', datacenterId)
49
+
50
+ return `/ui/object/validate_name?${params.toString()}`
51
+ }
@@ -1,18 +1,18 @@
1
- <template>
2
- <div class="skeleton-wrap">
3
- <ui-skeleton-item height="18px" />
4
- <ui-skeleton-item height="18px" />
5
- <ui-skeleton-item height="18px" />
6
- <ui-skeleton-item height="18px" />
7
- <ui-skeleton-item height="18px" />
8
- </div>
9
- </template>
10
-
11
- <script setup lang="ts"></script>
12
-
13
- <style scoped lang="scss">
14
- .skeleton-wrap {
15
- display: grid;
16
- grid-gap: 12px;
17
- }
18
- </style>
1
+ <template>
2
+ <div class="skeleton-wrap">
3
+ <ui-skeleton-item height="18px" />
4
+ <ui-skeleton-item height="18px" />
5
+ <ui-skeleton-item height="18px" />
6
+ <ui-skeleton-item height="18px" />
7
+ <ui-skeleton-item height="18px" />
8
+ </div>
9
+ </template>
10
+
11
+ <script setup lang="ts"></script>
12
+
13
+ <style scoped lang="scss">
14
+ .skeleton-wrap {
15
+ display: grid;
16
+ grid-gap: 12px;
17
+ }
18
+ </style>