bfg-common 1.5.60 → 1.5.61

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 (181) 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 +5 -2
  7. package/assets/localization/local_en.json +5 -2
  8. package/assets/localization/local_hy.json +5 -2
  9. package/assets/localization/local_kk.json +5 -2
  10. package/assets/localization/local_ru.json +5 -2
  11. package/assets/localization/local_zh.json +5 -2
  12. package/assets/scss/common/normalize.scss +339 -339
  13. package/components/atoms/TheIcon3.vue +50 -50
  14. package/components/atoms/collapse/CollapseNav.vue +165 -165
  15. package/components/atoms/dropdown/dropdown/Dropdown.vue +168 -168
  16. package/components/atoms/modal/bySteps/BySteps.vue +253 -253
  17. package/components/atoms/perPage/PerPage.vue +58 -58
  18. package/components/atoms/stack/StackBlock.vue +185 -185
  19. package/components/atoms/table/dataGrid/DataGridColumnSwitch.vue +222 -222
  20. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  21. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  22. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  23. package/components/atoms/tooltip/Signpost.vue +227 -227
  24. package/components/common/accordion/Recursion.vue +222 -222
  25. package/components/common/browse/BrowseNew.vue +237 -237
  26. package/components/common/browse/BrowseOld.vue +217 -217
  27. package/components/common/browse/blocks/contents/Files.vue +37 -37
  28. package/components/common/browse/blocks/contents/FilesOld.vue +72 -72
  29. package/components/common/browse/blocks/contents/filesNew/FilesNew.vue +96 -96
  30. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  31. package/components/common/context/Context.vue +111 -111
  32. package/components/common/context/lib/models/interfaces.ts +31 -31
  33. package/components/common/context/recursion/Recursion.vue +87 -87
  34. package/components/common/context/recursion/RecursionNew.vue +238 -238
  35. package/components/common/context/recursion/RecursionOld.vue +228 -228
  36. package/components/common/details/DetailsItem.vue +109 -109
  37. package/components/common/diagramMain/DiagramMain.vue +897 -897
  38. package/components/common/diagramMain/Header.vue +214 -214
  39. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  40. package/components/common/layout/theHeader/helpMenu/aboutNew/AboutNew.vue +103 -103
  41. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  42. package/components/common/mainNavigationPanel/MainNavigationPanelOld.vue +311 -311
  43. package/components/common/modals/unsavedChanges/UnsavedChanges.vue +56 -56
  44. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  45. package/components/common/pages/home/headline/Headline.vue +45 -45
  46. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  47. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  48. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  49. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  50. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  51. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  52. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  53. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  54. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  55. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  56. package/components/common/pages/packages/Packages.vue +208 -208
  57. package/components/common/pages/shortcuts/block/BlockNew.vue +96 -96
  58. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  59. package/components/common/portlets/customAttributes/Portlet.vue +667 -667
  60. package/components/common/portlets/tag/Portlet.vue +433 -433
  61. package/components/common/recursionTree/RecursionTree.vue +223 -223
  62. package/components/common/select/button/ButtonDropdown.vue +108 -108
  63. package/components/common/spiceConsole/Drawer.vue +370 -370
  64. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  65. package/components/common/split/horizontal/HorizontalOld.vue +337 -337
  66. package/components/common/split/vertical/Vertical.vue +160 -160
  67. package/components/common/tools/Actions.vue +202 -202
  68. package/components/common/vm/actions/add/Add.vue +784 -774
  69. package/components/common/vm/actions/add/New.vue +429 -0
  70. package/components/common/vm/actions/add/Old.vue +371 -0
  71. package/components/common/vm/actions/add/lib/config/steps.ts +263 -247
  72. package/components/common/vm/actions/clone/Clone.vue +798 -798
  73. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  74. package/components/common/vm/actions/clone/toTemplate/ToTemplate.vue +626 -634
  75. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  76. package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +275 -275
  77. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +274 -274
  78. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +177 -177
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +698 -698
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +410 -410
  81. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +319 -319
  82. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  83. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +99 -99
  84. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusNew.vue +117 -117
  85. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  86. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveNew.vue +164 -164
  87. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  88. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  89. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +70 -70
  90. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  91. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +338 -338
  92. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  93. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  94. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  95. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +368 -368
  96. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskNew.vue +232 -232
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskOld.vue +250 -250
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/ModeOld.vue +56 -56
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/SharingNew.vue +44 -44
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +286 -286
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkNew.vue +124 -124
  102. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/LocationOld.vue +134 -134
  103. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/New.vue +63 -63
  104. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +95 -95
  105. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  106. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressNew.vue +69 -69
  107. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressOld.vue +83 -83
  108. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  109. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  110. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  111. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  112. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoNew.vue +84 -84
  113. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  114. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  115. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  116. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  117. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGrid.vue +41 -41
  118. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridNew.vue +81 -81
  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 +56 -56
  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 +30 -30
  123. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +104 -104
  124. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardOld.vue +112 -112
  125. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/TotalVideoMemoryNew.vue +54 -54
  126. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  127. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +102 -102
  128. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +75 -75
  129. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +26 -26
  130. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +57 -57
  131. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/FirmwareNew.vue +42 -42
  132. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/MenuNew.vue +25 -25
  133. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +171 -171
  134. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +50 -50
  135. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +141 -141
  136. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +140 -140
  137. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +30 -30
  138. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +30 -30
  139. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/folderSharing/FolderSharingNew.vue +30 -30
  140. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  141. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapNew.vue +39 -39
  142. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  143. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordNew.vue +102 -102
  144. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordOld.vue +94 -94
  145. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  146. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +38 -38
  147. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  148. package/components/common/vm/actions/common/lib/utils/capabilities.ts +52 -52
  149. package/components/common/vm/actions/common/select/compatibility/Compatibility.vue +162 -162
  150. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -74
  151. package/components/common/vm/actions/common/select/createType/New.vue +84 -0
  152. package/components/common/vm/actions/common/select/createType/Old.vue +70 -0
  153. package/components/common/vm/actions/common/select/createType/lib/config/items.ts +24 -4
  154. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -0
  155. package/components/common/vm/actions/common/select/name/Name.vue +167 -236
  156. package/components/common/vm/actions/common/select/name/New.vue +143 -0
  157. package/components/common/vm/actions/common/select/name/Old.vue +119 -0
  158. package/components/common/vm/actions/common/select/storage/Storage.vue +130 -130
  159. package/components/common/vm/actions/common/select/storage/StorageOld.vue +129 -129
  160. package/components/common/vm/actions/common/select/template/Template.vue +64 -65
  161. package/components/common/vm/actions/common/select/template/TemplateTreeView.vue +88 -88
  162. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  163. package/components/common/wizards/datastore/add/lib/config/steps.ts +138 -138
  164. package/components/common/wizards/datastore/add/nfs/accessibility/Accessibility.vue +60 -60
  165. package/components/common/wizards/datastore/add/readyComplete/ReadyComplete.vue +92 -92
  166. package/components/common/wizards/network/add/steps/SelectConnectionType.vue +105 -105
  167. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  168. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  169. package/components/common/wizards/vm/migrate/select/network/table/network/Network.vue +150 -150
  170. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  171. package/components/common/wizards/vm/migrate/select/priority/Priority.vue +43 -43
  172. package/composables/productNameLocal.ts +30 -30
  173. package/composables/useAppVersion.ts +21 -21
  174. package/package.json +1 -1
  175. package/plugins/date.ts +233 -233
  176. package/plugins/directives.ts +24 -24
  177. package/public/spice-console/lib/images/bitmap.js +203 -203
  178. package/public/spice-console/network/spicechannel.js +383 -383
  179. package/store/main/mutations.ts +7 -7
  180. package/store/main/state.ts +7 -7
  181. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,52 +1,52 @@
1
- import type { UI_I_Capabilities } from '~/components/common/vm/actions/common/lib/models/interfaces'
2
- import { capabilities } from '~/components/common/vm/actions/common/lib/config/capabilities'
3
-
4
- export const mapCapabilities = (
5
- capabilitiesFromApi: UI_I_Capabilities
6
- ): void => {
7
- if (!capabilitiesFromApi) return
8
- const { $binary } = useNuxtApp()
9
-
10
- // Machine Types
11
- capabilities.machineTypes = Object.keys(
12
- capabilitiesFromApi.machine_types
13
- ).map((key) => {
14
- return {
15
- text: capabilitiesFromApi.machine_types[key],
16
- value: key,
17
- }
18
- })
19
- // CPU Models
20
- capabilities.cpuModels = Object.keys(capabilitiesFromApi.cpu_models).map(
21
- (key) => {
22
- return {
23
- text: capabilitiesFromApi.cpu_models[key],
24
- value: key,
25
- }
26
- }
27
- )
28
-
29
- Object.keys(capabilitiesFromApi.bus_types).forEach((key) => {
30
- capabilities.bus[key] = Object.keys(capabilitiesFromApi.bus_types[key]).map(
31
- (key2) => {
32
- return {
33
- text: capabilitiesFromApi.bus_types[key][key2],
34
- value: key2,
35
- }
36
- }
37
- )
38
- })
39
- Object.keys(capabilitiesFromApi.cdrom_bus_type).forEach((key) => {
40
- capabilities.cdromBus[key] = Object.keys(
41
- capabilitiesFromApi.cdrom_bus_type[key]
42
- ).map((key2) => {
43
- return {
44
- text: capabilitiesFromApi.cdrom_bus_type[key][key2],
45
- value: key2,
46
- }
47
- })
48
- })
49
-
50
- capabilities.maxCpus = capabilitiesFromApi.max_vcpus
51
- capabilities.maxMemory = $binary.kbToMb(capabilitiesFromApi.max_mem_kib)
52
- }
1
+ import type { UI_I_Capabilities } from '~/components/common/vm/actions/common/lib/models/interfaces'
2
+ import { capabilities } from '~/components/common/vm/actions/common/lib/config/capabilities'
3
+
4
+ export const mapCapabilities = (
5
+ capabilitiesFromApi: UI_I_Capabilities
6
+ ): void => {
7
+ if (!capabilitiesFromApi) return
8
+ const { $binary } = useNuxtApp()
9
+
10
+ // Machine Types
11
+ capabilities.machineTypes = Object.keys(
12
+ capabilitiesFromApi.machine_types
13
+ ).map((key) => {
14
+ return {
15
+ text: capabilitiesFromApi.machine_types[key],
16
+ value: key,
17
+ }
18
+ })
19
+ // CPU Models
20
+ capabilities.cpuModels = Object.keys(capabilitiesFromApi.cpu_models).map(
21
+ (key) => {
22
+ return {
23
+ text: capabilitiesFromApi.cpu_models[key],
24
+ value: key,
25
+ }
26
+ }
27
+ )
28
+
29
+ Object.keys(capabilitiesFromApi.bus_types).forEach((key) => {
30
+ capabilities.bus[key] = Object.keys(capabilitiesFromApi.bus_types[key]).map(
31
+ (key2) => {
32
+ return {
33
+ text: capabilitiesFromApi.bus_types[key][key2],
34
+ value: key2,
35
+ }
36
+ }
37
+ )
38
+ })
39
+ Object.keys(capabilitiesFromApi.cdrom_bus_type).forEach((key) => {
40
+ capabilities.cdromBus[key] = Object.keys(
41
+ capabilitiesFromApi.cdrom_bus_type[key]
42
+ ).map((key2) => {
43
+ return {
44
+ text: capabilitiesFromApi.cdrom_bus_type[key][key2],
45
+ value: key2,
46
+ }
47
+ })
48
+ })
49
+
50
+ capabilities.maxCpus = capabilitiesFromApi.max_vcpus
51
+ capabilities.maxMemory = $binary.kbToMb(capabilitiesFromApi.max_mem_kib)
52
+ }
@@ -1,162 +1,162 @@
1
- <template>
2
- <div class="select-compatibility">
3
- <p class="select-compatibility-block">
4
- {{ description }}
5
- </p>
6
- <div class="select-compatibility-block version-select-wrap">
7
- <label for="version-select"
8
- >{{ localization.common.compatibleWith }}:</label
9
- >
10
-
11
- <atoms-tooltip-error
12
- :has-error="!!apiError"
13
- selector="#vm-wizard-version-select"
14
- @remove="onRemoveValidationError"
15
- >
16
- <template #elem>
17
- <select
18
- id="vm-wizard-version-select"
19
- v-model="selectedVersion"
20
- data-id="vm-wizard-version-select"
21
- >
22
- <option v-for="(item, key) in versions" :key="key" :value="item">
23
- {{ item.text }}
24
- </option>
25
- </select>
26
- </template>
27
- <template #content>{{ apiError }}</template>
28
- </atoms-tooltip-error>
29
- <!-- <div id="version-select-help-icon" class="flex-align-center relative">-->
30
- <!-- <atoms-the-icon-->
31
- <!-- fill="#0072a3"-->
32
- <!-- width="24px"-->
33
- <!-- height="24px"-->
34
- <!-- name="info-circle"-->
35
- <!-- @click="isShowHelp = !isShowHelp"-->
36
- <!-- />-->
37
- <!-- <atoms-tooltip-signpost-->
38
- <!-- v-if="isShowHelp"-->
39
- <!-- elem-id="version-select-help-icon"-->
40
- <!-- @hide="isShowHelp = false"-->
41
- <!-- >-->
42
- <!-- <h3 class="help-title">{{ localization.common.help }}</h3>-->
43
-
44
- <!-- <p>-->
45
- <!-- {{-->
46
- <!-- localization.common.eachVirtualMachineCompatibilitySettingIncludesHardwareAvailableVirtualMachine-->
47
- <!-- }}-->
48
- <!-- </p>-->
49
-
50
- <!-- <a id="more-information-link" class="pointer">{{-->
51
- <!-- localization.common.moreInformation-->
52
- <!-- }}</a>-->
53
- <!-- </atoms-tooltip-signpost>-->
54
- <!-- </div>-->
55
- </div>
56
- <p class="select-compatibility-block">
57
- {{ versionDescription }}
58
- </p>
59
- </div>
60
- </template>
61
-
62
- <script setup lang="ts">
63
- import type { UI_I_Localization } from '~/lib/models/interfaces'
64
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
65
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
66
-
67
- const props = defineProps<{
68
- options: UI_I_OptionItem[]
69
- errorValidationFields: UI_I_ErrorValidationField<string>[]
70
- }>()
71
- const emits = defineEmits<{
72
- (event: 'change', value: UI_I_OptionItem): void
73
- (event: 'remove-error-by-title', value: string): void
74
- }>()
75
-
76
- const localization = computed<UI_I_Localization>(() => useLocal())
77
-
78
- const versions = ref<UI_I_OptionItem[]>(props.options)
79
- const selectedVersion = ref<UI_I_OptionItem | null>(null)
80
- watch(
81
- () => props.options,
82
- (newValue) => {
83
- versions.value = [...newValue]
84
- selectedVersion.value = newValue[0]
85
- },
86
- { immediate: true }
87
- )
88
-
89
- const config = useRuntimeConfig()
90
- const description = computed<string>(() => {
91
- return localization.value.common.hostSupportsMoreVirtualMachineVersionSelectCompatibilityVirtualMachine.replaceAll(
92
- '{trademark}',
93
- config.public[`TRADEMARK_${useEnvLanguage()}`]
94
- )
95
- })
96
- const versionDescription = computed<string>(() => {
97
- if (!selectedVersion.value) return ''
98
-
99
- const version = selectedVersion.value.value.split('-')[1]
100
- const text = selectedVersion.value.text
101
-
102
- if (selectedVersion.value === versions.value.at(-1)) {
103
- return localization.value.common.virtualMachineUsesHardwareVersionAvailable
104
- .replace('{0}', version)
105
- .replace('{1}', text)
106
- }
107
-
108
- return localization.value.common.virtualMachineUsesHardwareVersionUnavailable
109
- .replace('{0}', version)
110
- .replace('{1}', text)
111
- })
112
-
113
- watch(
114
- selectedVersion,
115
- (newValue) => {
116
- if (!newValue) return
117
- emits('change', newValue)
118
- },
119
- { immediate: true }
120
- )
121
-
122
- // const isShowHelp = ref(false)
123
-
124
- const apiError = computed<string>(() => {
125
- return (
126
- props.errorValidationFields?.find(
127
- (message) => message.field === 'compatibility'
128
- )?.error_message || ''
129
- )
130
- })
131
-
132
- const onRemoveValidationError = (): void => {
133
- emits('remove-error-by-title', 'compatibility')
134
- }
135
- </script>
136
-
137
- <style scoped lang="scss">
138
- .select-compatibility-block {
139
- margin-top: 12px;
140
- font-size: 13px;
141
-
142
- &.version-select-wrap {
143
- display: flex;
144
- align-items: center;
145
- gap: 6px;
146
-
147
- //#version-select-help-icon {
148
- // .help-title {
149
- // font-size: 22px;
150
- // }
151
- //
152
- // p {
153
- // width: 200px;
154
- // }
155
- //
156
- // a {
157
- // color: #0072a3;
158
- // }
159
- //}
160
- }
161
- }
162
- </style>
1
+ <template>
2
+ <div class="select-compatibility">
3
+ <p class="select-compatibility-block">
4
+ {{ description }}
5
+ </p>
6
+ <div class="select-compatibility-block version-select-wrap">
7
+ <label for="version-select"
8
+ >{{ localization.common.compatibleWith }}:</label
9
+ >
10
+
11
+ <atoms-tooltip-error
12
+ :has-error="!!apiError"
13
+ selector="#vm-wizard-version-select"
14
+ @remove="onRemoveValidationError"
15
+ >
16
+ <template #elem>
17
+ <select
18
+ id="vm-wizard-version-select"
19
+ v-model="selectedVersion"
20
+ data-id="vm-wizard-version-select"
21
+ >
22
+ <option v-for="(item, key) in versions" :key="key" :value="item">
23
+ {{ item.text }}
24
+ </option>
25
+ </select>
26
+ </template>
27
+ <template #content>{{ apiError }}</template>
28
+ </atoms-tooltip-error>
29
+ <!-- <div id="version-select-help-icon" class="flex-align-center relative">-->
30
+ <!-- <atoms-the-icon-->
31
+ <!-- fill="#0072a3"-->
32
+ <!-- width="24px"-->
33
+ <!-- height="24px"-->
34
+ <!-- name="info-circle"-->
35
+ <!-- @click="isShowHelp = !isShowHelp"-->
36
+ <!-- />-->
37
+ <!-- <atoms-tooltip-signpost-->
38
+ <!-- v-if="isShowHelp"-->
39
+ <!-- elem-id="version-select-help-icon"-->
40
+ <!-- @hide="isShowHelp = false"-->
41
+ <!-- >-->
42
+ <!-- <h3 class="help-title">{{ localization.common.help }}</h3>-->
43
+
44
+ <!-- <p>-->
45
+ <!-- {{-->
46
+ <!-- localization.common.eachVirtualMachineCompatibilitySettingIncludesHardwareAvailableVirtualMachine-->
47
+ <!-- }}-->
48
+ <!-- </p>-->
49
+
50
+ <!-- <a id="more-information-link" class="pointer">{{-->
51
+ <!-- localization.common.moreInformation-->
52
+ <!-- }}</a>-->
53
+ <!-- </atoms-tooltip-signpost>-->
54
+ <!-- </div>-->
55
+ </div>
56
+ <p class="select-compatibility-block">
57
+ {{ versionDescription }}
58
+ </p>
59
+ </div>
60
+ </template>
61
+
62
+ <script setup lang="ts">
63
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
64
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
65
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
66
+
67
+ const props = defineProps<{
68
+ options: UI_I_OptionItem[]
69
+ errorValidationFields: UI_I_ErrorValidationField<string>[]
70
+ }>()
71
+ const emits = defineEmits<{
72
+ (event: 'change', value: UI_I_OptionItem): void
73
+ (event: 'remove-error-by-title', value: string): void
74
+ }>()
75
+
76
+ const localization = computed<UI_I_Localization>(() => useLocal())
77
+
78
+ const versions = ref<UI_I_OptionItem[]>(props.options)
79
+ const selectedVersion = ref<UI_I_OptionItem | null>(null)
80
+ watch(
81
+ () => props.options,
82
+ (newValue) => {
83
+ versions.value = [...newValue]
84
+ selectedVersion.value = newValue[0]
85
+ },
86
+ { immediate: true }
87
+ )
88
+
89
+ const config = useRuntimeConfig()
90
+ const description = computed<string>(() => {
91
+ return localization.value.common.hostSupportsMoreVirtualMachineVersionSelectCompatibilityVirtualMachine.replaceAll(
92
+ '{trademark}',
93
+ config.public[`TRADEMARK_${useEnvLanguage()}`]
94
+ )
95
+ })
96
+ const versionDescription = computed<string>(() => {
97
+ if (!selectedVersion.value) return ''
98
+
99
+ const version = selectedVersion.value.value.split('-')[1]
100
+ const text = selectedVersion.value.text
101
+
102
+ if (selectedVersion.value === versions.value.at(-1)) {
103
+ return localization.value.common.virtualMachineUsesHardwareVersionAvailable
104
+ .replace('{0}', version)
105
+ .replace('{1}', text)
106
+ }
107
+
108
+ return localization.value.common.virtualMachineUsesHardwareVersionUnavailable
109
+ .replace('{0}', version)
110
+ .replace('{1}', text)
111
+ })
112
+
113
+ watch(
114
+ selectedVersion,
115
+ (newValue) => {
116
+ if (!newValue) return
117
+ emits('change', newValue)
118
+ },
119
+ { immediate: true }
120
+ )
121
+
122
+ // const isShowHelp = ref(false)
123
+
124
+ const apiError = computed<string>(() => {
125
+ return (
126
+ props.errorValidationFields?.find(
127
+ (message) => message.field === 'compatibility'
128
+ )?.error_message || ''
129
+ )
130
+ })
131
+
132
+ const onRemoveValidationError = (): void => {
133
+ emits('remove-error-by-title', 'compatibility')
134
+ }
135
+ </script>
136
+
137
+ <style scoped lang="scss">
138
+ .select-compatibility-block {
139
+ margin-top: 12px;
140
+ font-size: 13px;
141
+
142
+ &.version-select-wrap {
143
+ display: flex;
144
+ align-items: center;
145
+ gap: 6px;
146
+
147
+ //#version-select-help-icon {
148
+ // .help-title {
149
+ // font-size: 22px;
150
+ // }
151
+ //
152
+ // p {
153
+ // width: 200px;
154
+ // }
155
+ //
156
+ // a {
157
+ // color: #0072a3;
158
+ // }
159
+ //}
160
+ }
161
+ }
162
+ </style>
@@ -1,74 +1,38 @@
1
- <template>
2
- <div class="select-create-type">
3
- <atoms-list-select-list
4
- v-model="model"
5
- class="select"
6
- :items="items"
7
- />
8
- <p class="description">
9
- {{ description }}
10
- </p>
11
- </div>
12
- </template>
13
-
14
- <script setup lang="ts">
15
- import type { UI_I_Localization } from '~/lib/models/interfaces'
16
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
17
- import { itemsFunc } from '~/components/common/vm/actions/common/select/createType/lib/config/items'
18
-
19
- const model = defineModel<string>()
20
-
21
- const props = defineProps<{
22
- importFromVMWarevSphere: string
23
- }>()
24
-
25
- const localization = computed<UI_I_Localization>(() => useLocal())
26
-
27
- const items = computed<UI_I_OptionItem[]>(() =>
28
- itemsFunc(localization.value, props.importFromVMWarevSphere)
29
- )
30
- const description = computed<string>(() => {
31
- let result = ''
32
- switch (model.value) {
33
- case '0':
34
- result = localization.value.common.newVmCreateDescription
35
- break
36
- case '1':
37
- result = localization.value.vmWizard.deployFromTemplateDescription
38
- break
39
- }
40
- return result
41
- })
42
- </script>
43
-
44
- <style scoped lang="scss">
45
- .select-create-type {
46
- display: flex;
47
- padding-top: 12px;
48
-
49
- .description {
50
- color: #333333;
51
- font-size: 13px;
52
- }
53
-
54
- .description,
55
- .select {
56
- flex: 1 1 100%;
57
- margin-right: 5px;
58
- }
59
-
60
- :deep(select) {
61
- background-color: transparent;
62
- border-color: var(--type-list-border-color);
63
- }
64
- }
65
- </style>
66
-
67
- <style>
68
- :root {
69
- --type-list-border-color: #ccc;
70
- }
71
- :root.dark-theme {
72
- --type-list-border-color: #000;
73
- }
74
- </style>
1
+ <template>
2
+ <common-vm-actions-common-select-create-type-new
3
+ v-if="isNewView"
4
+ v-model="model"
5
+ :items="items"
6
+ :import-from-v-m-warev-sphere="props.importFromVMWarevSphere"
7
+ />
8
+ <common-vm-actions-common-select-create-type-old
9
+ v-else
10
+ v-model="model"
11
+ :items="items"
12
+ :import-from-v-m-warev-sphere="props.importFromVMWarevSphere"
13
+ />
14
+ </template>
15
+
16
+ <script setup lang="ts">
17
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
18
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
19
+ import { itemsFunc } from '~/components/common/vm/actions/common/select/createType/lib/config/items'
20
+
21
+ const model = defineModel<string>()
22
+
23
+ const props = defineProps<{
24
+ importFromVMWarevSphere: string
25
+ }>()
26
+
27
+ const { $store }: any = useNuxtApp()
28
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
29
+
30
+ const localization = computed<UI_I_Localization>(() => useLocal())
31
+
32
+ const items = computed<UI_I_OptionItem[]>(() =>
33
+ itemsFunc(localization.value, props.importFromVMWarevSphere)
34
+ )
35
+ </script>
36
+
37
+ <style scoped lang="scss">
38
+ </style>
@@ -0,0 +1,84 @@
1
+ <template>
2
+ <div class="select-create-type">
3
+ <div
4
+ v-for="item in props.items"
5
+ v-development="item.disabled"
6
+ :key="item.value"
7
+ :class="[
8
+ 'select-create-type-block',
9
+ { selected: item.value === model, disabled: item.disabled },
10
+ ]"
11
+ @click="model = item.value"
12
+ >
13
+ <ui-radio
14
+ v-model="model"
15
+ :label="item.text"
16
+ :value="item.value"
17
+ :test-id="item.testId"
18
+ :disabled="item.disabled"
19
+ size="md"
20
+ />
21
+
22
+ <p class="description">
23
+ {{ item.description }}
24
+ </p>
25
+ </div>
26
+ </div>
27
+ </template>
28
+
29
+ <script setup lang="ts">
30
+ import type { UI_I_VmCreateTypeOption } from '~/components/common/vm/actions/common/select/createType/lib/models/interfaces'
31
+
32
+ const model = defineModel<string>()
33
+
34
+ const props = defineProps<{
35
+ items: UI_I_VmCreateTypeOption[]
36
+ }>()
37
+ </script>
38
+
39
+ <style>
40
+ :root {
41
+ --select-create-type-block-bg-color: #ffffff;
42
+ --select-create-type-block-border-color: #e9ebed;
43
+ --select-create-type-block-border-hover-color: #d3d6da;
44
+ --select-create-type-block-selected-bg-color: #f0f8fd;
45
+ --select-create-type-block-selected-border-color: #008fd6;
46
+ }
47
+ :root.dark-theme {
48
+ --select-create-type-block-bg-color: transparent;
49
+ --select-create-type-block-border-color: #e9ebed1f;
50
+ --select-create-type-block-border-hover-color: #e9ebed3d;
51
+ --select-create-type-block-selected-bg-color: #2ba2de14;
52
+ --select-create-type-block-selected-border-color: #2ba2de;
53
+ }
54
+ </style>
55
+ <style scoped lang="scss">
56
+ .select-create-type-block {
57
+ background-color: var(--select-create-type-block-bg-color);
58
+ border: 1px solid var(--select-create-type-block-border-color);
59
+ padding: 12px;
60
+ border-radius: 8px;
61
+
62
+ &:not(.selected):not(.disabled) {
63
+ cursor: pointer;
64
+ &:hover {
65
+ border-color: var(--select-create-type-block-border-hover-color);
66
+ }
67
+ }
68
+
69
+ &.selected {
70
+ background-color: var(--select-create-type-block-selected-bg-color);
71
+ border: 1.5px solid var(--select-create-type-block-selected-border-color);
72
+ }
73
+
74
+ &:not(:last-child) {
75
+ margin-bottom: 12px;
76
+ }
77
+
78
+ .description {
79
+ font-size: 13px;
80
+ color: #9da6ad;
81
+ margin: 8px 0 0 28px;
82
+ }
83
+ }
84
+ </style>