bfg-common 1.5.242 → 1.5.243

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 (173) 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 +0 -6
  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/storage/actions/add/Add.vue +247 -247
  17. package/components/common/backup/storage/actions/add/New.vue +292 -281
  18. package/components/common/backup/storage/actions/add/Old.vue +114 -114
  19. package/components/common/backup/storage/actions/add/lib/config/steps.ts +168 -168
  20. package/components/common/backup/storage/actions/add/steps/nameAndConfigure/NameAndConfigure.vue +41 -41
  21. package/components/common/backup/storage/actions/add/steps/nameAndConfigure/NameAndConfigureNew.vue +314 -294
  22. package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyComplete.vue +45 -45
  23. package/components/common/backup/storage/actions/add/steps/readyComplete/lib/config/propertiesDetails.ts +242 -242
  24. package/components/common/backup/storage/actions/add/steps/typeMode/TypeModeNew.vue +18 -3
  25. package/components/common/backup/storage/actions/delete/Delete.vue +65 -65
  26. package/components/common/browse/BrowseNew.vue +2 -8
  27. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  28. package/components/common/context/lib/models/interfaces.ts +31 -31
  29. package/components/common/diagramMain/DiagramMain.vue +897 -897
  30. package/components/common/diagramMain/Header.vue +214 -214
  31. package/components/common/layout/theHeader/feedback/new/additionalDetails/Headline.vue +76 -66
  32. package/components/common/layout/theHeader/feedback/new/subtitle/Subtitle.vue +80 -70
  33. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  34. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  35. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  36. package/components/common/pages/home/headline/Headline.vue +45 -45
  37. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  38. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  39. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  40. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  41. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  42. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  43. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  44. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  45. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  46. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  47. package/components/common/pages/packages/Packages.vue +208 -208
  48. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  49. package/components/common/pages/tasks/table/Table.vue +25 -7
  50. package/components/common/pages/tasks/table/expandDetails/ExpandDetails.vue +27 -9
  51. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  52. package/components/common/recursionTree/RecursionTree.vue +223 -223
  53. package/components/common/select/button/ButtonDropdown.vue +108 -108
  54. package/components/common/spiceConsole/Drawer.vue +377 -377
  55. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  56. package/components/common/tooltip/Help.vue +181 -0
  57. package/components/common/tooltip/lib/models/types.ts +1 -0
  58. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  59. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  60. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  61. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  62. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  63. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +2 -5
  64. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +7 -7
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +319 -319
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +100 -100
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusNew.vue +104 -95
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveNew.vue +0 -4
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +78 -78
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuNew.vue +59 -8
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/model/ModelNew.vue +132 -109
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/SharesNew.vue +1 -6
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipNew.vue +154 -154
  81. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  82. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +307 -307
  83. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryNew.vue +1 -5
  84. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/hotPlug/HotPlugNew.vue +2 -8
  85. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +382 -382
  86. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskNew.vue +0 -4
  87. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/file/FileNew.vue +3 -8
  88. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +151 -151
  89. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationNew.vue +73 -73
  90. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +83 -83
  91. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/maximumSize/MaximumSizeNew.vue +4 -8
  92. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/provisioning/ProvisioningNew.vue +1 -6
  93. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/SharingNew.vue +1 -6
  94. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -288
  95. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkNew.vue +1 -1
  96. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/New.vue +3 -4
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/Table.vue +0 -1
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  102. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  103. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  104. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  105. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  106. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  107. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  108. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  109. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerNew.vue +0 -1
  110. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  111. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +2 -8
  112. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/inputDevices/InputDevicesNew.vue +40 -40
  113. package/components/common/vm/actions/common/customizeHardware/virtualHardware/reservation/ReservationNew.vue +2 -5
  114. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +2 -5
  115. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  116. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +1 -5
  117. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  118. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  119. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  120. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +0 -4
  121. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +0 -1
  122. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +2 -8
  123. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +31 -31
  124. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +31 -31
  125. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  126. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  127. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordNew.vue +128 -128
  128. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  129. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +39 -39
  130. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  131. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/ToolsNew.vue +1 -5
  132. package/components/common/vm/actions/common/lib/utils/capabilities.ts +52 -52
  133. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  134. package/components/common/vm/actions/common/select/computeResource/treeView/New.vue +44 -44
  135. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +118 -118
  136. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  137. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  138. package/components/common/vm/actions/common/select/name/New.vue +52 -69
  139. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  140. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  141. package/components/common/vm/actions/common/select/storage/new/New.vue +1 -5
  142. package/components/common/vm/actions/common/select/storage/new/lib/config/table.ts +1 -2
  143. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  144. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  145. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  146. package/components/common/wizards/datastore/add/New.vue +14 -3
  147. package/components/common/wizards/datastore/add/steps/nameAndConfigure/NameAndConfigureNew.vue +27 -6
  148. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceNew.vue +15 -3
  149. package/components/common/wizards/datastore/add/steps/typeMode/TypeModeNew.vue +14 -3
  150. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  151. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  152. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  153. package/components/common/wizards/vm/migrate/select/computeResource/tableView/TableView.vue +137 -135
  154. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  155. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  156. package/composables/productNameLocal.ts +30 -30
  157. package/composables/useAppVersion.ts +21 -21
  158. package/lib/utils/utils.ts +2 -14
  159. package/package.json +2 -2
  160. package/plugins/date.ts +233 -233
  161. package/plugins/text.ts +48 -59
  162. package/public/spice-console/lib/images/bitmap.js +203 -203
  163. package/public/spice-console/network/spicechannel.js +387 -387
  164. package/store/main/mutations.ts +7 -7
  165. package/store/main/state.ts +7 -7
  166. package/store/tasks/mappers/recentTasks.ts +64 -64
  167. package/components/common/backup/actions/deleteBackup/DeleteBackup.vue +0 -38
  168. package/plugins/cron.ts +0 -75
  169. package/plugins/helpers.ts +0 -18
  170. package/plugins/number.ts +0 -18
  171. package/plugins/panelStates.ts +0 -70
  172. package/plugins/time.ts +0 -17
  173. /package/{lib/models/plugins/panelStates → components/common/split/horizontal/lib/models}/interfaces.ts +0 -0
@@ -1,10 +1,6 @@
1
1
  <template>
2
2
  <div class="hardware-cpu">
3
- <ui-stack-block
4
- :has-children="true"
5
- test-id="cpu-stack-block"
6
- is-toggle-on-stack-view-key
7
- >
3
+ <ui-stack-block :has-children="true" test-id="cpu-stack-block">
8
4
  <template #stackBlockKey>
9
5
  <div
10
6
  id="vm-wizard-toggle-block-cpu"
@@ -34,9 +30,42 @@
34
30
  width="auto"
35
31
  />
36
32
 
37
- <common-vm-actions-common-customize-hardware-virtual-hardware-cpu-tooltip
38
- :vm-cpu-help-text-second="props.vmCpuHelpTextSecond"
39
- />
33
+ <!-- <common-vm-actions-common-customize-hardware-virtual-hardware-cpu-tooltip-->
34
+ <!-- :vm-cpu-help-text-second="props.vmCpuHelpTextSecond"-->
35
+ <!-- />-->
36
+
37
+ <common-tooltip-help
38
+ test-id="cpu-help-tooltip"
39
+ help-id="cpu-help-tooltip-icon"
40
+ icon-width="20"
41
+ icon-height="20"
42
+ :title="localization.common.cpu"
43
+ :dropdown-left="true"
44
+ dropdown-width="480px"
45
+ >
46
+ <div class="cpu-info-block">
47
+ <p class="help-text">
48
+ {{ localization.common.vmCpuHelpText1 }}
49
+ </p>
50
+ <p class="help-text">
51
+ {{ props.vmCpuHelpTextSecond }}
52
+ </p>
53
+ <p class="help-text">
54
+ {{ localization.common.vmCpuHelpText3 }}
55
+ </p>
56
+ <p class="help-text">
57
+ {{ localization.common.vmCpuHelpText4 }}
58
+ </p>
59
+ <div>
60
+ <a
61
+ id="cpu-more-info-link"
62
+ href="javascript:void(0)"
63
+ class="cpu-more-info"
64
+ >{{ localization.common.moreInformation }}</a
65
+ >
66
+ </div>
67
+ </div>
68
+ </common-tooltip-help>
40
69
  </div>
41
70
  </template>
42
71
  <template #stackChildren>
@@ -173,6 +202,16 @@ const emits = defineEmits<{
173
202
  const localization = computed<UI_I_Localization>(() => useLocal())
174
203
  </script>
175
204
 
205
+ <style>
206
+ :root {
207
+ --help-color: #4d5d69;
208
+ --cpu-help-more-info-color: #008fd6;
209
+ }
210
+ :root.dark-theme {
211
+ --help-color: #e9eaec;
212
+ --cpu-help-more-info-color: #2ba2de;
213
+ }
214
+ </style>
176
215
  <style scoped lang="scss">
177
216
  :deep(.ui-main-select-toggle) {
178
217
  display: flex;
@@ -191,4 +230,16 @@ const localization = computed<UI_I_Localization>(() => useLocal())
191
230
  :deep(.unit .ui-main-select-toggle) {
192
231
  width: 80px;
193
232
  }
233
+ .cpu-info-block {
234
+ :deep(.help-text) {
235
+ margin-bottom: 12px;
236
+ }
237
+ :deep(.cpu-more-info) {
238
+ font-size: 13px;
239
+ font-weight: 500;
240
+ line-height: 15.73px;
241
+ color: var(--cpu-help-more-info-color);
242
+ text-decoration: none;
243
+ }
244
+ }
194
245
  </style>
@@ -1,9 +1,7 @@
1
1
  <template>
2
2
  <ui-stack-block :has-children="false">
3
3
  <template #stackBlockKey>
4
- <span class="limit-title">
5
- {{ localization.common.cpuModel }}
6
- </span>
4
+ {{ localization.common.cpuModel }}
7
5
  </template>
8
6
  <template #stackBlockContent>
9
7
  <div class="cpu-model-content">
@@ -25,57 +23,74 @@
25
23
  test-id="passthrough-host-cpu"
26
24
  @change="emits('change-passthrough-host-cpu', $event)"
27
25
  />
28
- <div id="passthrough-help-icon" class="flex-align-center relative">
29
- <ui-icon
30
- width="16"
31
- height="16"
32
- name="info"
33
- data-id="show-passthrough-help-icon"
34
- :class="[
35
- 'passthrough-help-icon cursor-pointer disabled',
36
- { active: isShowPassthroughHost },
37
- ]"
38
- @click.stop="isShowPassthroughHost = !isShowPassthroughHost"
39
- />
40
- <Teleport to="body">
41
- <ui-dropdown
42
- :show="isShowPassthroughHost"
43
- :items="[]"
44
- elem-id="passthrough-help-icon"
45
- test-id=""
46
- width="480px"
47
- left
48
- @hide="isShowPassthroughHost = false"
49
- >
50
- <template #content>
51
- <div class="help-content">
52
- <div class="headline">
53
- <ui-icon name="info-2" width="16" height="16" />
54
- <h3 class="help-title">
55
- {{ localization.mainNavigation.help }}
56
- </h3>
57
- <ui-icon
58
- name="close"
59
- width="16"
60
- height="16"
61
- class="cursor-pointer"
62
- @click="isShowPassthroughHost = false"
63
- />
64
- </div>
65
-
66
- <p class="help-text">
67
- Lorem ipsum dolor sit amet, consectetur adipisicing elit.
68
- A cum eius expedita, fuga mollitia perferendis quod soluta
69
- vel? Dolor, illo, nam? A consequatur, consequuntur eos
70
- impedit iusto labore sunt tempora!
71
- </p>
72
- </div>
73
- </template>
74
- </ui-dropdown>
75
- </Teleport>
76
- </div>
26
+
27
+ <common-tooltip-help
28
+ class="ml-2"
29
+ test-id="passthrough-help"
30
+ help-id="passthrough-help-icon"
31
+ :dropdown-left="true"
32
+ :is-disabled="true"
33
+ dropdown-width="480px"
34
+ >
35
+ <p class="help-text">
36
+ Lorem ipsum dolor sit amet, consectetur adipisicing elit.
37
+ A cum eius expedita, fuga mollitia perferendis quod soluta
38
+ vel? Dolor, illo, nam? A consequatur, consequuntur eos
39
+ impedit iusto labore sunt tempora!
40
+ </p>
41
+ </common-tooltip-help>
42
+
43
+ <!-- <div id="passthrough-help-icon" class="flex-align-center relative">-->
44
+ <!-- <ui-icon-->
45
+ <!-- width="16"-->
46
+ <!-- height="16"-->
47
+ <!-- name="info"-->
48
+ <!-- data-id="show-passthrough-help-icon"-->
49
+ <!-- :class="[-->
50
+ <!-- 'passthrough-help-icon cursor-pointer',-->
51
+ <!-- { active: isShowPassthroughHost },-->
52
+ <!-- ]"-->
53
+ <!-- @click.stop="isShowPassthroughHost = !isShowPassthroughHost"-->
54
+ <!-- />-->
55
+ <!-- <Teleport to="body">-->
56
+ <!-- <ui-dropdown-->
57
+ <!-- :show="isShowPassthroughHost"-->
58
+ <!-- :items="[]"-->
59
+ <!-- elem-id="passthrough-help-icon"-->
60
+ <!-- test-id=""-->
61
+ <!-- width="480px"-->
62
+ <!-- left-->
63
+ <!-- @hide="isShowPassthroughHost = false"-->
64
+ <!-- >-->
65
+ <!-- <template #content>-->
66
+ <!-- <div class="help-content">-->
67
+ <!-- <div class="headline">-->
68
+ <!-- <ui-icon name="info-2" width="16" height="16" />-->
69
+ <!-- <h3 class="help-title">-->
70
+ <!-- {{ localization.mainNavigation.help }}-->
71
+ <!-- </h3>-->
72
+ <!-- <ui-icon-->
73
+ <!-- name="close"-->
74
+ <!-- width="16"-->
75
+ <!-- height="16"-->
76
+ <!-- class="cursor-pointer"-->
77
+ <!-- @click="isShowPassthroughHost = false"-->
78
+ <!-- />-->
79
+ <!-- </div>-->
80
+
81
+ <!-- <p class="help-text">-->
82
+ <!-- Lorem ipsum dolor sit amet, consectetur adipisicing elit.-->
83
+ <!-- A cum eius expedita, fuga mollitia perferendis quod soluta-->
84
+ <!-- vel? Dolor, illo, nam? A consequatur, consequuntur eos-->
85
+ <!-- impedit iusto labore sunt tempora!-->
86
+ <!-- </p>-->
87
+ <!-- </div>-->
88
+ <!-- </template>-->
89
+ <!-- </ui-dropdown>-->
90
+ <!-- </Teleport>-->
91
+ <!-- </div>-->
77
92
  </div>
78
- <div class="host-model-cpu-wrap flex-align-center">
93
+ <div class="flex-align-center">
79
94
  <ui-checkbox
80
95
  v-model="hostModelCpu"
81
96
  :disabled="props.disabled"
@@ -83,55 +98,70 @@
83
98
  test-id="host-model-cpu"
84
99
  @change="emits('change-host-model-cpu', $event)"
85
100
  />
86
- <div id="host-model-help-icon" class="flex-align-center relative">
87
- <ui-icon
88
- width="16"
89
- height="16"
90
- name="info"
91
- data-id="show-host-model-help-icon"
92
- :class="[
93
- 'host-model-help-icon cursor-pointer disabled',
94
- { active: isShowHostModel },
95
- ]"
96
- @click.stop="isShowHostModel = !isShowHostModel"
97
- />
98
- <Teleport to="body">
99
- <ui-dropdown
100
- :show="isShowHostModel"
101
- :items="[]"
102
- elem-id="host-model-help-icon"
103
- test-id=""
104
- width="480px"
105
- left
106
- @hide="isShowHostModel = false"
107
- >
108
- <template #content>
109
- <div class="help-content">
110
- <div class="headline">
111
- <ui-icon name="info-2" width="16" height="16" />
112
- <h3 class="help-title">
113
- {{ localization.mainNavigation.help }}
114
- </h3>
115
- <ui-icon
116
- name="close"
117
- width="16"
118
- height="16"
119
- class="cursor-pointer"
120
- @click="isShowHostModel = false"
121
- />
122
- </div>
123
-
124
- <p class="help-text">
125
- Lorem ipsum dolor sit amet, consectetur adipisicing elit.
126
- A cum eius expedita, fuga mollitia perferendis quod soluta
127
- vel? Dolor, illo, nam? A consequatur, consequuntur eos
128
- impedit iusto labore sunt tempora!
129
- </p>
130
- </div>
131
- </template>
132
- </ui-dropdown>
133
- </Teleport>
134
- </div>
101
+
102
+ <common-tooltip-help
103
+ test-id="host-model-help"
104
+ help-id="host-model-help-icon"
105
+ :dropdown-left="true"
106
+ :is-disabled="true"
107
+ dropdown-width="480px"
108
+ >
109
+ <p class="help-text">
110
+ Lorem ipsum dolor sit amet, consectetur adipisicing elit.
111
+ A cum eius expedita, fuga mollitia perferendis quod soluta
112
+ vel? Dolor, illo, nam? A consequatur, consequuntur eos
113
+ impedit iusto labore sunt tempora!
114
+ </p>
115
+ </common-tooltip-help>
116
+ <!-- <div id="host-model-help-icon" class="flex-align-center relative">-->
117
+ <!-- <ui-icon-->
118
+ <!-- width="16"-->
119
+ <!-- height="16"-->
120
+ <!-- name="info"-->
121
+ <!-- data-id="show-host-model-help-icon"-->
122
+ <!-- :class="[-->
123
+ <!-- 'host-model-help-icon cursor-pointer disabled',-->
124
+ <!-- { active: isShowHostModel },-->
125
+ <!-- ]"-->
126
+ <!-- @click.stop="isShowHostModel = !isShowHostModel"-->
127
+ <!-- />-->
128
+ <!-- <Teleport to="body">-->
129
+ <!-- <ui-dropdown-->
130
+ <!-- :show="isShowHostModel"-->
131
+ <!-- :items="[]"-->
132
+ <!-- elem-id="host-model-help-icon"-->
133
+ <!-- test-id=""-->
134
+ <!-- width="480px"-->
135
+ <!-- left-->
136
+ <!-- @hide="isShowHostModel = false"-->
137
+ <!-- >-->
138
+ <!-- <template #content>-->
139
+ <!-- <div class="help-content">-->
140
+ <!-- <div class="headline">-->
141
+ <!-- <ui-icon name="info-2" width="16" height="16" />-->
142
+ <!-- <h3 class="help-title">-->
143
+ <!-- {{ localization.mainNavigation.help }}-->
144
+ <!-- </h3>-->
145
+ <!-- <ui-icon-->
146
+ <!-- name="close"-->
147
+ <!-- width="16"-->
148
+ <!-- height="16"-->
149
+ <!-- class="cursor-pointer"-->
150
+ <!-- @click="isShowHostModel = false"-->
151
+ <!-- />-->
152
+ <!-- </div>-->
153
+
154
+ <!-- <p class="help-text">-->
155
+ <!-- Lorem ipsum dolor sit amet, consectetur adipisicing elit.-->
156
+ <!-- A cum eius expedita, fuga mollitia perferendis quod soluta-->
157
+ <!-- vel? Dolor, illo, nam? A consequatur, consequuntur eos-->
158
+ <!-- impedit iusto labore sunt tempora!-->
159
+ <!-- </p>-->
160
+ <!-- </div>-->
161
+ <!-- </template>-->
162
+ <!-- </ui-dropdown>-->
163
+ <!-- </Teleport>-->
164
+ <!-- </div>-->
135
165
  </div>
136
166
  </div>
137
167
  </template>
@@ -181,9 +211,6 @@ const onChangeCpuModel = (data: UI_T_SelectedValue): void => {
181
211
  }
182
212
  </style>
183
213
  <style scoped lang="scss">
184
- .limit-title {
185
- margin-right: 12px;
186
- }
187
214
  .cpu-model-content {
188
215
  display: flex;
189
216
  flex-direction: column;
@@ -193,10 +220,6 @@ const onChangeCpuModel = (data: UI_T_SelectedValue): void => {
193
220
  :deep(.ui-main-select-toggle) {
194
221
  width: 100%;
195
222
  }
196
- .passthrough-host-cpu-wrap :deep(.ui-checkbox-label),
197
- .host-model-cpu-wrap :deep(.ui-checkbox-label) {
198
- min-height: unset !important;
199
- }
200
223
  }
201
224
 
202
225
  #passthrough-help-icon,
@@ -1,140 +1,140 @@
1
- <template>
2
- <common-vm-actions-common-customize-hardware-virtual-hardware-cpu-shares-new
3
- v-if="isNewView"
4
- v-model:shares-type="sharesTypeLocal"
5
- v-model:shares="sharesLocal"
6
- :disabled="props.disabled"
7
- :shares-type-options="sharesTypeOptions"
8
- :shares-errors-texts="sharesLocalAndApiErrorsTexts"
9
- :shares-options="sharesOptions"
10
- :is-disabled-shares="isDisabledShares"
11
- @change-shares-type="onChangeSharesType"
12
- @remove-error="onRemoveValidationError"
13
- />
14
- <common-vm-actions-common-customize-hardware-virtual-hardware-cpu-shares-old
15
- v-else
16
- v-model:shares-type="sharesTypeLocal"
17
- v-model:shares="sharesLocal"
18
- :disabled="props.disabled"
19
- :shares-type-options="sharesTypeOptions"
20
- :shares-errors-texts="sharesLocalAndApiErrorsTexts"
21
- :shares-options="sharesOptions"
22
- :is-disabled-shares="isDisabledShares"
23
- @change-shares-type="onChangeSharesType"
24
- @remove-error="onRemoveValidationError"
25
- />
26
- </template>
27
-
28
- <script setup lang="ts">
29
- import type {
30
- UI_I_Localization,
31
- UI_I_HTMLSelectElement,
32
- } from '~/lib/models/interfaces'
33
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
34
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
35
- import {
36
- sharesTypeOptionsFunc,
37
- sharesOptionsFunc,
38
- } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options'
39
-
40
- const props = defineProps<{
41
- shares: string
42
- sharesType: string
43
- disabled: boolean
44
- errorValidationFields: UI_I_ErrorValidationField<string>[]
45
- }>()
46
- const emits = defineEmits<{
47
- (event: 'update:shares', value: string): void
48
- (event: 'update:shares-type', value: string): void
49
- (event: 'invalid', value: boolean): void
50
- (event: 'remove-error-by-title', value: string): void
51
- }>()
52
-
53
- const { $store }: any = useNuxtApp()
54
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
55
-
56
- const localization = computed<UI_I_Localization>(() => useLocal())
57
-
58
- const apiErrorLocal = computed<string>(() => {
59
- return (
60
- props.errorValidationFields?.find(
61
- (message) => message.field === 'cpu.shares'
62
- )?.error_message || ''
63
- )
64
- })
65
-
66
- const maxShares = 262_144
67
- const sharesOptions = computed<UI_I_OptionItem[]>(() => {
68
- return sharesOptionsFunc(localization.value, maxShares)
69
- })
70
-
71
- const sharesTypeOptions = ref<UI_I_OptionItem[]>(
72
- sharesTypeOptionsFunc(localization.value)
73
- )
74
-
75
- const isDisabledShares = computed<boolean>(
76
- () => sharesTypeLocal.value !== '2' || props.disabled
77
- )
78
- const sharesLocal = computed<string>({
79
- get() {
80
- return props.shares
81
- },
82
- set(newValue) {
83
- emits('update:shares', newValue)
84
- },
85
- })
86
- const sharesTypeLocal = computed<string>({
87
- get() {
88
- return props.sharesType
89
- },
90
- set(newValue) {
91
- emits('update:shares-type', newValue)
92
- },
93
- })
94
- const onChangeSharesType = (event: UI_I_HTMLSelectElement): void => {
95
- const value = event.target.value
96
- if (value === '2') return
97
- sharesLocal.value = event.target.value
98
- }
99
-
100
- const sharesErrorLocalText = computed<string>(() => {
101
- if (+sharesLocal.value < 2 || +sharesLocal.value > maxShares) {
102
- return localization.value.common.sharesMustBe
103
- .replace('{0}', '2')
104
- .replace('{1}', maxShares + '')
105
- }
106
-
107
- const validValue = /^\d+(\.\d+)?$/.test(sharesLocal.value + '')
108
- if (!validValue) {
109
- return localization.value.common.inputContainsInvalidCharacters
110
- }
111
-
112
- return ''
113
- })
114
- const sharesInvalid = computed<boolean>(() => !!sharesErrorLocalText.value)
115
- watch(
116
- sharesInvalid,
117
- (newValue) => {
118
- emits('invalid', newValue)
119
- },
120
- { immediate: true }
121
- )
122
-
123
- const sharesLocalAndApiErrorsTexts = computed<string>(() => {
124
- const localError = sharesErrorLocalText.value
125
- const apiError = apiErrorLocal.value
126
-
127
- let result = ''
128
- if (localError && !apiError) result = localError
129
- if (localError && apiError) result = localError + ', ' + apiError
130
- if (!localError) result = apiError
131
-
132
- return result
133
- })
134
-
135
- const onRemoveValidationError = (): void => {
136
- emits('remove-error-by-title', 'cpu.shares')
137
- }
138
- </script>
139
-
140
- <style scoped></style>
1
+ <template>
2
+ <common-vm-actions-common-customize-hardware-virtual-hardware-cpu-shares-new
3
+ v-if="isNewView"
4
+ v-model:shares-type="sharesTypeLocal"
5
+ v-model:shares="sharesLocal"
6
+ :disabled="props.disabled"
7
+ :shares-type-options="sharesTypeOptions"
8
+ :shares-errors-texts="sharesLocalAndApiErrorsTexts"
9
+ :shares-options="sharesOptions"
10
+ :is-disabled-shares="isDisabledShares"
11
+ @change-shares-type="onChangeSharesType"
12
+ @remove-error="onRemoveValidationError"
13
+ />
14
+ <common-vm-actions-common-customize-hardware-virtual-hardware-cpu-shares-old
15
+ v-else
16
+ v-model:shares-type="sharesTypeLocal"
17
+ v-model:shares="sharesLocal"
18
+ :disabled="props.disabled"
19
+ :shares-type-options="sharesTypeOptions"
20
+ :shares-errors-texts="sharesLocalAndApiErrorsTexts"
21
+ :shares-options="sharesOptions"
22
+ :is-disabled-shares="isDisabledShares"
23
+ @change-shares-type="onChangeSharesType"
24
+ @remove-error="onRemoveValidationError"
25
+ />
26
+ </template>
27
+
28
+ <script setup lang="ts">
29
+ import type {
30
+ UI_I_Localization,
31
+ UI_I_HTMLSelectElement,
32
+ } from '~/lib/models/interfaces'
33
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
34
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
35
+ import {
36
+ sharesTypeOptionsFunc,
37
+ sharesOptionsFunc,
38
+ } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options'
39
+
40
+ const props = defineProps<{
41
+ shares: string
42
+ sharesType: string
43
+ disabled: boolean
44
+ errorValidationFields: UI_I_ErrorValidationField<string>[]
45
+ }>()
46
+ const emits = defineEmits<{
47
+ (event: 'update:shares', value: string): void
48
+ (event: 'update:shares-type', value: string): void
49
+ (event: 'invalid', value: boolean): void
50
+ (event: 'remove-error-by-title', value: string): void
51
+ }>()
52
+
53
+ const { $store }: any = useNuxtApp()
54
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
55
+
56
+ const localization = computed<UI_I_Localization>(() => useLocal())
57
+
58
+ const apiErrorLocal = computed<string>(() => {
59
+ return (
60
+ props.errorValidationFields?.find(
61
+ (message) => message.field === 'cpu.shares'
62
+ )?.error_message || ''
63
+ )
64
+ })
65
+
66
+ const maxShares = 262_144
67
+ const sharesOptions = computed<UI_I_OptionItem[]>(() => {
68
+ return sharesOptionsFunc(localization.value, maxShares)
69
+ })
70
+
71
+ const sharesTypeOptions = ref<UI_I_OptionItem[]>(
72
+ sharesTypeOptionsFunc(localization.value)
73
+ )
74
+
75
+ const isDisabledShares = computed<boolean>(
76
+ () => sharesTypeLocal.value !== '2' || props.disabled
77
+ )
78
+ const sharesLocal = computed<string>({
79
+ get() {
80
+ return props.shares
81
+ },
82
+ set(newValue) {
83
+ emits('update:shares', newValue)
84
+ },
85
+ })
86
+ const sharesTypeLocal = computed<string>({
87
+ get() {
88
+ return props.sharesType
89
+ },
90
+ set(newValue) {
91
+ emits('update:shares-type', newValue)
92
+ },
93
+ })
94
+ const onChangeSharesType = (event: UI_I_HTMLSelectElement): void => {
95
+ const value = event.target.value
96
+ if (value === '2') return
97
+ sharesLocal.value = event.target.value
98
+ }
99
+
100
+ const sharesErrorLocalText = computed<string>(() => {
101
+ if (+sharesLocal.value < 2 || +sharesLocal.value > maxShares) {
102
+ return localization.value.common.sharesMustBe
103
+ .replace('{0}', '2')
104
+ .replace('{1}', maxShares + '')
105
+ }
106
+
107
+ const validValue = /^\d+(\.\d+)?$/.test(sharesLocal.value + '')
108
+ if (!validValue) {
109
+ return localization.value.common.inputContainsInvalidCharacters
110
+ }
111
+
112
+ return ''
113
+ })
114
+ const sharesInvalid = computed<boolean>(() => !!sharesErrorLocalText.value)
115
+ watch(
116
+ sharesInvalid,
117
+ (newValue) => {
118
+ emits('invalid', newValue)
119
+ },
120
+ { immediate: true }
121
+ )
122
+
123
+ const sharesLocalAndApiErrorsTexts = computed<string>(() => {
124
+ const localError = sharesErrorLocalText.value
125
+ const apiError = apiErrorLocal.value
126
+
127
+ let result = ''
128
+ if (localError && !apiError) result = localError
129
+ if (localError && apiError) result = localError + ', ' + apiError
130
+ if (!localError) result = apiError
131
+
132
+ return result
133
+ })
134
+
135
+ const onRemoveValidationError = (): void => {
136
+ emits('remove-error-by-title', 'cpu.shares')
137
+ }
138
+ </script>
139
+
140
+ <style scoped></style>