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,292 +1,283 @@
1
- <template>
2
- <ui-wizard
3
- show
4
- :steps="props.wizard.steps"
5
- :selected-scheme="props.selectedScheme"
6
- :is-loading="props.wizard.wizardLoader.status"
7
- :title="props.title"
8
- :texts="texts"
9
- test-id="add-datastore-wizard"
10
- @change-steps="onChangeSteps"
11
- @hide="onHideModal"
12
- @submit="onCreateDatastore"
13
- >
14
- <template #content="{ selectedStep }">
15
- <ui-wizard-block
16
- v-if="selectedStep.id === dynamicSteps.type"
17
- :sub-title-height="height0"
18
- >
19
- <template #subTitle>
20
- <div ref="subTitleBlock0">
21
- <div class="subtitle-block flex-row">
22
- <ui-wizard-subtitle :sub-title="selectedStep.subTitle" />
23
-
24
- <common-tooltip-help
25
- test-id="datastore-type-subtitle"
26
- help-id="datastore-type-subtitle-icon"
27
- :title="localization.common.information"
28
- :help-text="localization.common.datastoreTypeHelpDesc"
29
- dropdown-width="272px"
30
- dropdown-left
31
- dropdown-top
32
- />
33
- <!-- // TODO Удалить компонент если не используется? -->
34
-
35
- <!-- <common-wizards-datastore-add-steps-common-tooltip-info-->
36
- <!-- id="datastore-type-subtitle-tooltip"-->
37
- <!-- :description="localization.common.datastoreTypeHelpDesc"-->
38
- <!-- />-->
39
- </div>
40
- </div>
41
- </template>
42
- <template #content>
43
- <common-backup-storage-actions-add-steps-type-mode
44
- v-if="selectedStep.id === dynamicSteps.type"
45
- v-model="formModelLocal.type_code"
46
- />
47
- </template>
48
- </ui-wizard-block>
49
-
50
- <ui-wizard-block
51
- v-if="selectedStep.id === dynamicSteps.name"
52
- :sub-title-height="height1"
53
- >
54
- <template #subTitle>
55
- <div ref="subTitleBlock1">
56
- <div class="subtitle-block">
57
- <ui-alert
58
- v-if="props.alertMessages[dynamicSteps.name].length"
59
- test-id="add-host-connection-settings-error-alert"
60
- type="error"
61
- size="md"
62
- :messages="props.alertMessages[dynamicSteps.name]"
63
- class="subtitle-block__alert"
64
- />
65
-
66
- <ui-wizard-subtitle :sub-title="selectedStep.subTitle" />
67
- </div>
68
- </div>
69
- </template>
70
- <template #content>
71
- <common-backup-storage-actions-add-steps-name
72
- v-if="selectedStep.id === dynamicSteps.name"
73
- v-model="formModelLocal"
74
- :project="props.project"
75
- :messages-fields="selectedStep.fields"
76
- />
77
- </template>
78
- </ui-wizard-block>
79
-
80
- <ui-wizard-block
81
- v-if="selectedStep.id === dynamicSteps.nameAndConfigure"
82
- :sub-title-height="height2"
83
- >
84
- <template #subTitle>
85
- <div ref="subTitleBlock2">
86
- <div class="subtitle-block">
87
- <ui-alert
88
- v-if="props.alertMessages[dynamicSteps.nameAndConfigure].length"
89
- test-id="add-host-connection-settings-error-alert"
90
- type="error"
91
- size="md"
92
- :messages="props.alertMessages[dynamicSteps.nameAndConfigure]"
93
- class="subtitle-block__alert"
94
- />
95
-
96
- <ui-wizard-subtitle :sub-title="selectedStep.subTitle" />
97
- </div>
98
- </div>
99
- </template>
100
- <template #content>
101
- <common-backup-storage-actions-add-steps-name-and-configure
102
- v-if="selectedStep.id === dynamicSteps.nameAndConfigure"
103
- v-model="formModelLocal"
104
- :project="props.project"
105
- :messages-fields="selectedStep.fields"
106
- />
107
- </template>
108
- </ui-wizard-block>
109
-
110
- <ui-wizard-block
111
- v-if="selectedStep.id === dynamicSteps.storage"
112
- :sub-title-height="height3"
113
- >
114
- <template #subTitle>
115
- <div ref="subTitleBlock3">
116
- <div class="subtitle-block">
117
- <ui-alert
118
- v-if="props.alertMessages[dynamicSteps.storage].length"
119
- test-id="add-host-accessibility-error-alert"
120
- type="error"
121
- size="md"
122
- :messages="props.alertMessages[dynamicSteps.storage]"
123
- class="subtitle-block__alert"
124
- />
125
-
126
- <ui-wizard-subtitle :sub-title="selectedStep.subTitle" />
127
- </div>
128
- </div>
129
- </template>
130
- <template #content>
131
- <common-vm-actions-common-select-storage
132
- :datastore="props.datastore"
133
- :get-datastore-table-func="props.getDatastoreTableFunc"
134
- hide-compatibility
135
- hide-alert
136
- class="storage-datatable h-full"
137
- @change-storage="onChangeStorage"
138
- />
139
- </template>
140
- </ui-wizard-block>
141
-
142
- <ui-wizard-block
143
- v-if="selectedStep.id === dynamicSteps.hostAccessibility"
144
- :sub-title-height="height4"
145
- >
146
- <template #subTitle>
147
- <div ref="subTitleBlock4">
148
- <div class="subtitle-block">
149
- <ui-alert
150
- v-if="
151
- props.alertMessages[dynamicSteps.hostAccessibility].length
152
- "
153
- test-id="add-host-accessibility-error-alert"
154
- type="error"
155
- size="md"
156
- :messages="props.alertMessages[dynamicSteps.hostAccessibility]"
157
- class="subtitle-block__alert"
158
- />
159
-
160
- <ui-wizard-subtitle :sub-title="selectedStep.subTitle" />
161
- </div>
162
- </div>
163
- </template>
164
- <template #content>
165
- <common-backup-storage-actions-add-steps-host-accessibility
166
- v-if="selectedStep.id === dynamicSteps.hostAccessibility"
167
- v-model="formModelLocal.hosts"
168
- :alert-messages="
169
- props.alertMessages[dynamicSteps.hostAccessibility]
170
- "
171
- :hosts="props.hosts"
172
- />
173
- </template>
174
- </ui-wizard-block>
175
-
176
- <ui-wizard-block
177
- v-if="selectedStep.id === dynamicSteps.readyComplete"
178
- :sub-title-height="height5"
179
- >
180
- <template #subTitle>
181
- <div ref="subTitleBlock5">
182
- <div class="subtitle-block">
183
- <ui-wizard-subtitle :sub-title="selectedStep.subTitle" />
184
- </div>
185
- </div>
186
- </template>
187
- <template #content>
188
- <common-backup-storage-actions-add-steps-ready-complete
189
- v-if="selectedStep.id === dynamicSteps.readyComplete"
190
- :form="formModelLocal"
191
- :project="props.project"
192
- :hosts="props.hosts"
193
- :datastore="props.datastore"
194
- />
195
- </template>
196
- </ui-wizard-block>
197
- </template>
198
- </ui-wizard>
199
- </template>
200
-
201
- <script setup lang="ts">
202
- import { useElementSize } from '@vueuse/core'
203
- import type {
204
- UI_I_WizardStep,
205
- UI_I_WizardTexts,
206
- } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/interfaces'
207
- import type Wizard from '~/node_modules/bfg-uikit/components/ui/wizard/lib/utils/utils'
208
- import type { UI_I_Localization } from '~/lib/models/interfaces'
209
- import type { UI_T_Project } from '~/lib/models/types'
210
- import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
211
- import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
212
- import type { UI_I_CreateDatastoreForm } from '~/components/common/backup/storage/actions/add/lib/models/interfaces'
213
- import { dynamicSteps } from '~/components/common/backup/storage/actions/add/lib/config/steps'
214
-
215
- const formModelLocal = defineModel<UI_I_CreateDatastoreForm>({ required: true })
216
- const props = defineProps<{
217
- project: UI_T_Project
218
- wizard: Wizard
219
- selectedScheme: number[]
220
- alertMessages: string[][]
221
- title: string
222
- datastore: UI_I_DatastoreTableItem[]
223
- getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
224
- hosts?: any[]
225
- }>()
226
- const emits = defineEmits<{
227
- (event: 'change-steps', value: UI_I_WizardStep[]): void
228
- (event: 'change-storage', value: UI_I_WizardStep[]): void
229
- (event: 'hide'): void
230
- (event: 'submit', value: any): void
231
- }>()
232
-
233
- const localization = computed<UI_I_Localization>(() => useLocal())
234
-
235
- const texts = computed<UI_I_WizardTexts>(() => ({
236
- cancel: localization.value.common.cancel,
237
- back: localization.value.common.backCap,
238
- processing: localization.value.common.processing,
239
- next: localization.value.common.next,
240
- finish: localization.value.common.add,
241
- incompleteTitle: localization.value.common.incompleteProcess,
242
- incompleteMessage: localization.value.common.incompleteProcessMessage,
243
- incompleteCancel: localization.value.common.cancel,
244
- incompleteLeave: localization.value.common.leave,
245
- step: localization.value.common.step,
246
- of: localization.value.common.of2,
247
- }))
248
-
249
- const subTitleBlock0 = ref<HTMLElement | null>(null)
250
- const { height: height0 } = useElementSize(subTitleBlock0)
251
-
252
- const subTitleBlock1 = ref<HTMLElement | null>(null)
253
- const { height: height1 } = useElementSize(subTitleBlock1)
254
-
255
- const subTitleBlock2 = ref<HTMLElement | null>(null)
256
- const { height: height2 } = useElementSize(subTitleBlock2)
257
-
258
- const subTitleBlock3 = ref<HTMLElement | null>(null)
259
- const { height: height3 } = useElementSize(subTitleBlock3)
260
-
261
- const subTitleBlock4 = ref<HTMLElement | null>(null)
262
- const { height: height4 } = useElementSize(subTitleBlock4)
263
-
264
- const subTitleBlock5 = ref<HTMLElement | null>(null)
265
- const { height: height5 } = useElementSize(subTitleBlock5)
266
-
267
- const onChangeSteps = async (value: UI_I_WizardStep[]): Promise<void> =>
268
- emits('change-steps', value)
269
- const onChangeStorage = async (value: UI_I_WizardStep[]): Promise<void> =>
270
- emits('change-storage', value)
271
-
272
- const onHideModal = (): void => emits('hide')
273
- const onCreateDatastore = (): void => emits('submit')
274
- </script>
275
-
276
- <style scoped lang="scss">
277
- .subtitle-block {
278
- display: flex;
279
- flex-direction: column;
280
- row-gap: 16px;
281
- border-bottom: 1px solid var(--wizard-line);
282
- padding-bottom: 12px;
283
-
284
- &.flex-row {
285
- flex-direction: row;
286
- }
287
-
288
- :deep(&__alert) {
289
- padding: 10px 12px;
290
- }
291
- }
292
- </style>
1
+ <template>
2
+ <ui-wizard
3
+ show
4
+ :steps="props.wizard.steps"
5
+ :selected-scheme="props.selectedScheme"
6
+ :is-loading="props.wizard.wizardLoader.status"
7
+ :title="props.title"
8
+ :texts="texts"
9
+ test-id="add-datastore-wizard"
10
+ @change-steps="onChangeSteps"
11
+ @hide="onHideModal"
12
+ @submit="onCreateDatastore"
13
+ >
14
+ <template #content="{ selectedStep }">
15
+ <ui-wizard-block
16
+ v-if="selectedStep.id === dynamicSteps.type"
17
+ :sub-title-height="height0"
18
+ >
19
+ <template #subTitle>
20
+ <div ref="subTitleBlock0">
21
+ <div class="subtitle-block flex-row">
22
+ <ui-wizard-subtitle :sub-title="selectedStep.subTitle" />
23
+
24
+ <common-wizards-datastore-add-steps-common-tooltip-info
25
+ id="datastore-type-subtitle-tooltip"
26
+ :description="localization.common.datastoreTypeHelpDesc"
27
+ />
28
+ </div>
29
+ </div>
30
+ </template>
31
+ <template #content>
32
+ <common-backup-storage-actions-add-steps-type-mode
33
+ v-if="selectedStep.id === dynamicSteps.type"
34
+ v-model="formModelLocal.type_code"
35
+ />
36
+ </template>
37
+ </ui-wizard-block>
38
+
39
+ <ui-wizard-block
40
+ v-if="selectedStep.id === dynamicSteps.name"
41
+ :sub-title-height="height1"
42
+ >
43
+ <template #subTitle>
44
+ <div ref="subTitleBlock1">
45
+ <div class="subtitle-block">
46
+ <ui-alert
47
+ v-if="props.alertMessages[dynamicSteps.name].length"
48
+ test-id="add-host-connection-settings-error-alert"
49
+ type="error"
50
+ size="md"
51
+ :messages="props.alertMessages[dynamicSteps.name]"
52
+ class="subtitle-block__alert"
53
+ />
54
+
55
+ <ui-wizard-subtitle :sub-title="selectedStep.subTitle" />
56
+ </div>
57
+ </div>
58
+ </template>
59
+ <template #content>
60
+ <common-backup-storage-actions-add-steps-name
61
+ v-if="selectedStep.id === dynamicSteps.name"
62
+ v-model="formModelLocal"
63
+ :project="props.project"
64
+ :messages-fields="selectedStep.fields"
65
+ />
66
+ </template>
67
+ </ui-wizard-block>
68
+
69
+ <ui-wizard-block
70
+ v-if="selectedStep.id === dynamicSteps.nameAndConfigure"
71
+ :sub-title-height="height2"
72
+ >
73
+ <template #subTitle>
74
+ <div ref="subTitleBlock2">
75
+ <div class="subtitle-block">
76
+ <ui-alert
77
+ v-if="props.alertMessages[dynamicSteps.nameAndConfigure].length"
78
+ test-id="add-host-connection-settings-error-alert"
79
+ type="error"
80
+ size="md"
81
+ :messages="props.alertMessages[dynamicSteps.nameAndConfigure]"
82
+ class="subtitle-block__alert"
83
+ />
84
+
85
+ <ui-wizard-subtitle :sub-title="selectedStep.subTitle" />
86
+ </div>
87
+ </div>
88
+ </template>
89
+ <template #content>
90
+ <common-backup-storage-actions-add-steps-name-and-configure
91
+ v-if="selectedStep.id === dynamicSteps.nameAndConfigure"
92
+ v-model="formModelLocal"
93
+ :project="props.project"
94
+ :messages-fields="selectedStep.fields"
95
+ />
96
+ </template>
97
+ </ui-wizard-block>
98
+
99
+ <ui-wizard-block
100
+ v-if="selectedStep.id === dynamicSteps.storage"
101
+ :sub-title-height="height3"
102
+ >
103
+ <template #subTitle>
104
+ <div ref="subTitleBlock3">
105
+ <div class="subtitle-block">
106
+ <ui-alert
107
+ v-if="props.alertMessages[dynamicSteps.storage].length"
108
+ test-id="add-host-accessibility-error-alert"
109
+ type="error"
110
+ size="md"
111
+ :messages="props.alertMessages[dynamicSteps.storage]"
112
+ class="subtitle-block__alert"
113
+ />
114
+
115
+ <ui-wizard-subtitle :sub-title="selectedStep.subTitle" />
116
+ </div>
117
+ </div>
118
+ </template>
119
+ <template #content>
120
+ <common-vm-actions-common-select-storage
121
+ :datastore="props.datastore"
122
+ :is-datastore-loading="props.isDatastoreLoading"
123
+ :get-datastore-table-func="props.getDatastoreTableFunc"
124
+ hide-compatibility
125
+ hide-alert
126
+ class="storage-datatable h-full"
127
+ @change-storage="onChangeStorage"
128
+ />
129
+ </template>
130
+ </ui-wizard-block>
131
+
132
+ <ui-wizard-block
133
+ v-if="selectedStep.id === dynamicSteps.hostAccessibility"
134
+ :sub-title-height="height4"
135
+ >
136
+ <template #subTitle>
137
+ <div ref="subTitleBlock4">
138
+ <div class="subtitle-block">
139
+ <ui-alert
140
+ v-if="
141
+ props.alertMessages[dynamicSteps.hostAccessibility].length
142
+ "
143
+ test-id="add-host-accessibility-error-alert"
144
+ type="error"
145
+ size="md"
146
+ :messages="props.alertMessages[dynamicSteps.hostAccessibility]"
147
+ class="subtitle-block__alert"
148
+ />
149
+
150
+ <ui-wizard-subtitle :sub-title="selectedStep.subTitle" />
151
+ </div>
152
+ </div>
153
+ </template>
154
+ <template #content>
155
+ <common-backup-storage-actions-add-steps-host-accessibility
156
+ v-if="selectedStep.id === dynamicSteps.hostAccessibility"
157
+ v-model="formModelLocal.hosts"
158
+ :alert-messages="
159
+ props.alertMessages[dynamicSteps.hostAccessibility]
160
+ "
161
+ :hosts="props.hosts"
162
+ />
163
+ </template>
164
+ </ui-wizard-block>
165
+
166
+ <ui-wizard-block
167
+ v-if="selectedStep.id === dynamicSteps.readyComplete"
168
+ :sub-title-height="height5"
169
+ >
170
+ <template #subTitle>
171
+ <div ref="subTitleBlock5">
172
+ <div class="subtitle-block">
173
+ <ui-wizard-subtitle :sub-title="selectedStep.subTitle" />
174
+ </div>
175
+ </div>
176
+ </template>
177
+ <template #content>
178
+ <common-backup-storage-actions-add-steps-ready-complete
179
+ v-if="selectedStep.id === dynamicSteps.readyComplete"
180
+ :form="formModelLocal"
181
+ :project="props.project"
182
+ :hosts="props.hosts"
183
+ :datastore="props.datastore"
184
+ />
185
+ </template>
186
+ </ui-wizard-block>
187
+ </template>
188
+ </ui-wizard>
189
+ </template>
190
+
191
+ <script setup lang="ts">
192
+ import { useElementSize } from '@vueuse/core'
193
+ import type {
194
+ UI_I_WizardStep,
195
+ UI_I_WizardTexts,
196
+ } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/interfaces'
197
+ import type Wizard from '~/node_modules/bfg-uikit/components/ui/wizard/lib/utils/utils'
198
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
199
+ import type { UI_T_Project } from '~/lib/models/types'
200
+ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
201
+ import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
202
+ import type { UI_I_CreateDatastoreForm } from '~/components/common/backup/storage/actions/add/lib/models/interfaces'
203
+ import { dynamicSteps } from '~/components/common/backup/storage/actions/add/lib/config/steps'
204
+
205
+ const formModelLocal = defineModel<UI_I_CreateDatastoreForm>({ required: true })
206
+ const props = defineProps<{
207
+ project: UI_T_Project
208
+ wizard: Wizard
209
+ selectedScheme: number[]
210
+ alertMessages: string[][]
211
+ title: string
212
+ datastore: UI_I_DatastoreTableItem[]
213
+ isDatastoreLoading: boolean
214
+ getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
215
+ hosts?: any[]
216
+ }>()
217
+ const emits = defineEmits<{
218
+ (event: 'change-steps', value: UI_I_WizardStep[]): void
219
+ (event: 'change-storage', value: UI_I_WizardStep[]): void
220
+ (event: 'hide'): void
221
+ (event: 'submit', value: any): void
222
+ }>()
223
+
224
+ const localization = computed<UI_I_Localization>(() => useLocal())
225
+
226
+ const texts = computed<UI_I_WizardTexts>(() => ({
227
+ cancel: localization.value.common.cancel,
228
+ back: localization.value.common.backCap,
229
+ processing: localization.value.common.processing,
230
+ next: localization.value.common.next,
231
+ finish: localization.value.common.add,
232
+ incompleteTitle: localization.value.common.incompleteProcess,
233
+ incompleteMessage: localization.value.common.incompleteProcessMessage,
234
+ incompleteCancel: localization.value.common.cancel,
235
+ incompleteLeave: localization.value.common.leave,
236
+ step: localization.value.common.step,
237
+ of: localization.value.common.of2,
238
+ }))
239
+
240
+ const subTitleBlock0 = ref<HTMLElement | null>(null)
241
+ const { height: height0 } = useElementSize(subTitleBlock0)
242
+
243
+ const subTitleBlock1 = ref<HTMLElement | null>(null)
244
+ const { height: height1 } = useElementSize(subTitleBlock1)
245
+
246
+ const subTitleBlock2 = ref<HTMLElement | null>(null)
247
+ const { height: height2 } = useElementSize(subTitleBlock2)
248
+
249
+ const subTitleBlock3 = ref<HTMLElement | null>(null)
250
+ const { height: height3 } = useElementSize(subTitleBlock3)
251
+
252
+ const subTitleBlock4 = ref<HTMLElement | null>(null)
253
+ const { height: height4 } = useElementSize(subTitleBlock4)
254
+
255
+ const subTitleBlock5 = ref<HTMLElement | null>(null)
256
+ const { height: height5 } = useElementSize(subTitleBlock5)
257
+
258
+ const onChangeSteps = async (value: UI_I_WizardStep[]): Promise<void> =>
259
+ emits('change-steps', value)
260
+ const onChangeStorage = async (value: UI_I_WizardStep[]): Promise<void> =>
261
+ emits('change-storage', value)
262
+
263
+ const onHideModal = (): void => emits('hide')
264
+ const onCreateDatastore = (): void => emits('submit')
265
+ </script>
266
+
267
+ <style scoped lang="scss">
268
+ .subtitle-block {
269
+ display: flex;
270
+ flex-direction: column;
271
+ row-gap: 16px;
272
+ border-bottom: 1px solid var(--wizard-line);
273
+ padding-bottom: 12px;
274
+
275
+ &.flex-row {
276
+ flex-direction: row;
277
+ }
278
+
279
+ :deep(&__alert) {
280
+ padding: 10px 12px;
281
+ }
282
+ }
283
+ </style>