bfg-common 1.5.502 → 1.5.503

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 (122) 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 +0 -4
  7. package/assets/localization/local_en.json +0 -4
  8. package/assets/localization/local_hy.json +0 -4
  9. package/assets/localization/local_kk.json +0 -4
  10. package/assets/localization/local_ru.json +0 -4
  11. package/assets/localization/local_zh.json +0 -4
  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/DataGridPagination.vue +97 -97
  16. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  17. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  18. package/components/common/backup/storage/actions/add/Add.vue +251 -251
  19. package/components/common/backup/storage/actions/add/lib/utils.ts +62 -62
  20. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  21. package/components/common/diagramMain/modals/lib/config/portModal.ts +251 -251
  22. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  23. package/components/common/diagramMain/port/Port.vue +580 -580
  24. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  25. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  26. package/components/common/pages/backups/Backups.vue +61 -54
  27. package/components/common/pages/backups/DetailView.vue +52 -52
  28. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  29. package/components/common/pages/backups/modals/Modals.vue +243 -243
  30. package/components/common/pages/backups/modals/createBackup/configuration/Configuration.vue +29 -29
  31. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  32. package/components/common/pages/backups/modals/createBackup/datastores/tableView/TableView.vue +95 -95
  33. package/components/common/pages/backups/modals/createBackup/general/General.vue +141 -141
  34. package/components/common/pages/backups/modals/createBackup/lib/config/strategyOptions.ts +12 -12
  35. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  36. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  37. package/components/common/pages/backups/modals/restore/disks/Disks.vue +27 -27
  38. package/components/common/pages/backups/modals/restore/disks/tableView/lib/config/table.ts +117 -117
  39. package/components/common/pages/backups/modals/restore/name/Name.vue +166 -166
  40. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  41. package/components/common/pages/backups/modals/restore/networks/Networks.vue +67 -67
  42. package/components/common/pages/backups/modals/restore/networks/table/Table.vue +214 -214
  43. package/components/common/pages/backups/modals/restore/types/lib/config/typeOptions.ts +25 -25
  44. package/components/common/pages/backups/tools/Tools.vue +75 -75
  45. package/components/common/pages/backups/tools/lib/config/tabs.ts +36 -37
  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/readyToComplete/ReadyToComplete.vue +17 -17
  53. package/components/common/select/radio/RadioGroup.vue +137 -137
  54. package/components/common/spiceConsole/Drawer.vue +392 -392
  55. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  56. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  57. package/components/common/tools/Actions.vue +207 -207
  58. package/components/common/treeView/TreeView.vue +52 -52
  59. package/components/common/vm/actions/add/Add.vue +892 -889
  60. package/components/common/vm/actions/add/New.vue +693 -691
  61. package/components/common/vm/actions/add/Old.vue +412 -410
  62. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +85 -85
  63. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  64. package/components/common/vm/actions/add/lib/config/steps.ts +347 -347
  65. package/components/common/vm/actions/clone/Clone.vue +862 -861
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +368 -368
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/Table.vue +99 -99
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  75. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  76. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  77. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  78. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  79. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  80. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  81. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  82. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +143 -143
  83. package/components/common/vm/actions/common/select/computeResource/New.vue +184 -184
  84. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +131 -131
  85. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  86. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  87. package/components/common/vm/actions/common/select/name/Name.vue +178 -176
  88. package/components/common/vm/actions/common/select/name/New.vue +221 -221
  89. package/components/common/vm/actions/common/select/name/Old.vue +121 -121
  90. package/components/common/vm/actions/common/select/name/lib/models/interfaces.ts +4 -4
  91. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  92. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  93. package/components/common/vm/actions/common/select/storage/new/New.vue +320 -320
  94. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  95. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  96. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  97. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  98. package/components/common/vm/actions/register/Register.vue +284 -283
  99. package/components/common/vm/actions/register/lib/config/steps.ts +86 -86
  100. package/components/common/wizards/datastore/add/Add.vue +228 -228
  101. package/components/common/wizards/datastore/add/lib/utils.ts +93 -93
  102. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  103. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  104. package/composables/useAppVersion.ts +21 -21
  105. package/composables/useLocal.ts +6 -6
  106. package/composables/useLocalCommon.ts +39 -39
  107. package/package.json +2 -2
  108. package/plugins/date.ts +233 -233
  109. package/plugins/panelStates.ts +70 -70
  110. package/plugins/text.ts +59 -59
  111. package/public/spice-console/lib/images/bitmap.js +203 -203
  112. package/public/spice-console/network/spicechannel.js +440 -440
  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
  116. package/components/common/pages/backups/BackupsOld.vue +0 -80
  117. package/components/common/pages/backups/backupsNew/BackupsNew.vue +0 -355
  118. package/components/common/pages/backups/backupsNew/contextMenuView/ContextMenuView.vue +0 -101
  119. package/components/common/pages/backups/backupsNew/contextMenuView/lib/config/contextMenuItems.ts +0 -29
  120. package/components/common/pages/backups/backupsNew/lib/models/interfaces.ts +0 -12
  121. package/components/common/pages/backups/backupsNew/lib/utils/contextMenu.ts +0 -29
  122. package/components/common/pages/backups/backupsNew/lib/utils/details.ts +0 -30
@@ -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,62 +1,62 @@
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
- try {
22
- const url = buildValidationUrl(name, project, datacenterId)
23
-
24
- const { error } = await useMyFetch<null, API_UI_I_Error>(url, {
25
- method: 'GET',
26
- })
27
-
28
- if (
29
- error?.value?.data?.error_code !== 0
30
- ) {
31
- const existError =
32
- error.value.data?.error_message ?? String(error.value.data)
33
- sendMessage(existError)
34
- return
35
- }
36
-
37
- sendMessage('')
38
- } catch (e) {
39
- const msg = e instanceof Error ? e.message : 'Unknown error'
40
- sendMessage(msg)
41
- } finally {
42
- wizard.setLoader(false)
43
- }
44
- }
45
-
46
- const buildValidationUrl = (
47
- name: string,
48
- project: UI_T_Project,
49
- datacenterId?: string
50
- ): string => {
51
- if (project === 'procurator') {
52
- const params = new URLSearchParams({ name })
53
- return `/ui/ds/validate?${params.toString()}`
54
- }
55
-
56
- const params = new URLSearchParams()
57
- params.set('name', name)
58
- params.set('kind', String(UI_E_Kind.STORAGE_VALIDATION_NAME))
59
- if (datacenterId) params.set('datacenter', datacenterId)
60
-
61
- return `/ui/object/validate_name?${params.toString()}`
62
- }
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
+ try {
22
+ const url = buildValidationUrl(name, project, datacenterId)
23
+
24
+ const { error } = await useMyFetch<null, API_UI_I_Error>(url, {
25
+ method: 'GET',
26
+ })
27
+
28
+ if (
29
+ error?.value?.data?.error_code !== 0
30
+ ) {
31
+ const existError =
32
+ error.value.data?.error_message ?? String(error.value.data)
33
+ sendMessage(existError)
34
+ return
35
+ }
36
+
37
+ sendMessage('')
38
+ } catch (e) {
39
+ const msg = e instanceof Error ? e.message : 'Unknown error'
40
+ sendMessage(msg)
41
+ } finally {
42
+ wizard.setLoader(false)
43
+ }
44
+ }
45
+
46
+ const buildValidationUrl = (
47
+ name: string,
48
+ project: UI_T_Project,
49
+ datacenterId?: string
50
+ ): string => {
51
+ if (project === 'procurator') {
52
+ const params = new URLSearchParams({ name })
53
+ return `/ui/ds/validate?${params.toString()}`
54
+ }
55
+
56
+ const params = new URLSearchParams()
57
+ params.set('name', name)
58
+ params.set('kind', String(UI_E_Kind.STORAGE_VALIDATION_NAME))
59
+ if (datacenterId) params.set('datacenter', datacenterId)
60
+
61
+ return `/ui/object/validate_name?${params.toString()}`
62
+ }
@@ -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>