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,86 +1,86 @@
1
- import type { UI_I_WizardStep } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/interfaces'
2
- import { UI_E_WIZARD_STATUS } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/enums'
3
- import type { UI_I_Localization } from '~/lib/models/interfaces'
4
-
5
- export const dynamicSteps = {
6
- selectName: 0,
7
- selectNameFolder: 1,
8
- selectComputeResource: 2,
9
- readyComplete: 3,
10
- }
11
-
12
- export const stepsFunc = (
13
- localization: UI_I_Localization
14
- ): UI_I_WizardStep[] => {
15
- return [
16
- // Procurator
17
- {
18
- id: dynamicSteps.selectName,
19
- stepName: '',
20
- title: localization.common.selectName,
21
- subTitle: localization.common.specifyUniqueName,
22
- status: UI_E_WIZARD_STATUS.SELECTED,
23
- isValid: true,
24
- testId: 'vm-select-name',
25
- fields: {
26
- name: {
27
- field: '',
28
- alert: '',
29
- },
30
- },
31
- },
32
- // Sphere
33
- {
34
- id: dynamicSteps.selectNameFolder,
35
- stepName: '',
36
- title: localization.vmWizard.selectNameFolder,
37
- subTitle: localization.common.specifyUniqueNameTargetLocation,
38
- status: UI_E_WIZARD_STATUS.INACTIVE,
39
- isValid: true,
40
- testId: 'vm-select-name-folder',
41
- fields: {
42
- name: {
43
- field: '',
44
- alert: '',
45
- },
46
- },
47
- },
48
- // Sphere
49
- {
50
- id: dynamicSteps.selectComputeResource,
51
- stepName: '',
52
- title: localization.vmWizard.selectComputeResource,
53
- subTitle: localization.common.selectDestinationComputeResourceOperation,
54
- status: UI_E_WIZARD_STATUS.INACTIVE,
55
- isValid: true,
56
- testId: 'vm-select-compute-resource',
57
- fields: {
58
- computeResource: {
59
- field: '',
60
- alert: '',
61
- },
62
- },
63
- },
64
- {
65
- id: dynamicSteps.readyComplete,
66
- stepName: '',
67
- title: localization.vmWizard.readyComplete,
68
- subTitle: localization.vmWizard.lastCreateSubtitle,
69
- status: UI_E_WIZARD_STATUS.INACTIVE,
70
- isValid: true,
71
- testId: 'vm-ready-complete',
72
- fields: {},
73
- },
74
- ]
75
- }
76
-
77
- export const stepsSchemeInitial = [
78
- // 0 Procurator
79
- [dynamicSteps.selectName, dynamicSteps.readyComplete],
80
- // 1 Sphere
81
- [
82
- dynamicSteps.selectNameFolder,
83
- dynamicSteps.selectComputeResource,
84
- dynamicSteps.readyComplete,
85
- ],
86
- ]
1
+ import type { UI_I_WizardStep } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/interfaces'
2
+ import { UI_E_WIZARD_STATUS } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/enums'
3
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
4
+
5
+ export const dynamicSteps = {
6
+ selectName: 0,
7
+ selectNameFolder: 1,
8
+ selectComputeResource: 2,
9
+ readyComplete: 3,
10
+ }
11
+
12
+ export const stepsFunc = (
13
+ localization: UI_I_Localization
14
+ ): UI_I_WizardStep[] => {
15
+ return [
16
+ // Procurator
17
+ {
18
+ id: dynamicSteps.selectName,
19
+ stepName: '',
20
+ title: localization.common.selectName,
21
+ subTitle: localization.common.specifyUniqueName,
22
+ status: UI_E_WIZARD_STATUS.SELECTED,
23
+ isValid: true,
24
+ testId: 'vm-select-name',
25
+ fields: {
26
+ name: {
27
+ field: '',
28
+ alert: '',
29
+ },
30
+ },
31
+ },
32
+ // Sphere
33
+ {
34
+ id: dynamicSteps.selectNameFolder,
35
+ stepName: '',
36
+ title: localization.vmWizard.selectNameFolder,
37
+ subTitle: localization.common.specifyUniqueNameTargetLocation,
38
+ status: UI_E_WIZARD_STATUS.INACTIVE,
39
+ isValid: true,
40
+ testId: 'vm-select-name-folder',
41
+ fields: {
42
+ name: {
43
+ field: '',
44
+ alert: '',
45
+ },
46
+ },
47
+ },
48
+ // Sphere
49
+ {
50
+ id: dynamicSteps.selectComputeResource,
51
+ stepName: '',
52
+ title: localization.vmWizard.selectComputeResource,
53
+ subTitle: localization.common.selectDestinationComputeResourceOperation,
54
+ status: UI_E_WIZARD_STATUS.INACTIVE,
55
+ isValid: true,
56
+ testId: 'vm-select-compute-resource',
57
+ fields: {
58
+ computeResource: {
59
+ field: '',
60
+ alert: '',
61
+ },
62
+ },
63
+ },
64
+ {
65
+ id: dynamicSteps.readyComplete,
66
+ stepName: '',
67
+ title: localization.vmWizard.readyComplete,
68
+ subTitle: localization.vmWizard.lastCreateSubtitle,
69
+ status: UI_E_WIZARD_STATUS.INACTIVE,
70
+ isValid: true,
71
+ testId: 'vm-ready-complete',
72
+ fields: {},
73
+ },
74
+ ]
75
+ }
76
+
77
+ export const stepsSchemeInitial = [
78
+ // 0 Procurator
79
+ [dynamicSteps.selectName, dynamicSteps.readyComplete],
80
+ // 1 Sphere
81
+ [
82
+ dynamicSteps.selectNameFolder,
83
+ dynamicSteps.selectComputeResource,
84
+ dynamicSteps.readyComplete,
85
+ ],
86
+ ]
@@ -1,228 +1,228 @@
1
- <template>
2
- <common-wizards-datastore-add-new
3
- v-if="isNewView"
4
- v-model="form"
5
- :project="props.project"
6
- :wizard="wizard"
7
- :alert-messages="alertMessages"
8
- :selected-scheme="selectedScheme"
9
- :selected-node="props.selectedNode"
10
- :title="title"
11
- :nfs-hosts="props.nfsHosts"
12
- :host-id="props.hostId"
13
- @change-steps="onChangeSteps"
14
- @hide="onHideModal"
15
- @submit="onCreateDatastore"
16
- />
17
- <common-wizards-datastore-add-old
18
- v-else
19
- v-model="form"
20
- :project="props.project"
21
- :wizard="wizard"
22
- :alert-messages="alertMessages"
23
- :selected-scheme="selectedScheme"
24
- :title="title"
25
- :nfs-hosts="props.nfsHosts"
26
- :host-id="props.hostId"
27
- @change-steps="onChangeSteps"
28
- @hide-alert="onHideAlert"
29
- @hide="onHideModal"
30
- @submit="onCreateDatastore"
31
- />
32
- </template>
33
-
34
- <script setup lang="ts">
35
- import type {
36
- UI_I_WizardStep,
37
- UI_I_ValidationReturn,
38
- } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/interfaces'
39
- import Wizard from '~/node_modules/bfg-uikit/components/ui/wizard/lib/utils/utils'
40
- import type { UI_I_Localization } from '~/lib/models/interfaces'
41
- import type { UI_T_Project } from '~/lib/models/types'
42
- import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
43
- import type { UI_T_DatastoreTypeCode } from '~/components/common/wizards/datastore/add/lib/models/types'
44
- import type { UI_I_CreateDatastoreForm } from '~/components/common/wizards/datastore/add/lib/models/interfaces'
45
- import type { UI_I_CompatibleHosts } from '~/components/common/wizards/datastore/add/steps/hostAccessibility/table/lib/models/interfaces'
46
- import {
47
- stepsFunc,
48
- stepsSchemeInitial,
49
- getStepScheme,
50
- dynamicSteps,
51
- } from '~/components/common/wizards/datastore/add/lib/config/steps'
52
- import { datastoreDefaultFormFunc } from '~/components/common/wizards/datastore/add/lib/config/createDatastore'
53
- import * as validation from '~/components/common/wizards/datastore/add/lib/validations'
54
-
55
- const props = withDefaults(
56
- defineProps<{
57
- project: UI_T_Project
58
- selectedNode: UI_I_TreeNode
59
- nfsHosts?: UI_I_CompatibleHosts
60
- hostId?: string
61
- isMainFilter?: boolean
62
- datacenterId?: string // For Sphere
63
- }>(),
64
- {
65
- nfsHosts: undefined,
66
- hostId: undefined,
67
- isMainFilter: undefined,
68
- datacenterId: '',
69
- }
70
- )
71
- const emits = defineEmits<{
72
- (event: 'hide'): void
73
- (event: 'finish', value: UI_I_CreateDatastoreForm): void
74
- (event: 'main-filter', value: string): void
75
- }>()
76
-
77
- const localization = computed<UI_I_Localization>(() => useLocal())
78
- const { $store }: any = useNuxtApp()
79
-
80
- const wizard: Wizard = new Wizard(
81
- stepsFunc(localization.value),
82
- stepsSchemeInitial
83
- )
84
-
85
- const selectedScheme = computed<number[]>(() => wizard.selectedScheme.value)
86
- const alertMessages = computed<string[][]>(() => wizard.alertMessages.value)
87
-
88
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
89
-
90
- const title = computed<string>(() => localization.value.common.newDatastore)
91
-
92
- const form = ref<UI_I_CreateDatastoreForm>(
93
- useDeepCopy(datastoreDefaultFormFunc(props.hostId))
94
- )
95
- const validationFunc = async (
96
- value: UI_I_WizardStep[],
97
- currentStep: UI_I_WizardStep,
98
- nextStep: UI_I_WizardStep
99
- ): Promise<UI_I_ValidationReturn> => {
100
- let stepHasError = false
101
-
102
- if (
103
- wizard.isValidateForStep(
104
- dynamicSteps.nameAndDevice,
105
- currentStep.id,
106
- nextStep.id
107
- )
108
- ) {
109
- const nameValidation = await validation.checkDatastoreNameAsync(
110
- localization.value,
111
- value,
112
- form.value,
113
- dynamicSteps.nameAndDevice,
114
- 'datastoreName',
115
- wizard,
116
- props.project,
117
- props.datacenterId
118
- )
119
-
120
- value = nameValidation.newValue
121
-
122
- const lunDiskValidation = validation.checkSelectedLunDiskSync(
123
- localization.value,
124
- form.value,
125
- wizard,
126
- value,
127
- props.project,
128
- props.hostId
129
- )
130
-
131
- value = lunDiskValidation.newValue
132
-
133
- stepHasError = nameValidation.stepHasError || lunDiskValidation.stepHasError
134
- }
135
-
136
- if (
137
- wizard.isValidateForStep(
138
- dynamicSteps.nameAndConfigure,
139
- currentStep.id,
140
- nextStep.id
141
- )
142
- ) {
143
- const nameValidation = await validation.checkDatastoreNameAsync(
144
- localization.value,
145
- value,
146
- form.value,
147
- dynamicSteps.nameAndConfigure,
148
- 'name',
149
- wizard,
150
- props.project,
151
- props.datacenterId
152
- )
153
- value = nameValidation.newValue
154
-
155
- const folderValidation = validation.checkNfsFolderSync(
156
- localization.value,
157
- form.value.folder,
158
- wizard,
159
- value
160
- )
161
- value = folderValidation.newValue
162
-
163
- const serverValidation = validation.checkNfsServerSync(
164
- localization.value,
165
- form.value.server,
166
- wizard,
167
- value
168
- )
169
- value = serverValidation.newValue
170
-
171
- stepHasError =
172
- nameValidation.stepHasError ||
173
- folderValidation.stepHasError ||
174
- serverValidation.stepHasError
175
- }
176
-
177
- if (
178
- wizard.isValidateForStep(
179
- dynamicSteps.hostAccessibility,
180
- currentStep.id,
181
- nextStep.id
182
- )
183
- ) {
184
- const nameValidation = await validation.checkHostsAccessibilitySync(
185
- localization.value,
186
- form.value.hosts,
187
- wizard,
188
- value
189
- )
190
-
191
- value = nameValidation.newValue
192
-
193
- stepHasError = nameValidation.stepHasError
194
- }
195
-
196
- return {
197
- newValue: value,
198
- stepHasError,
199
- }
200
- }
201
-
202
- const onChangeSteps = async (value: UI_I_WizardStep[]): Promise<void> =>
203
- wizard.changeSteps(value, validationFunc)
204
-
205
- // Choosing Scheme
206
- watch(
207
- () => form.value.type_code,
208
- (newValue: UI_T_DatastoreTypeCode) => {
209
- const step = getStepScheme(props.project, newValue, props.hostId)
210
- if (step !== undefined) {
211
- wizard.changeScheme(step)
212
- }
213
- },
214
- { immediate: true }
215
- )
216
-
217
- const onHideAlert = (stepId: number): void => {
218
- wizard.hideAlertMessagesByStepId(stepId)
219
- }
220
- const onHideModal = (): void => {
221
- emits('hide')
222
- }
223
- const onCreateDatastore = (): void => {
224
- emits('finish', form.value)
225
- }
226
- </script>
227
-
228
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <common-wizards-datastore-add-new
3
+ v-if="isNewView"
4
+ v-model="form"
5
+ :project="props.project"
6
+ :wizard="wizard"
7
+ :alert-messages="alertMessages"
8
+ :selected-scheme="selectedScheme"
9
+ :selected-node="props.selectedNode"
10
+ :title="title"
11
+ :nfs-hosts="props.nfsHosts"
12
+ :host-id="props.hostId"
13
+ @change-steps="onChangeSteps"
14
+ @hide="onHideModal"
15
+ @submit="onCreateDatastore"
16
+ />
17
+ <common-wizards-datastore-add-old
18
+ v-else
19
+ v-model="form"
20
+ :project="props.project"
21
+ :wizard="wizard"
22
+ :alert-messages="alertMessages"
23
+ :selected-scheme="selectedScheme"
24
+ :title="title"
25
+ :nfs-hosts="props.nfsHosts"
26
+ :host-id="props.hostId"
27
+ @change-steps="onChangeSteps"
28
+ @hide-alert="onHideAlert"
29
+ @hide="onHideModal"
30
+ @submit="onCreateDatastore"
31
+ />
32
+ </template>
33
+
34
+ <script setup lang="ts">
35
+ import type {
36
+ UI_I_WizardStep,
37
+ UI_I_ValidationReturn,
38
+ } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/interfaces'
39
+ import Wizard from '~/node_modules/bfg-uikit/components/ui/wizard/lib/utils/utils'
40
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
41
+ import type { UI_T_Project } from '~/lib/models/types'
42
+ import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
43
+ import type { UI_T_DatastoreTypeCode } from '~/components/common/wizards/datastore/add/lib/models/types'
44
+ import type { UI_I_CreateDatastoreForm } from '~/components/common/wizards/datastore/add/lib/models/interfaces'
45
+ import type { UI_I_CompatibleHosts } from '~/components/common/wizards/datastore/add/steps/hostAccessibility/table/lib/models/interfaces'
46
+ import {
47
+ stepsFunc,
48
+ stepsSchemeInitial,
49
+ getStepScheme,
50
+ dynamicSteps,
51
+ } from '~/components/common/wizards/datastore/add/lib/config/steps'
52
+ import { datastoreDefaultFormFunc } from '~/components/common/wizards/datastore/add/lib/config/createDatastore'
53
+ import * as validation from '~/components/common/wizards/datastore/add/lib/validations'
54
+
55
+ const props = withDefaults(
56
+ defineProps<{
57
+ project: UI_T_Project
58
+ selectedNode: UI_I_TreeNode
59
+ nfsHosts?: UI_I_CompatibleHosts
60
+ hostId?: string
61
+ isMainFilter?: boolean
62
+ datacenterId?: string // For Sphere
63
+ }>(),
64
+ {
65
+ nfsHosts: undefined,
66
+ hostId: undefined,
67
+ isMainFilter: undefined,
68
+ datacenterId: '',
69
+ }
70
+ )
71
+ const emits = defineEmits<{
72
+ (event: 'hide'): void
73
+ (event: 'finish', value: UI_I_CreateDatastoreForm): void
74
+ (event: 'main-filter', value: string): void
75
+ }>()
76
+
77
+ const localization = computed<UI_I_Localization>(() => useLocal())
78
+ const { $store }: any = useNuxtApp()
79
+
80
+ const wizard: Wizard = new Wizard(
81
+ stepsFunc(localization.value),
82
+ stepsSchemeInitial
83
+ )
84
+
85
+ const selectedScheme = computed<number[]>(() => wizard.selectedScheme.value)
86
+ const alertMessages = computed<string[][]>(() => wizard.alertMessages.value)
87
+
88
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
89
+
90
+ const title = computed<string>(() => localization.value.common.newDatastore)
91
+
92
+ const form = ref<UI_I_CreateDatastoreForm>(
93
+ useDeepCopy(datastoreDefaultFormFunc(props.hostId))
94
+ )
95
+ const validationFunc = async (
96
+ value: UI_I_WizardStep[],
97
+ currentStep: UI_I_WizardStep,
98
+ nextStep: UI_I_WizardStep
99
+ ): Promise<UI_I_ValidationReturn> => {
100
+ let stepHasError = false
101
+
102
+ if (
103
+ wizard.isValidateForStep(
104
+ dynamicSteps.nameAndDevice,
105
+ currentStep.id,
106
+ nextStep.id
107
+ )
108
+ ) {
109
+ const nameValidation = await validation.checkDatastoreNameAsync(
110
+ localization.value,
111
+ value,
112
+ form.value,
113
+ dynamicSteps.nameAndDevice,
114
+ 'datastoreName',
115
+ wizard,
116
+ props.project,
117
+ props.datacenterId
118
+ )
119
+
120
+ value = nameValidation.newValue
121
+
122
+ const lunDiskValidation = validation.checkSelectedLunDiskSync(
123
+ localization.value,
124
+ form.value,
125
+ wizard,
126
+ value,
127
+ props.project,
128
+ props.hostId
129
+ )
130
+
131
+ value = lunDiskValidation.newValue
132
+
133
+ stepHasError = nameValidation.stepHasError || lunDiskValidation.stepHasError
134
+ }
135
+
136
+ if (
137
+ wizard.isValidateForStep(
138
+ dynamicSteps.nameAndConfigure,
139
+ currentStep.id,
140
+ nextStep.id
141
+ )
142
+ ) {
143
+ const nameValidation = await validation.checkDatastoreNameAsync(
144
+ localization.value,
145
+ value,
146
+ form.value,
147
+ dynamicSteps.nameAndConfigure,
148
+ 'name',
149
+ wizard,
150
+ props.project,
151
+ props.datacenterId
152
+ )
153
+ value = nameValidation.newValue
154
+
155
+ const folderValidation = validation.checkNfsFolderSync(
156
+ localization.value,
157
+ form.value.folder,
158
+ wizard,
159
+ value
160
+ )
161
+ value = folderValidation.newValue
162
+
163
+ const serverValidation = validation.checkNfsServerSync(
164
+ localization.value,
165
+ form.value.server,
166
+ wizard,
167
+ value
168
+ )
169
+ value = serverValidation.newValue
170
+
171
+ stepHasError =
172
+ nameValidation.stepHasError ||
173
+ folderValidation.stepHasError ||
174
+ serverValidation.stepHasError
175
+ }
176
+
177
+ if (
178
+ wizard.isValidateForStep(
179
+ dynamicSteps.hostAccessibility,
180
+ currentStep.id,
181
+ nextStep.id
182
+ )
183
+ ) {
184
+ const nameValidation = await validation.checkHostsAccessibilitySync(
185
+ localization.value,
186
+ form.value.hosts,
187
+ wizard,
188
+ value
189
+ )
190
+
191
+ value = nameValidation.newValue
192
+
193
+ stepHasError = nameValidation.stepHasError
194
+ }
195
+
196
+ return {
197
+ newValue: value,
198
+ stepHasError,
199
+ }
200
+ }
201
+
202
+ const onChangeSteps = async (value: UI_I_WizardStep[]): Promise<void> =>
203
+ wizard.changeSteps(value, validationFunc)
204
+
205
+ // Choosing Scheme
206
+ watch(
207
+ () => form.value.type_code,
208
+ (newValue: UI_T_DatastoreTypeCode) => {
209
+ const step = getStepScheme(props.project, newValue, props.hostId)
210
+ if (step !== undefined) {
211
+ wizard.changeScheme(step)
212
+ }
213
+ },
214
+ { immediate: true }
215
+ )
216
+
217
+ const onHideAlert = (stepId: number): void => {
218
+ wizard.hideAlertMessagesByStepId(stepId)
219
+ }
220
+ const onHideModal = (): void => {
221
+ emits('hide')
222
+ }
223
+ const onCreateDatastore = (): void => {
224
+ emits('finish', form.value)
225
+ }
226
+ </script>
227
+
228
+ <style scoped lang="scss"></style>