bfg-common 1.5.243 → 1.5.245

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 (190) 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/scss/common/icons/icons-1.scss +2 -2
  7. package/assets/scss/common/icons/icons-5.scss +5 -5
  8. package/assets/scss/common/icons/icons-6.scss +1 -1
  9. package/assets/scss/common/theme.scss +6 -0
  10. package/components/atoms/TheIcon3.vue +50 -50
  11. package/components/atoms/perPage/PerPage.vue +58 -58
  12. package/components/atoms/table/dataGrid/DataGrid.vue +1717 -1717
  13. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  14. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  15. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  16. package/components/common/backup/actions/deleteBackup/DeleteBackup.vue +38 -0
  17. package/components/common/backup/storage/actions/add/Add.vue +250 -247
  18. package/components/common/backup/storage/actions/add/New.vue +283 -292
  19. package/components/common/backup/storage/actions/add/Old.vue +116 -114
  20. package/components/common/backup/storage/actions/add/lib/config/steps.ts +168 -168
  21. package/components/common/backup/storage/actions/add/steps/nameAndConfigure/NameAndConfigure.vue +41 -41
  22. package/components/common/backup/storage/actions/add/steps/nameAndConfigure/NameAndConfigureNew.vue +294 -314
  23. package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyComplete.vue +45 -45
  24. package/components/common/backup/storage/actions/add/steps/readyComplete/lib/config/propertiesDetails.ts +242 -242
  25. package/components/common/backup/storage/actions/add/steps/typeMode/TypeModeNew.vue +3 -18
  26. package/components/common/backup/storage/actions/delete/Delete.vue +65 -65
  27. package/components/common/browse/BrowseNew.vue +8 -2
  28. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  29. package/components/common/context/lib/models/interfaces.ts +31 -31
  30. package/components/common/diagramMain/DiagramMain.vue +897 -897
  31. package/components/common/diagramMain/Header.vue +214 -214
  32. package/components/common/layout/theHeader/feedback/new/additionalDetails/Headline.vue +66 -76
  33. package/components/common/layout/theHeader/feedback/new/subtitle/Subtitle.vue +70 -80
  34. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  35. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  36. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  37. package/components/common/pages/home/headline/Headline.vue +45 -45
  38. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  39. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  40. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  41. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  42. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  43. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  44. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  45. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  46. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  47. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  48. package/components/common/pages/packages/Packages.vue +208 -208
  49. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  50. package/components/common/pages/tasks/table/Table.vue +7 -25
  51. package/components/common/pages/tasks/table/expandDetails/ExpandDetails.vue +9 -27
  52. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  53. package/components/common/recursionTree/RecursionTree.vue +223 -223
  54. package/components/common/select/button/ButtonDropdown.vue +108 -108
  55. package/components/common/spiceConsole/Drawer.vue +377 -377
  56. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  57. package/components/common/vm/actions/add/Add.vue +3 -0
  58. package/components/common/vm/actions/add/New.vue +4 -0
  59. package/components/common/vm/actions/add/Old.vue +4 -0
  60. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  61. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  62. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  63. package/components/common/vm/actions/clone/Clone.vue +3 -0
  64. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  65. package/components/common/vm/actions/clone/toTemplate/ToTemplate.vue +3 -0
  66. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  67. package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +3 -0
  68. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +7 -2
  69. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +2 -0
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +3 -0
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +9 -7
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +321 -319
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +100 -100
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusNew.vue +95 -104
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveNew.vue +4 -0
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +78 -78
  81. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  82. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuNew.vue +8 -59
  83. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/model/ModelNew.vue +109 -132
  84. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  85. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/SharesNew.vue +6 -1
  86. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  87. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipNew.vue +154 -154
  88. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  89. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +307 -307
  90. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryNew.vue +5 -1
  91. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/hotPlug/HotPlugNew.vue +8 -2
  92. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +385 -382
  93. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskNew.vue +6 -0
  94. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskOld.vue +2 -0
  95. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/file/FileNew.vue +8 -3
  96. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -151
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationNew.vue +75 -73
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +85 -83
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/StorageModal.vue +3 -0
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/StorageModalNew.vue +2 -0
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/StorageModalOld.vue +2 -0
  102. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/maximumSize/MaximumSizeNew.vue +8 -4
  103. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/provisioning/ProvisioningNew.vue +6 -1
  104. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/SharingNew.vue +6 -1
  105. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -288
  106. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkNew.vue +1 -1
  107. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/New.vue +4 -3
  108. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/Table.vue +1 -0
  109. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
  110. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  111. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  112. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  113. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  114. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  115. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  116. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  117. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  118. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  119. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  120. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerNew.vue +1 -0
  121. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  122. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +8 -2
  123. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/inputDevices/InputDevicesNew.vue +40 -40
  124. package/components/common/vm/actions/common/customizeHardware/virtualHardware/reservation/ReservationNew.vue +5 -2
  125. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +5 -2
  126. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  127. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +5 -1
  128. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  129. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  130. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  131. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +4 -0
  132. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +1 -0
  133. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +8 -2
  134. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +31 -31
  135. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +31 -31
  136. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  137. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  138. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordNew.vue +128 -128
  139. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  140. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +39 -39
  141. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  142. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/ToolsNew.vue +5 -1
  143. package/components/common/vm/actions/common/lib/utils/capabilities.ts +52 -52
  144. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  145. package/components/common/vm/actions/common/select/computeResource/treeView/New.vue +44 -44
  146. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +118 -118
  147. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  148. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  149. package/components/common/vm/actions/common/select/name/New.vue +69 -52
  150. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  151. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  152. package/components/common/vm/actions/common/select/storage/Old.vue +2 -0
  153. package/components/common/vm/actions/common/select/storage/Storage.vue +3 -0
  154. package/components/common/vm/actions/common/select/storage/new/New.vue +10 -5
  155. package/components/common/vm/actions/common/select/storage/new/lib/config/table.ts +2 -1
  156. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  157. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  158. package/components/common/vm/actions/editSettings/EditSettings.vue +3 -0
  159. package/components/common/vm/actions/editSettings/EditSettingsOld.vue +2 -0
  160. package/components/common/vm/actions/editSettings/new/New.vue +2 -0
  161. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  162. package/components/common/wizards/datastore/add/New.vue +3 -14
  163. package/components/common/wizards/datastore/add/steps/nameAndConfigure/NameAndConfigureNew.vue +6 -27
  164. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceNew.vue +3 -15
  165. package/components/common/wizards/datastore/add/steps/typeMode/TypeModeNew.vue +3 -14
  166. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  167. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  168. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  169. package/components/common/wizards/vm/migrate/select/computeResource/tableView/TableView.vue +135 -137
  170. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  171. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  172. package/composables/productNameLocal.ts +30 -30
  173. package/composables/useAppVersion.ts +21 -21
  174. package/lib/utils/utils.ts +14 -2
  175. package/package.json +2 -2
  176. package/plugins/cron.ts +75 -0
  177. package/plugins/date.ts +233 -233
  178. package/plugins/helpers.ts +18 -0
  179. package/plugins/number.ts +18 -0
  180. package/plugins/panelStates.ts +70 -0
  181. package/plugins/text.ts +59 -48
  182. package/plugins/time.ts +17 -0
  183. package/public/spice-console/lib/images/bitmap.js +203 -203
  184. package/public/spice-console/network/spicechannel.js +387 -387
  185. package/store/main/mutations.ts +7 -7
  186. package/store/main/state.ts +7 -7
  187. package/store/tasks/mappers/recentTasks.ts +64 -64
  188. package/components/common/tooltip/Help.vue +0 -181
  189. package/components/common/tooltip/lib/models/types.ts +0 -1
  190. /package/{components/common/split/horizontal/lib/models → lib/models/plugins/panelStates}/interfaces.ts +0 -0
@@ -1,247 +1,250 @@
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
- :get-datastore-table-func="props.getDatastoreTableFunc"
13
- @change-steps="onChangeSteps"
14
- @change-storage="onChangeStorage"
15
- @submit="onCreate"
16
- @hide="onHideModal"
17
- />
18
- <common-backup-storage-actions-add-old
19
- v-else
20
- v-model="form"
21
- :project="props.project"
22
- :wizard="wizard"
23
- :selected-scheme="selectedScheme"
24
- :alert-messages="alertMessages"
25
- :title="title"
26
- :hosts="props.hosts"
27
- :datastore="props.datastore"
28
- :get-datastore-table-func="props.getDatastoreTableFunc"
29
- @change-steps="onChangeSteps"
30
- @change-storage="onChangeStorage"
31
- @submit="onCreate"
32
- @hide="onHideModal"
33
- />
34
- </template>
35
-
36
- <script setup lang="ts">
37
- import type { UI_T_Project } from '~/lib/models/types'
38
- import type { UI_I_CreateDatastoreForm } from '~/components/common/backup/storage/actions/add/lib/models/interfaces'
39
- import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
40
- import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
41
- import type { UI_I_Localization } from '~/lib/models/interfaces'
42
- import type {
43
- UI_I_ValidationReturn,
44
- UI_I_WizardStep,
45
- } from '~/components/atoms/wizard/lib/models/interfaces'
46
- import type { UI_T_DatastoreTypeCode } from '~/components/common/backup/storage/actions/add/lib/models/types'
47
- // TODO use from uikit
48
- import Wizard from "~/components/atoms/wizard/lib/utils/utils";
49
- import {
50
- stepsFunc,
51
- stepsSchemeInitial,
52
- } from '~/components/common/backup/storage/actions/add/lib/config/steps'
53
- import { datastoreDefaultFormFunc } from '~/components/common/backup/storage/actions/add/lib/config/createDatastore'
54
- import {
55
- dynamicSteps,
56
- getStepScheme,
57
- } from '~/components/common/backup/storage/actions/add/lib/config/steps'
58
- import * as validation from '~/components/common/backup/storage/actions/add/lib/validations'
59
-
60
- const props = withDefaults(
61
- defineProps<{
62
- project: UI_T_Project
63
- datastore: UI_I_DatastoreTableItem[]
64
- getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
65
- hosts?: any[]
66
- }>(),
67
- { hosts: [] }
68
- )
69
- const emits = defineEmits<{
70
- (event: 'create', value: UI_I_CreateDatastoreForm): void
71
- (event: 'hide'): void
72
- }>()
73
-
74
- const { $store }: any = useNuxtApp()
75
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
76
-
77
- const localization = computed<UI_I_Localization>(() => useLocal())
78
-
79
- const title = ref(localization.value.common.newBackupStorage)
80
-
81
- const wizard: Wizard = new Wizard(
82
- stepsFunc(localization.value),
83
- stepsSchemeInitial
84
- )
85
-
86
- const selectedScheme = computed<number[]>(() => wizard.selectedScheme.value)
87
- const alertMessages = computed<string[][]>(() => wizard.alertMessages.value)
88
-
89
- const form = ref<UI_I_CreateDatastoreForm>(
90
- useDeepCopy(datastoreDefaultFormFunc())
91
- )
92
-
93
- const validationFunc = async (
94
- value: UI_I_WizardStep[],
95
- currentStep: UI_I_WizardStep,
96
- nextStep: UI_I_WizardStep
97
- ): Promise<UI_I_ValidationReturn> => {
98
- let stepHasError = false
99
-
100
- if (
101
- wizard.isValidateForStep(dynamicSteps.name, currentStep.id, nextStep.id)
102
- ) {
103
- const nameValidation = await validation.checkDatastoreNameAsync(
104
- localization.value,
105
- value,
106
- form.value,
107
- dynamicSteps.name,
108
- 'name',
109
- wizard,
110
- props.project
111
- )
112
-
113
- value = nameValidation.newValue
114
-
115
- stepHasError = nameValidation.stepHasError
116
- }
117
-
118
- if (
119
- wizard.isValidateForStep(
120
- dynamicSteps.nameAndConfigure,
121
- currentStep.id,
122
- nextStep.id
123
- )
124
- ) {
125
- const nameValidation = await validation.checkDatastoreNameAsync(
126
- localization.value,
127
- value,
128
- form.value,
129
- dynamicSteps.nameAndConfigure,
130
- 'name',
131
- wizard,
132
- props.project
133
- )
134
- value = nameValidation.newValue
135
-
136
- const folderValidation = validation.checkFolderSync(
137
- localization.value,
138
- form.value.folder,
139
- wizard,
140
- value
141
- )
142
- value = folderValidation.newValue
143
-
144
- const serverValidation = validation.checkServerSync(
145
- localization.value,
146
- form.value.server,
147
- wizard,
148
- value
149
- )
150
- value = serverValidation.newValue
151
-
152
- const usernameValidation = validation.checkUsernameSync(
153
- localization.value,
154
- form.value.user,
155
- wizard,
156
- value
157
- )
158
- value = usernameValidation.newValue
159
-
160
- const passwordValidation = validation.checkPasswordSync(
161
- localization.value,
162
- form.value.password,
163
- wizard,
164
- value
165
- )
166
- value = passwordValidation.newValue
167
-
168
- stepHasError =
169
- nameValidation.stepHasError ||
170
- folderValidation.stepHasError ||
171
- serverValidation.stepHasError ||
172
- usernameValidation.stepHasError ||
173
- passwordValidation.stepHasError
174
- }
175
-
176
- if (
177
- wizard.isValidateForStep(
178
- dynamicSteps.hostAccessibility,
179
- currentStep.id,
180
- nextStep.id
181
- )
182
- ) {
183
- const hostsValidation = await validation.checkHostsAccessibilitySync(
184
- localization.value,
185
- form.value.hosts,
186
- wizard,
187
- value
188
- )
189
-
190
- value = hostsValidation.newValue
191
-
192
- stepHasError = hostsValidation.stepHasError
193
- }
194
-
195
- if (
196
- wizard.isValidateForStep(dynamicSteps.storage, currentStep.id, nextStep.id)
197
- ) {
198
- const storageValidation = await validation.checkStorageSync(
199
- localization.value,
200
- form.value.storm_id,
201
- wizard,
202
- value
203
- )
204
-
205
- value = storageValidation.newValue
206
-
207
- stepHasError = storageValidation.stepHasError
208
- }
209
-
210
- return {
211
- newValue: value,
212
- stepHasError,
213
- }
214
- }
215
-
216
- const onChangeSteps = async (value: UI_I_WizardStep[]): Promise<void> =>
217
- wizard.changeSteps(value, validationFunc)
218
-
219
- // Choosing Scheme
220
- watch(
221
- () => form.value.type_code,
222
- (newValue: UI_T_DatastoreTypeCode) => {
223
- const step = getStepScheme(props.project, newValue)
224
- if (step !== undefined) {
225
- wizard.changeScheme(step)
226
- }
227
- },
228
- { immediate: true }
229
- )
230
-
231
- const onChangeStorage = (storage: UI_I_DatastoreTableItem | null): void => {
232
- if (!storage) return
233
-
234
- form.value.storm_id = storage.id
235
- }
236
-
237
- const onCreate = async (
238
- ): Promise<void> => {
239
- emits('create', form.value)
240
- }
241
-
242
- const onHideModal = (): void => {
243
- emits('hide')
244
- }
245
- </script>
246
-
247
- <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 { UI_T_Project } from '~/lib/models/types'
40
+ import type { UI_I_CreateDatastoreForm } from '~/components/common/backup/storage/actions/add/lib/models/interfaces'
41
+ import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
42
+ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
43
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
44
+ import type {
45
+ UI_I_ValidationReturn,
46
+ UI_I_WizardStep,
47
+ } from '~/components/atoms/wizard/lib/models/interfaces'
48
+ import type { UI_T_DatastoreTypeCode } from '~/components/common/backup/storage/actions/add/lib/models/types'
49
+ // TODO use from uikit
50
+ import Wizard from "~/components/atoms/wizard/lib/utils/utils";
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
+ }>(),
70
+ { hosts: [] }
71
+ )
72
+ const emits = defineEmits<{
73
+ (event: 'create', value: UI_I_CreateDatastoreForm): void
74
+ (event: 'hide'): void
75
+ }>()
76
+
77
+ const { $store }: any = useNuxtApp()
78
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
79
+
80
+ const localization = computed<UI_I_Localization>(() => useLocal())
81
+
82
+ const title = ref(localization.value.common.newBackupStorage)
83
+
84
+ const wizard: Wizard = new Wizard(
85
+ stepsFunc(localization.value),
86
+ stepsSchemeInitial
87
+ )
88
+
89
+ const selectedScheme = computed<number[]>(() => wizard.selectedScheme.value)
90
+ const alertMessages = computed<string[][]>(() => wizard.alertMessages.value)
91
+
92
+ const form = ref<UI_I_CreateDatastoreForm>(
93
+ useDeepCopy(datastoreDefaultFormFunc())
94
+ )
95
+
96
+ const validationFunc = async (
97
+ value: UI_I_WizardStep[],
98
+ currentStep: UI_I_WizardStep,
99
+ nextStep: UI_I_WizardStep
100
+ ): Promise<UI_I_ValidationReturn> => {
101
+ let stepHasError = false
102
+
103
+ if (
104
+ wizard.isValidateForStep(dynamicSteps.name, currentStep.id, nextStep.id)
105
+ ) {
106
+ const nameValidation = await validation.checkDatastoreNameAsync(
107
+ localization.value,
108
+ value,
109
+ form.value,
110
+ dynamicSteps.name,
111
+ 'name',
112
+ wizard,
113
+ props.project
114
+ )
115
+
116
+ value = nameValidation.newValue
117
+
118
+ stepHasError = nameValidation.stepHasError
119
+ }
120
+
121
+ if (
122
+ wizard.isValidateForStep(
123
+ dynamicSteps.nameAndConfigure,
124
+ currentStep.id,
125
+ nextStep.id
126
+ )
127
+ ) {
128
+ const nameValidation = await validation.checkDatastoreNameAsync(
129
+ localization.value,
130
+ value,
131
+ form.value,
132
+ dynamicSteps.nameAndConfigure,
133
+ 'name',
134
+ wizard,
135
+ props.project
136
+ )
137
+ value = nameValidation.newValue
138
+
139
+ const folderValidation = validation.checkFolderSync(
140
+ localization.value,
141
+ form.value.folder,
142
+ wizard,
143
+ value
144
+ )
145
+ value = folderValidation.newValue
146
+
147
+ const serverValidation = validation.checkServerSync(
148
+ localization.value,
149
+ form.value.server,
150
+ wizard,
151
+ value
152
+ )
153
+ value = serverValidation.newValue
154
+
155
+ const usernameValidation = validation.checkUsernameSync(
156
+ localization.value,
157
+ form.value.user,
158
+ wizard,
159
+ value
160
+ )
161
+ value = usernameValidation.newValue
162
+
163
+ const passwordValidation = validation.checkPasswordSync(
164
+ localization.value,
165
+ form.value.password,
166
+ wizard,
167
+ value
168
+ )
169
+ value = passwordValidation.newValue
170
+
171
+ stepHasError =
172
+ nameValidation.stepHasError ||
173
+ folderValidation.stepHasError ||
174
+ serverValidation.stepHasError ||
175
+ usernameValidation.stepHasError ||
176
+ passwordValidation.stepHasError
177
+ }
178
+
179
+ if (
180
+ wizard.isValidateForStep(
181
+ dynamicSteps.hostAccessibility,
182
+ currentStep.id,
183
+ nextStep.id
184
+ )
185
+ ) {
186
+ const hostsValidation = await validation.checkHostsAccessibilitySync(
187
+ localization.value,
188
+ form.value.hosts,
189
+ wizard,
190
+ value
191
+ )
192
+
193
+ value = hostsValidation.newValue
194
+
195
+ stepHasError = hostsValidation.stepHasError
196
+ }
197
+
198
+ if (
199
+ wizard.isValidateForStep(dynamicSteps.storage, currentStep.id, nextStep.id)
200
+ ) {
201
+ const storageValidation = await validation.checkStorageSync(
202
+ localization.value,
203
+ form.value.storm_id,
204
+ wizard,
205
+ value
206
+ )
207
+
208
+ value = storageValidation.newValue
209
+
210
+ stepHasError = storageValidation.stepHasError
211
+ }
212
+
213
+ return {
214
+ newValue: value,
215
+ stepHasError,
216
+ }
217
+ }
218
+
219
+ const onChangeSteps = async (value: UI_I_WizardStep[]): Promise<void> =>
220
+ wizard.changeSteps(value, validationFunc)
221
+
222
+ // Choosing Scheme
223
+ watch(
224
+ () => form.value.type_code,
225
+ (newValue: UI_T_DatastoreTypeCode) => {
226
+ const step = getStepScheme(props.project, newValue)
227
+ if (step !== undefined) {
228
+ wizard.changeScheme(step)
229
+ }
230
+ },
231
+ { immediate: true }
232
+ )
233
+
234
+ const onChangeStorage = (storage: UI_I_DatastoreTableItem | null): void => {
235
+ if (!storage) return
236
+
237
+ form.value.storm_id = storage.id
238
+ }
239
+
240
+ const onCreate = async (
241
+ ): Promise<void> => {
242
+ emits('create', form.value)
243
+ }
244
+
245
+ const onHideModal = (): void => {
246
+ emits('hide')
247
+ }
248
+ </script>
249
+
250
+ <style scoped lang="scss"></style>