@jait/gateway 0.1.255 → 0.1.257

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/dist/routes/git.d.ts.map +1 -1
  2. package/dist/routes/git.js +58 -0
  3. package/dist/routes/git.js.map +1 -1
  4. package/dist/routes/preview.d.ts.map +1 -1
  5. package/dist/routes/preview.js +39 -0
  6. package/dist/routes/preview.js.map +1 -1
  7. package/dist/security/sandbox-manager.d.ts +1 -0
  8. package/dist/security/sandbox-manager.d.ts.map +1 -1
  9. package/dist/security/sandbox-manager.js +11 -0
  10. package/dist/security/sandbox-manager.js.map +1 -1
  11. package/dist/services/git.d.ts +11 -0
  12. package/dist/services/git.d.ts.map +1 -1
  13. package/dist/services/git.js +37 -0
  14. package/dist/services/git.js.map +1 -1
  15. package/dist/services/live-view-manager.d.ts +20 -0
  16. package/dist/services/live-view-manager.d.ts.map +1 -0
  17. package/dist/services/live-view-manager.js +114 -0
  18. package/dist/services/live-view-manager.js.map +1 -0
  19. package/dist/services/preview.d.ts +16 -1
  20. package/dist/services/preview.d.ts.map +1 -1
  21. package/dist/services/preview.js +112 -2
  22. package/dist/services/preview.js.map +1 -1
  23. package/dist/surfaces/browser.d.ts +12 -0
  24. package/dist/surfaces/browser.d.ts.map +1 -1
  25. package/dist/surfaces/browser.js +31 -1
  26. package/dist/surfaces/browser.js.map +1 -1
  27. package/dist/tools/preview-tools.d.ts.map +1 -1
  28. package/dist/tools/preview-tools.js.map +1 -1
  29. package/package.json +1 -1
  30. package/web-dist/assets/{_basePickBy-BjvMP2af.js → _basePickBy-B2KkoWFz.js} +1 -1
  31. package/web-dist/assets/{_baseUniq-CQbQ6NgV.js → _baseUniq-DFNflT4F.js} +1 -1
  32. package/web-dist/assets/{arc-D3KRIJWu.js → arc-C7JI0CHt.js} +1 -1
  33. package/web-dist/assets/{architectureDiagram-2XIMDMQ5-DM3fcOkr.js → architectureDiagram-2XIMDMQ5-bI95Cgh9.js} +1 -1
  34. package/web-dist/assets/{blockDiagram-WCTKOSBZ-B-9Vjl98.js → blockDiagram-WCTKOSBZ-DgfGN-sd.js} +1 -1
  35. package/web-dist/assets/{c4Diagram-IC4MRINW-CTu2yYlj.js → c4Diagram-IC4MRINW-xM9CGMLf.js} +1 -1
  36. package/web-dist/assets/channel-otEtLTdD.js +1 -0
  37. package/web-dist/assets/{chunk-4BX2VUAB-ZDQu0uWO.js → chunk-4BX2VUAB-C66ZLhus.js} +1 -1
  38. package/web-dist/assets/{chunk-55IACEB6-YtzMmlzY.js → chunk-55IACEB6-ByPuHMYM.js} +1 -1
  39. package/web-dist/assets/{chunk-FMBD7UC4-BsIyXbSx.js → chunk-FMBD7UC4-CMH4hMhI.js} +1 -1
  40. package/web-dist/assets/{chunk-JSJVCQXG-CfudXyS3.js → chunk-JSJVCQXG-BJLuo8dM.js} +1 -1
  41. package/web-dist/assets/{chunk-KX2RTZJC-B-fQrx3o.js → chunk-KX2RTZJC-CU0ZE2mJ.js} +1 -1
  42. package/web-dist/assets/{chunk-NQ4KR5QH-DzmNoENv.js → chunk-NQ4KR5QH-CD4JSx3E.js} +1 -1
  43. package/web-dist/assets/{chunk-QZHKN3VN-DtkgvjXx.js → chunk-QZHKN3VN-BhZcwDDX.js} +1 -1
  44. package/web-dist/assets/{chunk-WL4C6EOR-BCxmVwuX.js → chunk-WL4C6EOR-CScYiORQ.js} +1 -1
  45. package/web-dist/assets/classDiagram-VBA2DB6C-D3uA1Ef5.js +1 -0
  46. package/web-dist/assets/classDiagram-v2-RAHNMMFH-D3uA1Ef5.js +1 -0
  47. package/web-dist/assets/clone-CAAX5MRw.js +1 -0
  48. package/web-dist/assets/{cose-bilkent-S5V4N54A-Ixga3b-M.js → cose-bilkent-S5V4N54A-DTphha5A.js} +1 -1
  49. package/web-dist/assets/{dagre-KLK3FWXG-CXoAVVKA.js → dagre-KLK3FWXG-Dm5HIzgU.js} +1 -1
  50. package/web-dist/assets/{diagram-E7M64L7V-CcBLNXz0.js → diagram-E7M64L7V-BafxXR5t.js} +1 -1
  51. package/web-dist/assets/{diagram-IFDJBPK2-6gwd3HNI.js → diagram-IFDJBPK2-DDMAYAl_.js} +1 -1
  52. package/web-dist/assets/{diagram-P4PSJMXO-CAXp9Quj.js → diagram-P4PSJMXO-DHvyv48k.js} +1 -1
  53. package/web-dist/assets/{erDiagram-INFDFZHY-C6p1MF8r.js → erDiagram-INFDFZHY-B_xrbbBo.js} +1 -1
  54. package/web-dist/assets/{flowDiagram-PKNHOUZH-B2M24TQ4.js → flowDiagram-PKNHOUZH-CRcTFuaU.js} +1 -1
  55. package/web-dist/assets/{ganttDiagram-A5KZAMGK-CmKwfSN8.js → ganttDiagram-A5KZAMGK-CeIGrgW3.js} +1 -1
  56. package/web-dist/assets/{gitGraphDiagram-K3NZZRJ6-f6_FZnF_.js → gitGraphDiagram-K3NZZRJ6-B8p3GzsB.js} +1 -1
  57. package/web-dist/assets/{graph-X0lqls-x.js → graph-DgPXX2YH.js} +1 -1
  58. package/web-dist/assets/{index-DnSc9BPB.js → index-Dyq1wR8W.js} +307 -307
  59. package/web-dist/assets/{infoDiagram-LFFYTUFH-59VZJVF5.js → infoDiagram-LFFYTUFH-C1EleBwJ.js} +1 -1
  60. package/web-dist/assets/{ishikawaDiagram-PHBUUO56-BEy0oxW6.js → ishikawaDiagram-PHBUUO56-CY7B0Af8.js} +1 -1
  61. package/web-dist/assets/{journeyDiagram-4ABVD52K-BDulB1lR.js → journeyDiagram-4ABVD52K-BEbad9lw.js} +1 -1
  62. package/web-dist/assets/{kanban-definition-K7BYSVSG-Cx1576bJ.js → kanban-definition-K7BYSVSG-PmiPROs_.js} +1 -1
  63. package/web-dist/assets/{layout-C7p8zLip.js → layout-u4nQqZo9.js} +1 -1
  64. package/web-dist/assets/{linear-C7lgV0KB.js → linear-CYNrNanw.js} +1 -1
  65. package/web-dist/assets/{mindmap-definition-YRQLILUH-B0aaRwFC.js → mindmap-definition-YRQLILUH-Ch-jh05Z.js} +1 -1
  66. package/web-dist/assets/{pieDiagram-SKSYHLDU-BrlmIbXe.js → pieDiagram-SKSYHLDU-ypmvYTXD.js} +1 -1
  67. package/web-dist/assets/{quadrantDiagram-337W2JSQ-BwXx6zzR.js → quadrantDiagram-337W2JSQ-Butg8Ecg.js} +1 -1
  68. package/web-dist/assets/{requirementDiagram-Z7DCOOCP-kUdwkQkY.js → requirementDiagram-Z7DCOOCP-nj6Myt9w.js} +1 -1
  69. package/web-dist/assets/{sankeyDiagram-WA2Y5GQK-Dkpg3nlZ.js → sankeyDiagram-WA2Y5GQK-DPAF8v8e.js} +1 -1
  70. package/web-dist/assets/{sequenceDiagram-2WXFIKYE-CyZv4rLL.js → sequenceDiagram-2WXFIKYE-DVyGYemI.js} +1 -1
  71. package/web-dist/assets/{stateDiagram-RAJIS63D-CZbnLN4N.js → stateDiagram-RAJIS63D-CstalmXc.js} +1 -1
  72. package/web-dist/assets/stateDiagram-v2-FVOUBMTO-DidQo5W_.js +1 -0
  73. package/web-dist/assets/{timeline-definition-YZTLITO2-BSFBZK4o.js → timeline-definition-YZTLITO2-D0D_Mp_k.js} +1 -1
  74. package/web-dist/assets/{treemap-KZPCXAKY-Bhm8QcdX.js → treemap-KZPCXAKY-C9RoKRs9.js} +1 -1
  75. package/web-dist/assets/{vennDiagram-LZ73GAT5-CamPCKoy.js → vennDiagram-LZ73GAT5-r2eoeYH9.js} +1 -1
  76. package/web-dist/assets/{xychartDiagram-JWTSCODW-BgY7GIM5.js → xychartDiagram-JWTSCODW-CdE4gaJ1.js} +1 -1
  77. package/web-dist/index.html +1 -1
  78. package/web-dist/noVNC/LICENSE.txt +62 -0
  79. package/web-dist/noVNC/app/error-handler.js +79 -0
  80. package/web-dist/noVNC/app/images/alt.svg +92 -0
  81. package/web-dist/noVNC/app/images/clipboard.svg +106 -0
  82. package/web-dist/noVNC/app/images/connect.svg +96 -0
  83. package/web-dist/noVNC/app/images/ctrl.svg +96 -0
  84. package/web-dist/noVNC/app/images/ctrlaltdel.svg +100 -0
  85. package/web-dist/noVNC/app/images/disconnect.svg +94 -0
  86. package/web-dist/noVNC/app/images/drag.svg +76 -0
  87. package/web-dist/noVNC/app/images/error.svg +81 -0
  88. package/web-dist/noVNC/app/images/esc.svg +92 -0
  89. package/web-dist/noVNC/app/images/expander.svg +69 -0
  90. package/web-dist/noVNC/app/images/fullscreen.svg +93 -0
  91. package/web-dist/noVNC/app/images/handle.svg +82 -0
  92. package/web-dist/noVNC/app/images/handle_bg.svg +172 -0
  93. package/web-dist/noVNC/app/images/icons/Makefile +42 -0
  94. package/web-dist/noVNC/app/images/icons/novnc-icon-sm.svg +163 -0
  95. package/web-dist/noVNC/app/images/icons/novnc-icon.svg +163 -0
  96. package/web-dist/noVNC/app/images/icons/novnc-ios-120.png +0 -0
  97. package/web-dist/noVNC/app/images/icons/novnc-ios-152.png +0 -0
  98. package/web-dist/noVNC/app/images/icons/novnc-ios-167.png +0 -0
  99. package/web-dist/noVNC/app/images/icons/novnc-ios-180.png +0 -0
  100. package/web-dist/noVNC/app/images/icons/novnc-ios-40.png +0 -0
  101. package/web-dist/noVNC/app/images/icons/novnc-ios-58.png +0 -0
  102. package/web-dist/noVNC/app/images/icons/novnc-ios-60.png +0 -0
  103. package/web-dist/noVNC/app/images/icons/novnc-ios-80.png +0 -0
  104. package/web-dist/noVNC/app/images/icons/novnc-ios-87.png +0 -0
  105. package/web-dist/noVNC/app/images/icons/novnc-ios-icon.svg +183 -0
  106. package/web-dist/noVNC/app/images/icons/novnc.ico +0 -0
  107. package/web-dist/noVNC/app/images/info.svg +81 -0
  108. package/web-dist/noVNC/app/images/keyboard.svg +88 -0
  109. package/web-dist/noVNC/app/images/power.svg +87 -0
  110. package/web-dist/noVNC/app/images/settings.svg +76 -0
  111. package/web-dist/noVNC/app/images/tab.svg +86 -0
  112. package/web-dist/noVNC/app/images/toggleextrakeys.svg +90 -0
  113. package/web-dist/noVNC/app/images/warning.svg +81 -0
  114. package/web-dist/noVNC/app/images/windows.svg +65 -0
  115. package/web-dist/noVNC/app/locale/README +1 -0
  116. package/web-dist/noVNC/app/locale/cs.json +71 -0
  117. package/web-dist/noVNC/app/locale/de.json +74 -0
  118. package/web-dist/noVNC/app/locale/el.json +100 -0
  119. package/web-dist/noVNC/app/locale/es.json +68 -0
  120. package/web-dist/noVNC/app/locale/fr.json +82 -0
  121. package/web-dist/noVNC/app/locale/hu.json +80 -0
  122. package/web-dist/noVNC/app/locale/it.json +68 -0
  123. package/web-dist/noVNC/app/locale/ja.json +81 -0
  124. package/web-dist/noVNC/app/locale/ko.json +70 -0
  125. package/web-dist/noVNC/app/locale/nl.json +95 -0
  126. package/web-dist/noVNC/app/locale/pl.json +80 -0
  127. package/web-dist/noVNC/app/locale/pt_BR.json +72 -0
  128. package/web-dist/noVNC/app/locale/ru.json +72 -0
  129. package/web-dist/noVNC/app/locale/sv.json +83 -0
  130. package/web-dist/noVNC/app/locale/tr.json +69 -0
  131. package/web-dist/noVNC/app/locale/uk.json +81 -0
  132. package/web-dist/noVNC/app/locale/zh_CN.json +93 -0
  133. package/web-dist/noVNC/app/locale/zh_TW.json +69 -0
  134. package/web-dist/noVNC/app/localization.js +206 -0
  135. package/web-dist/noVNC/app/sounds/CREDITS +4 -0
  136. package/web-dist/noVNC/app/sounds/bell.mp3 +0 -0
  137. package/web-dist/noVNC/app/sounds/bell.oga +0 -0
  138. package/web-dist/noVNC/app/styles/Orbitron700.ttf +0 -0
  139. package/web-dist/noVNC/app/styles/Orbitron700.woff +0 -0
  140. package/web-dist/noVNC/app/styles/base.css +927 -0
  141. package/web-dist/noVNC/app/styles/constants.css +30 -0
  142. package/web-dist/noVNC/app/styles/input.css +628 -0
  143. package/web-dist/noVNC/app/ui.js +1873 -0
  144. package/web-dist/noVNC/app/wakelock.js +199 -0
  145. package/web-dist/noVNC/app/webutil.js +250 -0
  146. package/web-dist/noVNC/core/base64.js +104 -0
  147. package/web-dist/noVNC/core/clipboard.js +72 -0
  148. package/web-dist/noVNC/core/crypto/aes.js +178 -0
  149. package/web-dist/noVNC/core/crypto/bigint.js +34 -0
  150. package/web-dist/noVNC/core/crypto/crypto.js +90 -0
  151. package/web-dist/noVNC/core/crypto/des.js +330 -0
  152. package/web-dist/noVNC/core/crypto/dh.js +55 -0
  153. package/web-dist/noVNC/core/crypto/md5.js +82 -0
  154. package/web-dist/noVNC/core/crypto/rsa.js +132 -0
  155. package/web-dist/noVNC/core/decoders/copyrect.js +27 -0
  156. package/web-dist/noVNC/core/decoders/h264.js +321 -0
  157. package/web-dist/noVNC/core/decoders/hextile.js +181 -0
  158. package/web-dist/noVNC/core/decoders/jpeg.js +161 -0
  159. package/web-dist/noVNC/core/decoders/raw.js +59 -0
  160. package/web-dist/noVNC/core/decoders/rre.js +44 -0
  161. package/web-dist/noVNC/core/decoders/tight.js +393 -0
  162. package/web-dist/noVNC/core/decoders/tightpng.js +27 -0
  163. package/web-dist/noVNC/core/decoders/zlib.js +51 -0
  164. package/web-dist/noVNC/core/decoders/zrle.js +185 -0
  165. package/web-dist/noVNC/core/deflator.js +84 -0
  166. package/web-dist/noVNC/core/display.js +578 -0
  167. package/web-dist/noVNC/core/encodings.js +54 -0
  168. package/web-dist/noVNC/core/inflator.js +65 -0
  169. package/web-dist/noVNC/core/input/domkeytable.js +311 -0
  170. package/web-dist/noVNC/core/input/fixedkeys.js +129 -0
  171. package/web-dist/noVNC/core/input/gesturehandler.js +567 -0
  172. package/web-dist/noVNC/core/input/keyboard.js +294 -0
  173. package/web-dist/noVNC/core/input/keysym.js +616 -0
  174. package/web-dist/noVNC/core/input/keysymdef.js +688 -0
  175. package/web-dist/noVNC/core/input/util.js +191 -0
  176. package/web-dist/noVNC/core/input/vkeys.js +116 -0
  177. package/web-dist/noVNC/core/input/xtscancodes.js +173 -0
  178. package/web-dist/noVNC/core/ra2.js +312 -0
  179. package/web-dist/noVNC/core/rfb.js +3426 -0
  180. package/web-dist/noVNC/core/util/browser.js +266 -0
  181. package/web-dist/noVNC/core/util/cursor.js +249 -0
  182. package/web-dist/noVNC/core/util/element.js +32 -0
  183. package/web-dist/noVNC/core/util/events.js +138 -0
  184. package/web-dist/noVNC/core/util/eventtarget.js +35 -0
  185. package/web-dist/noVNC/core/util/int.js +15 -0
  186. package/web-dist/noVNC/core/util/logging.js +56 -0
  187. package/web-dist/noVNC/core/util/strings.js +28 -0
  188. package/web-dist/noVNC/core/websock.js +369 -0
  189. package/web-dist/noVNC/defaults.json +1 -0
  190. package/web-dist/noVNC/mandatory.json +1 -0
  191. package/web-dist/noVNC/vendor/pako/LICENSE +21 -0
  192. package/web-dist/noVNC/vendor/pako/README.md +6 -0
  193. package/web-dist/noVNC/vendor/pako/lib/utils/common.js +45 -0
  194. package/web-dist/noVNC/vendor/pako/lib/zlib/adler32.js +27 -0
  195. package/web-dist/noVNC/vendor/pako/lib/zlib/constants.js +47 -0
  196. package/web-dist/noVNC/vendor/pako/lib/zlib/crc32.js +36 -0
  197. package/web-dist/noVNC/vendor/pako/lib/zlib/deflate.js +1846 -0
  198. package/web-dist/noVNC/vendor/pako/lib/zlib/gzheader.js +35 -0
  199. package/web-dist/noVNC/vendor/pako/lib/zlib/inffast.js +324 -0
  200. package/web-dist/noVNC/vendor/pako/lib/zlib/inflate.js +1527 -0
  201. package/web-dist/noVNC/vendor/pako/lib/zlib/inftrees.js +322 -0
  202. package/web-dist/noVNC/vendor/pako/lib/zlib/messages.js +11 -0
  203. package/web-dist/noVNC/vendor/pako/lib/zlib/trees.js +1195 -0
  204. package/web-dist/noVNC/vendor/pako/lib/zlib/zstream.js +24 -0
  205. package/web-dist/noVNC/vnc_lite.html +180 -0
  206. package/web-dist/assets/channel-r3VxZeIf.js +0 -1
  207. package/web-dist/assets/classDiagram-VBA2DB6C-BRBktPwb.js +0 -1
  208. package/web-dist/assets/classDiagram-v2-RAHNMMFH-BRBktPwb.js +0 -1
  209. package/web-dist/assets/clone-rt9RfsvE.js +0 -1
  210. package/web-dist/assets/stateDiagram-v2-FVOUBMTO-C28Nk4KM.js +0 -1
@@ -0,0 +1,927 @@
1
+ /*
2
+ * noVNC base CSS
3
+ * Copyright (C) 2019 The noVNC authors
4
+ * noVNC is licensed under the MPL 2.0 (see LICENSE.txt)
5
+ * This file is licensed under the 2-Clause BSD license (see LICENSE.txt).
6
+ */
7
+
8
+ /*
9
+ * Z index layers:
10
+ *
11
+ * 0: Main screen
12
+ * 10: Control bar
13
+ * 50: Transition blocker
14
+ * 60: Connection popups
15
+ * 100: Status bar
16
+ * ...
17
+ * 1000: Javascript crash
18
+ * ...
19
+ * 10000: Max (used for polyfills)
20
+ */
21
+
22
+ /*
23
+ * State variables (set on :root):
24
+ *
25
+ * noVNC_loading: Page is still loading
26
+ * noVNC_connecting: Connecting to server
27
+ * noVNC_reconnecting: Re-establishing a connection
28
+ * noVNC_connected: Connected to server (most common state)
29
+ * noVNC_disconnecting: Disconnecting from server
30
+ */
31
+
32
+ :root {
33
+ font-family: sans-serif;
34
+ line-height: 1.6;
35
+ }
36
+
37
+ body {
38
+ margin:0;
39
+ padding:0;
40
+ /*Background image with light grey curve.*/
41
+ background-color:#494949;
42
+ background-repeat:no-repeat;
43
+ background-position:right bottom;
44
+ height:100%;
45
+ touch-action: none;
46
+ }
47
+
48
+ html {
49
+ height:100%;
50
+ }
51
+
52
+ .noVNC_only_touch.noVNC_hidden {
53
+ display: none;
54
+ }
55
+
56
+ .noVNC_disabled {
57
+ color: var(--novnc-grey);
58
+ }
59
+
60
+ /* ----------------------------------------
61
+ * Spinner
62
+ * ----------------------------------------
63
+ */
64
+
65
+ .noVNC_spinner {
66
+ position: relative;
67
+ }
68
+ .noVNC_spinner, .noVNC_spinner::before, .noVNC_spinner::after {
69
+ width: 10px;
70
+ height: 10px;
71
+ border-radius: 2px;
72
+ box-shadow: -60px 10px 0 rgba(255, 255, 255, 0);
73
+ animation: noVNC_spinner 1.0s linear infinite;
74
+ }
75
+ .noVNC_spinner::before {
76
+ content: "";
77
+ position: absolute;
78
+ left: 0px;
79
+ top: 0px;
80
+ animation-delay: -0.1s;
81
+ }
82
+ .noVNC_spinner::after {
83
+ content: "";
84
+ position: absolute;
85
+ top: 0px;
86
+ left: 0px;
87
+ animation-delay: 0.1s;
88
+ }
89
+ @keyframes noVNC_spinner {
90
+ 0% { box-shadow: -60px 10px 0 rgba(255, 255, 255, 0); width: 20px; }
91
+ 25% { box-shadow: 20px 10px 0 rgba(255, 255, 255, 1); width: 10px; }
92
+ 50% { box-shadow: 60px 10px 0 rgba(255, 255, 255, 0); width: 10px; }
93
+ }
94
+
95
+ /* ----------------------------------------
96
+ * WebKit centering hacks
97
+ * ----------------------------------------
98
+ */
99
+
100
+ .noVNC_center {
101
+ /*
102
+ * This is a workaround because webkit misrenders transforms and
103
+ * uses non-integer coordinates, resulting in blurry content.
104
+ * Ideally we'd use "top: 50%; transform: translateY(-50%);" on
105
+ * the objects instead.
106
+ */
107
+ display: flex;
108
+ align-items: center;
109
+ justify-content: center;
110
+ position: fixed;
111
+ top: 0;
112
+ left: 0;
113
+ width: 100%;
114
+ height: 100%;
115
+ pointer-events: none;
116
+ }
117
+ .noVNC_center > * {
118
+ pointer-events: auto;
119
+ }
120
+ .noVNC_vcenter {
121
+ display: flex !important;
122
+ flex-direction: column;
123
+ justify-content: center;
124
+ position: fixed;
125
+ top: 0;
126
+ left: 0;
127
+ height: 100%;
128
+ margin: 0 !important;
129
+ padding: 0 !important;
130
+ pointer-events: none;
131
+ }
132
+ .noVNC_vcenter > * {
133
+ pointer-events: auto;
134
+ }
135
+
136
+ /* ----------------------------------------
137
+ * Layering
138
+ * ----------------------------------------
139
+ */
140
+
141
+ .noVNC_connect_layer {
142
+ z-index: 60;
143
+ }
144
+
145
+ /* ----------------------------------------
146
+ * Fallback error
147
+ * ----------------------------------------
148
+ */
149
+
150
+ #noVNC_fallback_error {
151
+ z-index: 1000;
152
+ visibility: hidden;
153
+ /* Put a dark background in front of everything but the error,
154
+ and don't let mouse events pass through */
155
+ background: rgba(0, 0, 0, 0.8);
156
+ pointer-events: all;
157
+ }
158
+ #noVNC_fallback_error.noVNC_open {
159
+ visibility: visible;
160
+ }
161
+
162
+ #noVNC_fallback_error > div {
163
+ max-width: calc(100vw - 30px - 30px);
164
+ max-height: calc(100vh - 30px - 30px);
165
+ overflow: auto;
166
+
167
+ padding: 15px;
168
+
169
+ transition: 0.5s ease-in-out;
170
+
171
+ transform: translateY(-50px);
172
+ opacity: 0;
173
+
174
+ text-align: center;
175
+ font-weight: bold;
176
+ color: #fff;
177
+
178
+ border-radius: 12px;
179
+ box-shadow: 6px 6px 0px rgba(0, 0, 0, 0.5);
180
+ background: rgba(200,55,55,0.8);
181
+ }
182
+ #noVNC_fallback_error.noVNC_open > div {
183
+ transform: translateY(0);
184
+ opacity: 1;
185
+ }
186
+
187
+ #noVNC_fallback_errormsg {
188
+ font-weight: normal;
189
+ }
190
+
191
+ #noVNC_fallback_errormsg .noVNC_message {
192
+ display: inline-block;
193
+ text-align: left;
194
+ font-family: monospace;
195
+ white-space: pre-wrap;
196
+ }
197
+
198
+ #noVNC_fallback_error .noVNC_location {
199
+ font-style: italic;
200
+ font-size: 0.8em;
201
+ color: rgba(255, 255, 255, 0.8);
202
+ }
203
+
204
+ #noVNC_fallback_error .noVNC_stack {
205
+ padding: 10px;
206
+ margin: 10px;
207
+ font-size: 0.8em;
208
+ text-align: left;
209
+ font-family: monospace;
210
+ white-space: pre;
211
+ border: 1px solid rgba(0, 0, 0, 0.5);
212
+ background: rgba(0, 0, 0, 0.2);
213
+ overflow: auto;
214
+ }
215
+
216
+ /* ----------------------------------------
217
+ * Control bar
218
+ * ----------------------------------------
219
+ */
220
+
221
+ #noVNC_control_bar_anchor {
222
+ /* The anchor is needed to get z-stacking to work */
223
+ position: fixed;
224
+ z-index: 10;
225
+
226
+ transition: 0.5s ease-in-out;
227
+
228
+ /* Edge misrenders animations wihthout this */
229
+ transform: translateX(0);
230
+ }
231
+ :root.noVNC_connected #noVNC_control_bar_anchor.noVNC_idle {
232
+ opacity: 0.8;
233
+ }
234
+ #noVNC_control_bar_anchor.noVNC_right {
235
+ left: auto;
236
+ right: 0;
237
+ }
238
+
239
+ #noVNC_control_bar {
240
+ position: relative;
241
+ left: -100%;
242
+
243
+ transition: 0.5s ease-in-out;
244
+
245
+ background-color: var(--novnc-blue);
246
+ border-radius: 0 12px 12px 0;
247
+
248
+ user-select: none;
249
+ -webkit-user-select: none;
250
+ -webkit-touch-callout: none; /* Disable iOS image long-press popup */
251
+ }
252
+ #noVNC_control_bar.noVNC_open {
253
+ box-shadow: 6px 6px 0px rgba(0, 0, 0, 0.5);
254
+ left: 0;
255
+ }
256
+ #noVNC_control_bar::before {
257
+ /* This extra element is to get a proper shadow */
258
+ content: "";
259
+ position: absolute;
260
+ z-index: -1;
261
+ height: 100%;
262
+ width: 30px;
263
+ left: -30px;
264
+ transition: box-shadow 0.5s ease-in-out;
265
+ }
266
+ #noVNC_control_bar.noVNC_open::before {
267
+ box-shadow: 6px 6px 0px rgba(0, 0, 0, 0.5);
268
+ }
269
+ .noVNC_right #noVNC_control_bar {
270
+ left: 100%;
271
+ border-radius: 12px 0 0 12px;
272
+ }
273
+ .noVNC_right #noVNC_control_bar.noVNC_open {
274
+ left: 0;
275
+ }
276
+ .noVNC_right #noVNC_control_bar::before {
277
+ visibility: hidden;
278
+ }
279
+
280
+ #noVNC_control_bar_handle {
281
+ position: absolute;
282
+ left: -15px;
283
+ top: 0;
284
+ transform: translateY(35px);
285
+ width: calc(100% + 30px);
286
+ height: 50px;
287
+ z-index: -1;
288
+ cursor: pointer;
289
+ border-radius: 6px;
290
+ background-color: var(--novnc-darkblue);
291
+ background-image: url("../images/handle_bg.svg");
292
+ background-repeat: no-repeat;
293
+ background-position: right;
294
+ box-shadow: 3px 3px 0px rgba(0, 0, 0, 0.5);
295
+ }
296
+ #noVNC_control_bar_handle:after {
297
+ content: "";
298
+ transition: transform 0.5s ease-in-out;
299
+ background: url("../images/handle.svg");
300
+ position: absolute;
301
+ top: 22px; /* (50px-6px)/2 */
302
+ right: 5px;
303
+ width: 5px;
304
+ height: 6px;
305
+ }
306
+ #noVNC_control_bar.noVNC_open #noVNC_control_bar_handle:after {
307
+ transform: translateX(1px) rotate(180deg);
308
+ }
309
+ :root:not(.noVNC_connected) #noVNC_control_bar_handle {
310
+ display: none;
311
+ }
312
+ .noVNC_right #noVNC_control_bar_handle {
313
+ background-position: left;
314
+ }
315
+ .noVNC_right #noVNC_control_bar_handle:after {
316
+ left: 5px;
317
+ right: 0;
318
+ transform: translateX(1px) rotate(180deg);
319
+ }
320
+ .noVNC_right #noVNC_control_bar.noVNC_open #noVNC_control_bar_handle:after {
321
+ transform: none;
322
+ }
323
+ /* Larger touch area for the handle, used when a touch screen is available */
324
+ #noVNC_control_bar_handle div {
325
+ position: absolute;
326
+ right: -35px;
327
+ top: 0;
328
+ width: 50px;
329
+ height: 100%;
330
+ display: none;
331
+ }
332
+ @media (any-pointer: coarse) {
333
+ #noVNC_control_bar_handle div {
334
+ display: initial;
335
+ }
336
+ }
337
+ .noVNC_right #noVNC_control_bar_handle div {
338
+ left: -35px;
339
+ right: auto;
340
+ }
341
+
342
+ #noVNC_control_bar > .noVNC_scroll {
343
+ max-height: 100vh; /* Chrome is buggy with 100% */
344
+ overflow-x: hidden;
345
+ overflow-y: auto;
346
+ padding: 0 10px;
347
+ }
348
+
349
+ #noVNC_control_bar > .noVNC_scroll > * {
350
+ display: block;
351
+ margin: 10px auto;
352
+ }
353
+
354
+ /* Control bar hint */
355
+ #noVNC_hint_anchor {
356
+ position: fixed;
357
+ right: -50px;
358
+ left: auto;
359
+ }
360
+ #noVNC_control_bar_anchor.noVNC_right + #noVNC_hint_anchor {
361
+ left: -50px;
362
+ right: auto;
363
+ }
364
+ #noVNC_control_bar_hint {
365
+ position: relative;
366
+ transform: scale(0);
367
+ width: 100px;
368
+ height: 50%;
369
+ max-height: 600px;
370
+
371
+ visibility: hidden;
372
+ opacity: 0;
373
+ transition: 0.2s ease-in-out;
374
+ background: transparent;
375
+ box-shadow: 0 0 10px black, inset 0 0 10px 10px var(--novnc-darkblue);
376
+ border-radius: 12px;
377
+ transition-delay: 0s;
378
+ }
379
+ #noVNC_control_bar_hint.noVNC_active {
380
+ visibility: visible;
381
+ opacity: 1;
382
+ transition-delay: 0.2s;
383
+ transform: scale(1);
384
+ }
385
+ #noVNC_control_bar_hint.noVNC_notransition {
386
+ transition: none !important;
387
+ }
388
+
389
+ /* Control bar buttons */
390
+ #noVNC_control_bar .noVNC_button {
391
+ min-width: unset;
392
+ padding: 4px 4px;
393
+ vertical-align: middle;
394
+ border:1px solid rgba(255, 255, 255, 0.2);
395
+ border-radius: 6px;
396
+ background-color: transparent;
397
+ }
398
+ #noVNC_control_bar .noVNC_button.noVNC_selected {
399
+ border-color: rgba(0, 0, 0, 0.8);
400
+ background-color: rgba(0, 0, 0, 0.5);
401
+ }
402
+ #noVNC_control_bar .noVNC_button.noVNC_hidden {
403
+ display: none !important;
404
+ }
405
+
406
+ /* Panels */
407
+ .noVNC_panel {
408
+ transform: translateX(25px);
409
+
410
+ transition: 0.5s ease-in-out;
411
+
412
+ box-sizing: border-box; /* so max-width don't have to care about padding */
413
+ max-width: calc(100vw - 75px - 25px); /* minus left and right margins */
414
+ max-height: 100vh; /* Chrome is buggy with 100% */
415
+ overflow-x: hidden;
416
+ overflow-y: auto;
417
+
418
+ visibility: hidden;
419
+ opacity: 0;
420
+
421
+ padding: 15px;
422
+
423
+ background: #fff;
424
+ border-radius: 12px;
425
+ color: #000;
426
+ border: 2px solid #E0E0E0;
427
+ box-shadow: 6px 6px 0px rgba(0, 0, 0, 0.5);
428
+ }
429
+ .noVNC_panel.noVNC_open {
430
+ visibility: visible;
431
+ opacity: 1;
432
+ transform: translateX(75px);
433
+ }
434
+ .noVNC_right .noVNC_vcenter {
435
+ left: auto;
436
+ right: 0;
437
+ }
438
+ .noVNC_right .noVNC_panel {
439
+ transform: translateX(-25px);
440
+ }
441
+ .noVNC_right .noVNC_panel.noVNC_open {
442
+ transform: translateX(-75px);
443
+ }
444
+
445
+ .noVNC_panel > * {
446
+ display: block;
447
+ margin: 10px auto;
448
+ }
449
+ .noVNC_panel > *:first-child {
450
+ margin-top: 0 !important;
451
+ }
452
+ .noVNC_panel > *:last-child {
453
+ margin-bottom: 0 !important;
454
+ }
455
+
456
+ .noVNC_panel hr {
457
+ border: none;
458
+ border-top: 1px solid var(--novnc-lightgrey);
459
+ width: 100%; /* <hr> inside a flexbox will otherwise be 0px wide */
460
+ }
461
+
462
+ .noVNC_panel label {
463
+ display: block;
464
+ white-space: nowrap;
465
+ margin: 5px;
466
+ }
467
+ @media (max-width: 540px) {
468
+ /* Allow wrapping on small screens */
469
+ .noVNC_panel label {
470
+ white-space: unset;
471
+ }
472
+ }
473
+
474
+ .noVNC_panel li {
475
+ margin: 5px;
476
+ }
477
+
478
+ .noVNC_panel .noVNC_heading {
479
+ background-color: var(--novnc-blue);
480
+ border-radius: 6px;
481
+ padding: 5px 8px;
482
+ /* Compensate for padding in image */
483
+ padding-right: 11px;
484
+ display: flex;
485
+ align-items: center;
486
+ gap: 6px;
487
+ color: white;
488
+ font-size: 20px;
489
+ font-weight: bold;
490
+ white-space: nowrap;
491
+ }
492
+ .noVNC_panel .noVNC_heading img {
493
+ vertical-align: bottom;
494
+ }
495
+
496
+ .noVNC_panel form {
497
+ display: flex;
498
+ flex-direction: column;
499
+ gap: 12px
500
+ }
501
+
502
+ .noVNC_panel .button_row {
503
+ margin-top: 10px;
504
+ display: flex;
505
+ gap: 10px;
506
+ justify-content: space-between;
507
+ }
508
+ .noVNC_panel .button_row *:only-child {
509
+ margin-left: auto; /* Align single buttons to the right */
510
+ }
511
+
512
+ /* Expanders */
513
+ .noVNC_expander {
514
+ cursor: pointer;
515
+ }
516
+ .noVNC_expander::before {
517
+ content: url("../images/expander.svg");
518
+ display: inline-block;
519
+ margin-right: 5px;
520
+ transition: 0.2s ease-in-out;
521
+ }
522
+ .noVNC_expander.noVNC_open::before {
523
+ transform: rotateZ(90deg);
524
+ }
525
+ .noVNC_expander ~ * {
526
+ margin: 5px;
527
+ margin-left: 10px;
528
+ padding: 5px;
529
+ background: rgba(0, 0, 0, 0.04);
530
+ border-radius: 6px;
531
+ }
532
+ .noVNC_expander:not(.noVNC_open) ~ * {
533
+ display: none;
534
+ }
535
+
536
+ /* Control bar content */
537
+
538
+ #noVNC_control_bar .noVNC_logo {
539
+ font-size: 13px;
540
+ }
541
+
542
+ .noVNC_logo + hr {
543
+ /* Remove all but top border */
544
+ border: none;
545
+ border-top: 1px solid rgba(255, 255, 255, 0.2);
546
+ }
547
+
548
+ :root:not(.noVNC_connected) #noVNC_view_drag_button {
549
+ display: none;
550
+ }
551
+
552
+ /* noVNC Touch Device only buttons */
553
+ :root:not(.noVNC_connected) #noVNC_mobile_buttons {
554
+ display: none;
555
+ }
556
+ @media not all and (any-pointer: coarse) {
557
+ /* FIXME: The button for the virtual keyboard is the only button in this
558
+ group of "mobile buttons". It is bad to assume that no touch
559
+ devices have physical keyboards available. Hopefully we can get
560
+ a media query for this:
561
+ https://github.com/w3c/csswg-drafts/issues/3871 */
562
+ :root.noVNC_connected #noVNC_mobile_buttons {
563
+ display: none;
564
+ }
565
+ }
566
+
567
+ /* Extra manual keys */
568
+ :root:not(.noVNC_connected) #noVNC_toggle_extra_keys_button {
569
+ display: none;
570
+ }
571
+
572
+ #noVNC_modifiers {
573
+ background-color: var(--novnc-darkgrey);
574
+ border: none;
575
+ padding: 10px;
576
+ }
577
+
578
+ /* Shutdown/Reboot */
579
+ :root:not(.noVNC_connected) #noVNC_power_button {
580
+ display: none;
581
+ }
582
+ #noVNC_power {
583
+ }
584
+ #noVNC_power_buttons {
585
+ display: none;
586
+ }
587
+
588
+ #noVNC_power input[type=button] {
589
+ width: 100%;
590
+ }
591
+
592
+ /* Clipboard */
593
+ :root:not(.noVNC_connected) #noVNC_clipboard_button {
594
+ display: none;
595
+ }
596
+ #noVNC_clipboard_text {
597
+ width: 360px;
598
+ min-width: 150px;
599
+ height: 160px;
600
+ min-height: 70px;
601
+
602
+ box-sizing: border-box;
603
+ max-width: 100%;
604
+ /* minus approximate height of title, height of subtitle, and margin */
605
+ max-height: calc(100vh - 10em - 25px);
606
+ }
607
+
608
+ /* Settings */
609
+ #noVNC_settings {
610
+ }
611
+ #noVNC_settings ul {
612
+ list-style: none;
613
+ padding: 0px;
614
+ }
615
+ #noVNC_settings button,
616
+ #noVNC_settings select,
617
+ #noVNC_settings textarea,
618
+ #noVNC_settings input:not([type=checkbox]):not([type=radio]) {
619
+ margin-left: 6px;
620
+ /* Prevent inputs in settings from being too wide */
621
+ max-width: calc(100% - 6px - var(--input-xpadding) * 2);
622
+ }
623
+
624
+ #noVNC_setting_port {
625
+ width: 80px;
626
+ }
627
+ #noVNC_setting_path {
628
+ width: 100px;
629
+ }
630
+
631
+ /* Version */
632
+
633
+ .noVNC_version_wrapper {
634
+ font-size: small;
635
+ }
636
+
637
+ .noVNC_version {
638
+ margin-left: 1rem;
639
+ }
640
+
641
+ /* Connection controls */
642
+ :root:not(.noVNC_connected) #noVNC_disconnect_button {
643
+ display: none;
644
+ }
645
+
646
+ /* ----------------------------------------
647
+ * Status dialog
648
+ * ----------------------------------------
649
+ */
650
+
651
+ #noVNC_status {
652
+ position: fixed;
653
+ top: 0;
654
+ left: 0;
655
+ width: 100%;
656
+ z-index: 100;
657
+ transform: translateY(-100%);
658
+
659
+ cursor: pointer;
660
+
661
+ transition: 0.5s ease-in-out;
662
+
663
+ visibility: hidden;
664
+ opacity: 0;
665
+
666
+ padding: 5px;
667
+
668
+ display: flex;
669
+ flex-direction: row;
670
+ justify-content: center;
671
+ align-content: center;
672
+
673
+ line-height: 1.6;
674
+ word-wrap: break-word;
675
+ color: #fff;
676
+
677
+ border-bottom: 1px solid rgba(0, 0, 0, 0.9);
678
+ }
679
+ #noVNC_status.noVNC_open {
680
+ transform: translateY(0);
681
+ visibility: visible;
682
+ opacity: 1;
683
+ }
684
+
685
+ #noVNC_status::before {
686
+ content: "";
687
+ display: inline-block;
688
+ width: 25px;
689
+ height: 25px;
690
+ margin-right: 5px;
691
+ }
692
+
693
+ #noVNC_status.noVNC_status_normal {
694
+ background: rgba(128,128,128,0.9);
695
+ }
696
+ #noVNC_status.noVNC_status_normal::before {
697
+ content: url("../images/info.svg") " ";
698
+ }
699
+ #noVNC_status.noVNC_status_error {
700
+ background: rgba(200,55,55,0.9);
701
+ }
702
+ #noVNC_status.noVNC_status_error::before {
703
+ content: url("../images/error.svg") " ";
704
+ }
705
+ #noVNC_status.noVNC_status_warn {
706
+ background: rgba(180,180,30,0.9);
707
+ }
708
+ #noVNC_status.noVNC_status_warn::before {
709
+ content: url("../images/warning.svg") " ";
710
+ }
711
+
712
+ /* ----------------------------------------
713
+ * Connect dialog
714
+ * ----------------------------------------
715
+ */
716
+
717
+ #noVNC_connect_dlg {
718
+ transition: 0.5s ease-in-out;
719
+
720
+ transform: scale(0, 0);
721
+ visibility: hidden;
722
+ opacity: 0;
723
+ }
724
+ #noVNC_connect_dlg.noVNC_open {
725
+ transform: scale(1, 1);
726
+ visibility: visible;
727
+ opacity: 1;
728
+ }
729
+ #noVNC_connect_dlg .noVNC_logo {
730
+ transition: 0.5s ease-in-out;
731
+ padding: 10px;
732
+ margin-bottom: 10px;
733
+
734
+ font-size: 80px;
735
+ text-align: center;
736
+
737
+ border-radius: 6px;
738
+ }
739
+ @media (max-width: 440px) {
740
+ #noVNC_connect_dlg {
741
+ max-width: calc(100vw - 100px);
742
+ }
743
+ #noVNC_connect_dlg .noVNC_logo {
744
+ font-size: calc(25vw - 30px);
745
+ }
746
+ }
747
+ #noVNC_connect_dlg div {
748
+ padding: 18px;
749
+
750
+ background-color: var(--novnc-darkgrey);
751
+ border-radius: 12px;
752
+ text-align: center;
753
+ font-size: 20px;
754
+
755
+ box-shadow: 6px 6px 0px rgba(0, 0, 0, 0.5);
756
+ }
757
+ #noVNC_connect_button {
758
+ width: 100%;
759
+ padding: 6px 30px;
760
+ cursor: pointer;
761
+ border-color: transparent;
762
+ border-radius: 12px;
763
+ background-color: var(--novnc-blue);
764
+ color: white;
765
+
766
+ display: flex;
767
+ justify-content: center;
768
+ place-items: center;
769
+ gap: 4px;
770
+ }
771
+
772
+ #noVNC_connect_button img {
773
+ vertical-align: bottom;
774
+ height: 1.3em;
775
+ }
776
+
777
+ /* ----------------------------------------
778
+ * Server verification dialog
779
+ * ----------------------------------------
780
+ */
781
+
782
+ #noVNC_verify_server_dlg {
783
+ position: relative;
784
+
785
+ transform: translateY(-50px);
786
+ }
787
+ #noVNC_verify_server_dlg.noVNC_open {
788
+ transform: translateY(0);
789
+ }
790
+ #noVNC_fingerprint_block {
791
+ margin: 10px;
792
+ }
793
+
794
+ /* ----------------------------------------
795
+ * Password dialog
796
+ * ----------------------------------------
797
+ */
798
+
799
+ #noVNC_credentials_dlg {
800
+ position: relative;
801
+
802
+ transform: translateY(-50px);
803
+ }
804
+ #noVNC_credentials_dlg.noVNC_open {
805
+ transform: translateY(0);
806
+ }
807
+ #noVNC_username_block.noVNC_hidden,
808
+ #noVNC_password_block.noVNC_hidden {
809
+ display: none;
810
+ }
811
+
812
+
813
+ /* ----------------------------------------
814
+ * Main area
815
+ * ----------------------------------------
816
+ */
817
+
818
+ /* Transition screen */
819
+ #noVNC_transition {
820
+ transition: 0.5s ease-in-out;
821
+
822
+ display: flex;
823
+ opacity: 0;
824
+ visibility: hidden;
825
+
826
+ position: fixed;
827
+ top: 0;
828
+ left: 0;
829
+ bottom: 0;
830
+ right: 0;
831
+
832
+ color: white;
833
+ background: rgba(0, 0, 0, 0.5);
834
+ z-index: 50;
835
+
836
+ /*display: flex;*/
837
+ align-items: center;
838
+ justify-content: center;
839
+ flex-direction: column;
840
+ }
841
+ :root.noVNC_loading #noVNC_transition,
842
+ :root.noVNC_connecting #noVNC_transition,
843
+ :root.noVNC_disconnecting #noVNC_transition,
844
+ :root.noVNC_reconnecting #noVNC_transition {
845
+ opacity: 1;
846
+ visibility: visible;
847
+ }
848
+ :root:not(.noVNC_reconnecting) #noVNC_cancel_reconnect_button {
849
+ display: none;
850
+ }
851
+ #noVNC_transition_text {
852
+ font-size: 1.5em;
853
+ }
854
+
855
+ /* Main container */
856
+ #noVNC_container {
857
+ width: 100%;
858
+ height: 100%;
859
+ background-color: #313131;
860
+ border-bottom-right-radius: 800px 600px;
861
+ /*border-top-left-radius: 800px 600px;*/
862
+
863
+ /* If selection isn't disabled, long-pressing stuff in the sidebar
864
+ can accidentally select the container or the canvas. This can
865
+ happen when attempting to move the handle. */
866
+ user-select: none;
867
+ -webkit-user-select: none;
868
+ }
869
+
870
+ #noVNC_keyboardinput {
871
+ width: 1px;
872
+ height: 1px;
873
+ background-color: #fff;
874
+ color: #fff;
875
+ border: 0;
876
+ position: absolute;
877
+ left: -40px;
878
+ z-index: -1;
879
+ ime-mode: disabled;
880
+ }
881
+
882
+ /*Default noVNC logo.*/
883
+ /* From: http://fonts.googleapis.com/css?family=Orbitron:700 */
884
+ @font-face {
885
+ font-family: 'Orbitron';
886
+ font-style: normal;
887
+ font-weight: 700;
888
+ src: local('?'), url('Orbitron700.woff') format('woff'),
889
+ url('Orbitron700.ttf') format('truetype');
890
+ }
891
+
892
+ .noVNC_logo {
893
+ color: var(--novnc-yellow);
894
+ font-family: 'Orbitron', 'OrbitronTTF', sans-serif;
895
+ line-height: 0.9;
896
+ text-shadow: 0.1em 0.1em 0 black;
897
+ }
898
+ .noVNC_logo span{
899
+ color: var(--novnc-green);
900
+ }
901
+
902
+ #noVNC_bell {
903
+ display: none;
904
+ }
905
+
906
+ /* ----------------------------------------
907
+ * Media sizing
908
+ * ----------------------------------------
909
+ */
910
+
911
+ @media screen and (max-width: 640px){
912
+ #noVNC_logo {
913
+ font-size: 150px;
914
+ }
915
+ }
916
+
917
+ @media screen and (min-width: 321px) and (max-width: 480px) {
918
+ #noVNC_logo {
919
+ font-size: 110px;
920
+ }
921
+ }
922
+
923
+ @media screen and (max-width: 320px) {
924
+ #noVNC_logo {
925
+ font-size: 90px;
926
+ }
927
+ }