bfg-common 1.5.82 → 1.5.84

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 (210) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/assets/scss/common/normalize.scss +339 -339
  3. package/components/atoms/TheIcon3.vue +50 -50
  4. package/components/atoms/collapse/CollapseNav.vue +165 -165
  5. package/components/atoms/dropdown/dropdown/Dropdown.vue +168 -168
  6. package/components/atoms/modal/bySteps/BySteps.vue +253 -253
  7. package/components/atoms/perPage/PerPage.vue +58 -58
  8. package/components/atoms/stack/StackBlock.vue +185 -185
  9. package/components/atoms/table/dataGrid/DataGridColumnSwitch.vue +222 -222
  10. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  11. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  12. package/components/atoms/table/info/Info.vue +5 -11
  13. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  14. package/components/atoms/tooltip/Signpost.vue +227 -227
  15. package/components/common/browse/BrowseNew.vue +237 -237
  16. package/components/common/browse/BrowseOld.vue +217 -217
  17. package/components/common/browse/blocks/contents/Files.vue +37 -37
  18. package/components/common/browse/blocks/contents/FilesOld.vue +72 -72
  19. package/components/common/browse/blocks/contents/filesNew/FilesNew.vue +96 -96
  20. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  21. package/components/common/context/Context.vue +111 -111
  22. package/components/common/context/lib/models/interfaces.ts +31 -31
  23. package/components/common/context/recursion/Recursion.vue +87 -87
  24. package/components/common/context/recursion/RecursionNew.vue +238 -238
  25. package/components/common/context/recursion/RecursionOld.vue +228 -228
  26. package/components/common/details/DetailsItem.vue +109 -109
  27. package/components/common/diagramMain/DiagramMain.vue +897 -897
  28. package/components/common/diagramMain/Header.vue +214 -214
  29. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  30. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  31. package/components/common/mainNavigationPanel/MainNavigationPanelOld.vue +311 -311
  32. package/components/common/modals/unsavedChanges/UnsavedChanges.vue +56 -56
  33. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/lib/config/utils.ts +1040 -1040
  34. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  35. package/components/common/pages/home/headline/Headline.vue +45 -45
  36. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  37. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  38. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  39. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  40. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  41. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  42. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  43. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  44. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  45. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  46. package/components/common/pages/packages/Packages.vue +208 -208
  47. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  48. package/components/common/portlets/customAttributes/Portlet.vue +667 -667
  49. package/components/common/portlets/tag/Portlet.vue +433 -433
  50. package/components/common/readyToComplete/New.vue +66 -66
  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 +370 -370
  55. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  56. package/components/common/split/horizontal/HorizontalOld.vue +337 -337
  57. package/components/common/split/vertical/Vertical.vue +160 -160
  58. package/components/common/tools/Actions.vue +202 -202
  59. package/components/common/vm/actions/add/Add.vue +785 -785
  60. package/components/common/vm/actions/add/New.vue +556 -556
  61. package/components/common/vm/actions/add/Old.vue +371 -371
  62. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  63. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  64. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  65. package/components/common/vm/actions/add/lib/config/steps.ts +263 -263
  66. package/components/common/vm/actions/clone/Clone.vue +798 -798
  67. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  68. package/components/common/vm/actions/clone/toTemplate/ToTemplate.vue +626 -626
  69. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  70. package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +275 -275
  71. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +272 -272
  72. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +177 -177
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +698 -698
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +468 -410
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +319 -319
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +99 -99
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusNew.vue +118 -117
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveNew.vue +165 -164
  81. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  82. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  83. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +70 -70
  84. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  85. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +338 -338
  86. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuNew.vue +1 -0
  87. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/coresPerSocket/CoresPerSocketNew.vue +1 -0
  88. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/maxCpu/MaxCpuNew.vue +1 -0
  89. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/model/ModelNew.vue +1 -0
  90. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  91. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/SharesNew.vue +2 -0
  92. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  93. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  94. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/LimitNew.vue +2 -0
  95. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryNew.vue +2 -0
  96. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +368 -368
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskNew.vue +233 -232
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskOld.vue +250 -250
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/cache/CacheNew.vue +1 -0
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/limitIops/LimitIopsNew.vue +2 -0
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/ModeNew.vue +1 -0
  102. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/ModeOld.vue +56 -56
  103. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/provisioning/ProvisioningNew.vue +1 -0
  104. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/SharingNew.vue +45 -44
  105. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +286 -286
  106. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkNew.vue +125 -124
  107. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/adapterType/AdapterTypeNew.vue +1 -0
  108. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/LocationOld.vue +134 -134
  109. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/New.vue +63 -63
  110. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +95 -95
  111. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  112. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressNew.vue +70 -69
  113. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressOld.vue +83 -83
  114. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  115. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  116. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  117. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  118. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoNew.vue +85 -84
  119. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  120. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  121. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  122. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  123. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGrid.vue +41 -41
  124. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridNew.vue +82 -81
  125. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  126. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerNew.vue +57 -56
  127. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  128. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +30 -30
  129. package/components/common/vm/actions/common/customizeHardware/virtualHardware/reservation/ReservationNew.vue +2 -0
  130. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +105 -104
  131. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardOld.vue +112 -112
  132. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/model/ModelNew.vue +1 -0
  133. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplaysNew.vue +1 -0
  134. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/TotalVideoMemoryNew.vue +54 -54
  135. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  136. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +102 -102
  137. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +75 -75
  138. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +26 -26
  139. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/DelayNew.vue +1 -0
  140. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +57 -57
  141. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/FirmwareNew.vue +43 -42
  142. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/MenuNew.vue +25 -25
  143. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +171 -171
  144. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +50 -50
  145. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +144 -141
  146. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +140 -140
  147. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +30 -30
  148. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +30 -30
  149. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/folderSharing/FolderSharingNew.vue +30 -30
  150. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  151. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapNew.vue +40 -39
  152. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  153. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordNew.vue +102 -102
  154. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordOld.vue +94 -94
  155. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  156. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +39 -38
  157. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  158. package/components/common/vm/actions/common/lib/utils/capabilities.ts +52 -52
  159. package/components/common/vm/actions/common/select/compatibility/Compatibility.vue +100 -100
  160. package/components/common/vm/actions/common/select/compatibility/New.vue +165 -165
  161. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  162. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +134 -134
  163. package/components/common/vm/actions/common/select/computeResource/New.vue +141 -141
  164. package/components/common/vm/actions/common/select/computeResource/Old.vue +99 -99
  165. package/components/common/vm/actions/common/select/computeResource/treeView/New.vue +44 -44
  166. package/components/common/vm/actions/common/select/computeResource/treeView/Old.vue +48 -48
  167. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +118 -118
  168. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  169. package/components/common/vm/actions/common/select/createType/New.vue +84 -84
  170. package/components/common/vm/actions/common/select/createType/Old.vue +70 -70
  171. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  172. package/components/common/vm/actions/common/select/name/Name.vue +167 -167
  173. package/components/common/vm/actions/common/select/name/New.vue +246 -246
  174. package/components/common/vm/actions/common/select/name/Old.vue +119 -119
  175. package/components/common/vm/actions/common/select/os/New.vue +122 -122
  176. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  177. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  178. package/components/common/vm/actions/common/select/storage/Old.vue +129 -129
  179. package/components/common/vm/actions/common/select/storage/Storage.vue +130 -130
  180. package/components/common/vm/actions/common/select/storage/new/New.vue +189 -189
  181. package/components/common/vm/actions/common/select/storage/new/lib/config/table.ts +326 -326
  182. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  183. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  184. package/components/common/vm/actions/common/select/template/Template.vue +64 -64
  185. package/components/common/vm/actions/common/select/template/TemplateTreeView.vue +88 -88
  186. package/components/common/vm/actions/editSettings/lib/config/modal.ts +1 -1
  187. package/components/common/vm/actions/editSettings/new/New.vue +185 -179
  188. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  189. package/components/common/wizards/datastore/add/lib/config/steps.ts +138 -138
  190. package/components/common/wizards/datastore/add/nfs/accessibility/Accessibility.vue +60 -60
  191. package/components/common/wizards/datastore/add/readyComplete/ReadyComplete.vue +92 -92
  192. package/components/common/wizards/network/add/steps/SelectConnectionType.vue +105 -105
  193. package/components/common/wizards/vm/migrate/Migrate.vue +11 -10
  194. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  195. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -111
  196. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -57
  197. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  198. package/components/common/wizards/vm/migrate/select/network/table/network/Network.vue +150 -150
  199. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  200. package/components/common/wizards/vm/migrate/select/priority/Priority.vue +43 -43
  201. package/composables/productNameLocal.ts +30 -30
  202. package/composables/useAppVersion.ts +21 -21
  203. package/package.json +1 -1
  204. package/plugins/date.ts +233 -233
  205. package/plugins/directives.ts +24 -24
  206. package/public/spice-console/lib/images/bitmap.js +203 -203
  207. package/public/spice-console/network/spicechannel.js +383 -383
  208. package/store/main/mutations.ts +7 -7
  209. package/store/main/state.ts +7 -7
  210. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,370 +1,370 @@
1
- <template>
2
- <div
3
- :class="['vmw-drawer animation', { show: isShow }]"
4
- data-id="spice-console-drawer"
5
- @click.capture="onInputManagerFocus"
6
- >
7
- <div
8
- v-if="!isShow"
9
- ref="grab"
10
- data-id="spice-console-drawer-toggle"
11
- class="vmw-drawer__open"
12
- :style="`top: ${y}px;`"
13
- @click="toggleDrawer"
14
- >
15
- <atoms-the-icon name="arrow" class="vmw-drawer__open-icon" />
16
- <atoms-the-icon2 name="drag" class="vmw-drawer__drag-icon" />
17
- </div>
18
-
19
- <div class="vmw-drawer-header">
20
- <h3>{{ localization.common.consolePanel }}</h3>
21
- <atoms-the-icon
22
- class="vmw-drawer-header__close"
23
- data-id="spice-console-drawer-toggle-icon"
24
- name="close"
25
- @click="toggleDrawer"
26
- />
27
- </div>
28
-
29
- <div class="vmw-drawer-body">
30
- <button
31
- class="vmw-drawer-body__btn animation toggle-fullscreen"
32
- data-id="spice-console-drawer-toggle-fullscreen"
33
- @click="emits('toggle-fullscreen')"
34
- >
35
- {{ localization.common.toggleFullscreenMode }}
36
- </button>
37
- <button
38
- class="vmw-drawer-body__btn animation toggle-fullscreen"
39
- @click="emits('send-alt-command')"
40
- >
41
- {{ localization.common.sendAltCommand }}
42
- </button>
43
- <label class="vmw-drawer-body__btn animation relative">
44
- {{ localization.remoteConsole.uploadFolder }}
45
- <input type="file" webkitdirectory directory multiple />
46
- </label>
47
- <label class="vmw-drawer-body__btn animation relative">
48
- {{ localization.remoteConsole.uploadFiles }}
49
- <input type="file" multiple />
50
- </label>
51
-
52
- <select
53
- v-model="usbDevice"
54
- @mouseenter="hover = true"
55
- @mouseleave="hover = false"
56
- @change="onChangeUsbDevice"
57
- >
58
- <option
59
- v-for="item in usbDevices"
60
- :key="item.value"
61
- :value="item.value"
62
- :disabled="item.disabled"
63
- >
64
- {{ item.label }}
65
- </option>
66
- </select>
67
-
68
- <select
69
- v-model="codec"
70
- @mouseenter="hover = true"
71
- @mouseleave="hover = false"
72
- @change="onChangeCodec"
73
- >
74
- <option :value="1">MJPEG</option>
75
- <option :value="2">VP8</option>
76
- <option :value="3">H264</option>
77
- <option :value="4" disabled>VP9</option>
78
- <option :value="5">H265</option>
79
- </select>
80
-
81
- <hr />
82
- <button
83
- class="vmw-drawer-body__btn animation show-keyboard"
84
- @click="onToggleKeyboard"
85
- >
86
- {{ showOrHideKeyboard }}
87
- </button>
88
- </div>
89
-
90
- <div class="vmw-drawer-footer">
91
- <div class="size-info">
92
- <p class="size-info-text">View size: {{ viewSize }}</p>
93
- <p class="size-info-text">Canvas size: {{ canvasSize }}</p>
94
- </div>
95
- <div id="debug-stream"></div>
96
- </div>
97
- <div v-if="isKeyboardShown">
98
- <common-spice-console-keyboard />
99
- </div>
100
- </div>
101
- </template>
102
- <script setup lang="ts">
103
- import { useDraggable } from '@vueuse/core'
104
- import type { UI_I_DeviceOption } from '~/components/common/spiceConsole/lib/models/interfaces'
105
- import type { UI_I_Localization } from '~/lib/models/interfaces'
106
- import type { UI_T_CODEC } from '~/components/common/spiceConsole/lib/models/types'
107
- import {
108
- getUSBDeviceType,
109
- identifyHIDDevice,
110
- } from '~/components/common/spiceConsole/lib/utils/getDeviceType'
111
-
112
- const emits = defineEmits<{
113
- (event: 'toggle-fullscreen'): void
114
- (event: 'send-alt-command'): void
115
- }>()
116
-
117
- const codec = ref<UI_T_CODEC>(1)
118
- const onChangeCodec = (): void => {
119
- // @ts-ignore
120
- if (!window.app) return
121
- // @ts-ignore
122
- const channels = window.app.spiceConnection.channels
123
- for (const i in channels) {
124
- const channel = channels[i]
125
- if (channel.channel === wdi.SpiceVars.SPICE_CHANNEL_DISPLAY) {
126
- channel.changeCodec(codec.value)
127
- }
128
- }
129
- document.getElementById('inputmanager')?.focus()
130
- }
131
-
132
- const isKeyboardShown = ref<boolean>(false)
133
- const onToggleKeyboard = (): void => {
134
- isKeyboardShown.value = !isKeyboardShown.value
135
- }
136
-
137
- const isShow = ref<boolean>(false)
138
- const grab = ref<HTMLDivElement | null>(null)
139
- const localization = computed<UI_I_Localization>(() => useLocal())
140
- const initialTop = window.innerHeight / 2 - 15
141
- const { y } = useDraggable(grab, {
142
- initialValue: { x: -30, y: initialTop },
143
- })
144
-
145
- const showOrHideKeyboard = computed<string>(() =>
146
- isKeyboardShown.value
147
- ? localization.value.common.hideKeyboard
148
- : localization.value.common.showKeyboard
149
- )
150
-
151
- watch(y, () => {
152
- isDrag = true
153
- })
154
-
155
- let isDrag = false
156
- const toggleDrawer = (): void => {
157
- if (isDrag) {
158
- isDrag = false
159
- return
160
- }
161
- isShow.value = !isShow.value
162
- }
163
-
164
- const hover = ref<boolean>(false)
165
- const onInputManagerFocus = (): void => {
166
- if (hover.value) return
167
- document.getElementById('inputmanager')?.focus()
168
- }
169
-
170
- const viewSize = ref<string>('0 x 0')
171
- const canvasSize = ref<string>('0 x 0')
172
- const displaySizeInfo = (): void => {
173
- const layout = document.getElementById('eventLayer')
174
- viewSize.value = `${window.innerWidth}px x ${window.innerHeight}px`
175
- if (layout) {
176
- canvasSize.value = `${layout.width || 0}px x ${layout.height || 0}px`
177
- }
178
-
179
- requestAnimationFrame(displaySizeInfo)
180
- }
181
- displaySizeInfo()
182
-
183
- const usbDevice = ref<number | string>(-1)
184
- const usbDevices = ref<UI_I_DeviceOption[]>([
185
- { label: 'USB Device', value: -1, disabled: true },
186
- { label: 'Add USB device', value: -2 },
187
- ])
188
- const onChangeUsbDevice = (data: any): void => {
189
- if (data.target.value === '-2') {
190
- getUSBDeviceInformation()
191
- }
192
- }
193
-
194
- const getUSBDeviceInformation = async (): Promise<void> => {
195
- try {
196
- // Запросить устройство
197
- const device = await navigator.usb.requestDevice({ filters: [] })
198
- usbDevice.value = setDevice(device)
199
- } catch (error) {
200
- console.error('Error:', error)
201
- }
202
- }
203
-
204
- const setDevice = (device: any): string => {
205
- const interfaces = device.configuration.interfaces
206
-
207
- const types: any = new Set()
208
- interfaces.forEach((item: any) => {
209
- const classCode = item.alternate.interfaceClass
210
- const subclassCode = item.alternate.interfaceSubclass
211
- const protocolCode = item.alternate.interfaceProtocol
212
-
213
- if (classCode === 0x03) {
214
- // HID класс
215
- types.add(identifyHIDDevice(subclassCode, protocolCode))
216
- } else {
217
- types.add(getUSBDeviceType(classCode))
218
- }
219
- })
220
-
221
- const value = `${device.productId}_${device.vendorId}`
222
- if (usbDevices.value.every((device) => device.value !== value)) {
223
- usbDevices.value.push({
224
- value,
225
- label: Array.from(types).join(' / '),
226
- })
227
- }
228
-
229
- return value
230
- }
231
-
232
- const setDefaultDevices = async (): Promise<void> => {
233
- const devices = await navigator.usb.getDevices()
234
- devices.forEach((device: any) => {
235
- setDevice(device)
236
- })
237
- }
238
- setDefaultDevices()
239
- </script>
240
- <style lang="scss" scoped>
241
- .vmw-drawer {
242
- background-color: #314351;
243
- position: absolute;
244
- top: 0;
245
- right: -300px;
246
- width: 300px;
247
- height: 100vh;
248
- padding: 20px;
249
- z-index: var(--z-modal);
250
-
251
- &.show {
252
- right: 0;
253
-
254
- .vmw-drawer__open {
255
- z-index: var(--z-negative);
256
- }
257
- }
258
-
259
- &__open {
260
- width: 65px;
261
- height: 40px;
262
- background-color: #314351;
263
- position: absolute;
264
- left: -30px;
265
- cursor: pointer;
266
- border-top-left-radius: 20px;
267
- border-bottom-left-radius: 20px;
268
- box-shadow: 0 0 15px 5px #31435169;
269
- transition: left 0.5s;
270
- user-select: none;
271
-
272
- &.moving {
273
- cursor: grabbing;
274
- }
275
-
276
- &:hover {
277
- left: -60px;
278
- }
279
-
280
- & .vmw-drawer__open-icon {
281
- fill: #ffffff;
282
- transform: rotate(-90deg);
283
- width: 30px;
284
- height: 40px;
285
- z-index: var(--z-dropdown);
286
- }
287
-
288
- & .vmw-drawer__drag-icon {
289
- fill: #ffffff;
290
- width: 40px;
291
- position: absolute;
292
- left: 21px;
293
- z-index: calc(var(--z-default) + 1);
294
- cursor: grabbing;
295
- }
296
- }
297
-
298
- .vmw-drawer-header {
299
- & h3 {
300
- color: #fff;
301
- font-weight: bold;
302
- font-size: 20px;
303
- text-align: center;
304
- }
305
-
306
- &__close {
307
- width: 30px;
308
- fill: #fff;
309
- position: absolute;
310
- right: 10px;
311
- top: 10px;
312
- cursor: pointer;
313
- }
314
- }
315
-
316
- .vmw-drawer-body {
317
- margin-top: 50px;
318
-
319
- & select,
320
- &__btn {
321
- display: block;
322
- width: 100%;
323
- color: #fff;
324
- cursor: pointer;
325
- font-size: 15px;
326
- border: 1px solid #fff;
327
- padding: 5px;
328
- border-radius: 5px;
329
- text-align: center;
330
- margin-bottom: 20px;
331
- background-color: transparent;
332
-
333
- &:not(.disable):hover {
334
- background-color: #ffffff;
335
- color: #314351;
336
- }
337
-
338
- &.disable {
339
- opacity: 0.5;
340
- cursor: not-allowed;
341
- }
342
-
343
- input[type='file'] {
344
- position: absolute;
345
- top: 0;
346
- left: 0;
347
- right: 0;
348
- bottom: 0;
349
- opacity: 0;
350
- }
351
- }
352
-
353
- & > hr {
354
- margin-bottom: 20px;
355
- border-color: #ffffff40;
356
- box-shadow: 0 0 20px 0.5px #ffffff2e;
357
- }
358
- }
359
-
360
- .vmw-drawer-footer {
361
- .size-info {
362
- margin-bottom: 10px;
363
-
364
- .size-info-text {
365
- color: #ffffff;
366
- }
367
- }
368
- }
369
- }
370
- </style>
1
+ <template>
2
+ <div
3
+ :class="['vmw-drawer animation', { show: isShow }]"
4
+ data-id="spice-console-drawer"
5
+ @click.capture="onInputManagerFocus"
6
+ >
7
+ <div
8
+ v-if="!isShow"
9
+ ref="grab"
10
+ data-id="spice-console-drawer-toggle"
11
+ class="vmw-drawer__open"
12
+ :style="`top: ${y}px;`"
13
+ @click="toggleDrawer"
14
+ >
15
+ <atoms-the-icon name="arrow" class="vmw-drawer__open-icon" />
16
+ <atoms-the-icon2 name="drag" class="vmw-drawer__drag-icon" />
17
+ </div>
18
+
19
+ <div class="vmw-drawer-header">
20
+ <h3>{{ localization.common.consolePanel }}</h3>
21
+ <atoms-the-icon
22
+ class="vmw-drawer-header__close"
23
+ data-id="spice-console-drawer-toggle-icon"
24
+ name="close"
25
+ @click="toggleDrawer"
26
+ />
27
+ </div>
28
+
29
+ <div class="vmw-drawer-body">
30
+ <button
31
+ class="vmw-drawer-body__btn animation toggle-fullscreen"
32
+ data-id="spice-console-drawer-toggle-fullscreen"
33
+ @click="emits('toggle-fullscreen')"
34
+ >
35
+ {{ localization.common.toggleFullscreenMode }}
36
+ </button>
37
+ <button
38
+ class="vmw-drawer-body__btn animation toggle-fullscreen"
39
+ @click="emits('send-alt-command')"
40
+ >
41
+ {{ localization.common.sendAltCommand }}
42
+ </button>
43
+ <label class="vmw-drawer-body__btn animation relative">
44
+ {{ localization.remoteConsole.uploadFolder }}
45
+ <input type="file" webkitdirectory directory multiple />
46
+ </label>
47
+ <label class="vmw-drawer-body__btn animation relative">
48
+ {{ localization.remoteConsole.uploadFiles }}
49
+ <input type="file" multiple />
50
+ </label>
51
+
52
+ <select
53
+ v-model="usbDevice"
54
+ @mouseenter="hover = true"
55
+ @mouseleave="hover = false"
56
+ @change="onChangeUsbDevice"
57
+ >
58
+ <option
59
+ v-for="item in usbDevices"
60
+ :key="item.value"
61
+ :value="item.value"
62
+ :disabled="item.disabled"
63
+ >
64
+ {{ item.label }}
65
+ </option>
66
+ </select>
67
+
68
+ <select
69
+ v-model="codec"
70
+ @mouseenter="hover = true"
71
+ @mouseleave="hover = false"
72
+ @change="onChangeCodec"
73
+ >
74
+ <option :value="1">MJPEG</option>
75
+ <option :value="2">VP8</option>
76
+ <option :value="3">H264</option>
77
+ <option :value="4" disabled>VP9</option>
78
+ <option :value="5">H265</option>
79
+ </select>
80
+
81
+ <hr />
82
+ <button
83
+ class="vmw-drawer-body__btn animation show-keyboard"
84
+ @click="onToggleKeyboard"
85
+ >
86
+ {{ showOrHideKeyboard }}
87
+ </button>
88
+ </div>
89
+
90
+ <div class="vmw-drawer-footer">
91
+ <div class="size-info">
92
+ <p class="size-info-text">View size: {{ viewSize }}</p>
93
+ <p class="size-info-text">Canvas size: {{ canvasSize }}</p>
94
+ </div>
95
+ <div id="debug-stream"></div>
96
+ </div>
97
+ <div v-if="isKeyboardShown">
98
+ <common-spice-console-keyboard />
99
+ </div>
100
+ </div>
101
+ </template>
102
+ <script setup lang="ts">
103
+ import { useDraggable } from '@vueuse/core'
104
+ import type { UI_I_DeviceOption } from '~/components/common/spiceConsole/lib/models/interfaces'
105
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
106
+ import type { UI_T_CODEC } from '~/components/common/spiceConsole/lib/models/types'
107
+ import {
108
+ getUSBDeviceType,
109
+ identifyHIDDevice,
110
+ } from '~/components/common/spiceConsole/lib/utils/getDeviceType'
111
+
112
+ const emits = defineEmits<{
113
+ (event: 'toggle-fullscreen'): void
114
+ (event: 'send-alt-command'): void
115
+ }>()
116
+
117
+ const codec = ref<UI_T_CODEC>(1)
118
+ const onChangeCodec = (): void => {
119
+ // @ts-ignore
120
+ if (!window.app) return
121
+ // @ts-ignore
122
+ const channels = window.app.spiceConnection.channels
123
+ for (const i in channels) {
124
+ const channel = channels[i]
125
+ if (channel.channel === wdi.SpiceVars.SPICE_CHANNEL_DISPLAY) {
126
+ channel.changeCodec(codec.value)
127
+ }
128
+ }
129
+ document.getElementById('inputmanager')?.focus()
130
+ }
131
+
132
+ const isKeyboardShown = ref<boolean>(false)
133
+ const onToggleKeyboard = (): void => {
134
+ isKeyboardShown.value = !isKeyboardShown.value
135
+ }
136
+
137
+ const isShow = ref<boolean>(false)
138
+ const grab = ref<HTMLDivElement | null>(null)
139
+ const localization = computed<UI_I_Localization>(() => useLocal())
140
+ const initialTop = window.innerHeight / 2 - 15
141
+ const { y } = useDraggable(grab, {
142
+ initialValue: { x: -30, y: initialTop },
143
+ })
144
+
145
+ const showOrHideKeyboard = computed<string>(() =>
146
+ isKeyboardShown.value
147
+ ? localization.value.common.hideKeyboard
148
+ : localization.value.common.showKeyboard
149
+ )
150
+
151
+ watch(y, () => {
152
+ isDrag = true
153
+ })
154
+
155
+ let isDrag = false
156
+ const toggleDrawer = (): void => {
157
+ if (isDrag) {
158
+ isDrag = false
159
+ return
160
+ }
161
+ isShow.value = !isShow.value
162
+ }
163
+
164
+ const hover = ref<boolean>(false)
165
+ const onInputManagerFocus = (): void => {
166
+ if (hover.value) return
167
+ document.getElementById('inputmanager')?.focus()
168
+ }
169
+
170
+ const viewSize = ref<string>('0 x 0')
171
+ const canvasSize = ref<string>('0 x 0')
172
+ const displaySizeInfo = (): void => {
173
+ const layout = document.getElementById('eventLayer')
174
+ viewSize.value = `${window.innerWidth}px x ${window.innerHeight}px`
175
+ if (layout) {
176
+ canvasSize.value = `${layout.width || 0}px x ${layout.height || 0}px`
177
+ }
178
+
179
+ requestAnimationFrame(displaySizeInfo)
180
+ }
181
+ displaySizeInfo()
182
+
183
+ const usbDevice = ref<number | string>(-1)
184
+ const usbDevices = ref<UI_I_DeviceOption[]>([
185
+ { label: 'USB Device', value: -1, disabled: true },
186
+ { label: 'Add USB device', value: -2 },
187
+ ])
188
+ const onChangeUsbDevice = (data: any): void => {
189
+ if (data.target.value === '-2') {
190
+ getUSBDeviceInformation()
191
+ }
192
+ }
193
+
194
+ const getUSBDeviceInformation = async (): Promise<void> => {
195
+ try {
196
+ // Запросить устройство
197
+ const device = await navigator.usb.requestDevice({ filters: [] })
198
+ usbDevice.value = setDevice(device)
199
+ } catch (error) {
200
+ console.error('Error:', error)
201
+ }
202
+ }
203
+
204
+ const setDevice = (device: any): string => {
205
+ const interfaces = device.configuration.interfaces
206
+
207
+ const types: any = new Set()
208
+ interfaces.forEach((item: any) => {
209
+ const classCode = item.alternate.interfaceClass
210
+ const subclassCode = item.alternate.interfaceSubclass
211
+ const protocolCode = item.alternate.interfaceProtocol
212
+
213
+ if (classCode === 0x03) {
214
+ // HID класс
215
+ types.add(identifyHIDDevice(subclassCode, protocolCode))
216
+ } else {
217
+ types.add(getUSBDeviceType(classCode))
218
+ }
219
+ })
220
+
221
+ const value = `${device.productId}_${device.vendorId}`
222
+ if (usbDevices.value.every((device) => device.value !== value)) {
223
+ usbDevices.value.push({
224
+ value,
225
+ label: Array.from(types).join(' / '),
226
+ })
227
+ }
228
+
229
+ return value
230
+ }
231
+
232
+ const setDefaultDevices = async (): Promise<void> => {
233
+ const devices = await navigator.usb.getDevices()
234
+ devices.forEach((device: any) => {
235
+ setDevice(device)
236
+ })
237
+ }
238
+ setDefaultDevices()
239
+ </script>
240
+ <style lang="scss" scoped>
241
+ .vmw-drawer {
242
+ background-color: #314351;
243
+ position: absolute;
244
+ top: 0;
245
+ right: -300px;
246
+ width: 300px;
247
+ height: 100vh;
248
+ padding: 20px;
249
+ z-index: var(--z-modal);
250
+
251
+ &.show {
252
+ right: 0;
253
+
254
+ .vmw-drawer__open {
255
+ z-index: var(--z-negative);
256
+ }
257
+ }
258
+
259
+ &__open {
260
+ width: 65px;
261
+ height: 40px;
262
+ background-color: #314351;
263
+ position: absolute;
264
+ left: -30px;
265
+ cursor: pointer;
266
+ border-top-left-radius: 20px;
267
+ border-bottom-left-radius: 20px;
268
+ box-shadow: 0 0 15px 5px #31435169;
269
+ transition: left 0.5s;
270
+ user-select: none;
271
+
272
+ &.moving {
273
+ cursor: grabbing;
274
+ }
275
+
276
+ &:hover {
277
+ left: -60px;
278
+ }
279
+
280
+ & .vmw-drawer__open-icon {
281
+ fill: #ffffff;
282
+ transform: rotate(-90deg);
283
+ width: 30px;
284
+ height: 40px;
285
+ z-index: var(--z-dropdown);
286
+ }
287
+
288
+ & .vmw-drawer__drag-icon {
289
+ fill: #ffffff;
290
+ width: 40px;
291
+ position: absolute;
292
+ left: 21px;
293
+ z-index: calc(var(--z-default) + 1);
294
+ cursor: grabbing;
295
+ }
296
+ }
297
+
298
+ .vmw-drawer-header {
299
+ & h3 {
300
+ color: #fff;
301
+ font-weight: bold;
302
+ font-size: 20px;
303
+ text-align: center;
304
+ }
305
+
306
+ &__close {
307
+ width: 30px;
308
+ fill: #fff;
309
+ position: absolute;
310
+ right: 10px;
311
+ top: 10px;
312
+ cursor: pointer;
313
+ }
314
+ }
315
+
316
+ .vmw-drawer-body {
317
+ margin-top: 50px;
318
+
319
+ & select,
320
+ &__btn {
321
+ display: block;
322
+ width: 100%;
323
+ color: #fff;
324
+ cursor: pointer;
325
+ font-size: 15px;
326
+ border: 1px solid #fff;
327
+ padding: 5px;
328
+ border-radius: 5px;
329
+ text-align: center;
330
+ margin-bottom: 20px;
331
+ background-color: transparent;
332
+
333
+ &:not(.disable):hover {
334
+ background-color: #ffffff;
335
+ color: #314351;
336
+ }
337
+
338
+ &.disable {
339
+ opacity: 0.5;
340
+ cursor: not-allowed;
341
+ }
342
+
343
+ input[type='file'] {
344
+ position: absolute;
345
+ top: 0;
346
+ left: 0;
347
+ right: 0;
348
+ bottom: 0;
349
+ opacity: 0;
350
+ }
351
+ }
352
+
353
+ & > hr {
354
+ margin-bottom: 20px;
355
+ border-color: #ffffff40;
356
+ box-shadow: 0 0 20px 0.5px #ffffff2e;
357
+ }
358
+ }
359
+
360
+ .vmw-drawer-footer {
361
+ .size-info {
362
+ margin-bottom: 10px;
363
+
364
+ .size-info-text {
365
+ color: #ffffff;
366
+ }
367
+ }
368
+ }
369
+ }
370
+ </style>