bfg-common 1.5.243 → 1.5.245

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