mirror of
https://github.com/wailsapp/wails.git
synced 2025-05-02 16:51:16 +08:00
179 lines
5.7 KiB
HTML
179 lines
5.7 KiB
HTML
<html>
|
|
|
|
<head>
|
|
<title>Wails Headless</title>
|
|
<style>
|
|
.wails-reconnect-overlay {
|
|
position: fixed;
|
|
top: 0;
|
|
left: 0;
|
|
width: 100%;
|
|
height: 100%;
|
|
background: rgba(0, 0, 0, 0.6);
|
|
font-family: sans-serif;
|
|
display: none;
|
|
z-index: 999999;
|
|
}
|
|
|
|
.wails-reconnect-overlay-content {
|
|
padding: 20px 30px;
|
|
text-align: center;
|
|
width: 20em;
|
|
position: relative;
|
|
height: 17em;
|
|
border-radius: 1em;
|
|
margin: 5% auto 0;
|
|
background-color: white;
|
|
box-shadow: 1px 1px 20px 3px;
|
|
background-image: url("");
|
|
background-repeat: no-repeat;
|
|
background-position: center;
|
|
}
|
|
|
|
.wails-reconnect-overlay-title {
|
|
font-size: 2em;
|
|
}
|
|
|
|
.wails-reconnect-overlay-message {
|
|
font-size: 1.3em;
|
|
}
|
|
|
|
/* https://codepen.io/EastingAndNorthing/pen/aNWrZz - Cheers Mark! */
|
|
|
|
.wails-reconnect-overlay-loadingspinner {
|
|
pointer-events: none;
|
|
width: 2.5em;
|
|
height: 2.5em;
|
|
border: 0.4em solid transparent;
|
|
border-color: #eee;
|
|
border-top-color: #3E67EC;
|
|
border-radius: 50%;
|
|
animation: loadingspin 1s linear infinite;
|
|
margin: auto;
|
|
padding: 2.5em;
|
|
}
|
|
|
|
@keyframes loadingspin {
|
|
100% {
|
|
transform: rotate(360deg)
|
|
}
|
|
}
|
|
</style>
|
|
</head>
|
|
|
|
<body>
|
|
<div class="wails-reconnect-overlay">
|
|
<div class="wails-reconnect-overlay-content">
|
|
<div class="wails-reconnect-overlay-title">Disconnected</div><br>
|
|
<div class="wails-reconnect-overlay-loadingspinner"></div><br>
|
|
<div class="wails-reconnect-overlay-message">Waiting for backend</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div id="app"></div>
|
|
|
|
<script id="wails-headless-runtime">
|
|
(function () {
|
|
|
|
var websocket = null;
|
|
var connectTimer = null;
|
|
var reconnectOverlay = document.querySelector(".wails-reconnect-overlay");
|
|
var connectionState = "disconnected";
|
|
|
|
function showReconnectOverlay() {
|
|
reconnectOverlay.style.display = 'block';
|
|
}
|
|
|
|
function hideReconnectOverlay() {
|
|
reconnectOverlay.style.display = 'none';
|
|
}
|
|
|
|
window.external = {
|
|
invoke: function (msg) {
|
|
websocket.send(msg);
|
|
}
|
|
};
|
|
|
|
function addScript(script, id) {
|
|
var s = document.createElement("script")
|
|
if (id) {
|
|
s.id = id;
|
|
}
|
|
s.textContent = script;
|
|
document.head.appendChild(s)
|
|
}
|
|
|
|
function handleConnect() {
|
|
console.log("[Wails] Connected to backend");
|
|
addKeyListener();
|
|
hideReconnectOverlay();
|
|
clearInterval(connectTimer);
|
|
websocket.onclose = handleDisconnect;
|
|
websocket.onmessage = handleMessage;
|
|
connectionState = "connected";
|
|
// websocket.onerror = function () { }
|
|
}
|
|
|
|
function handleDisconnect() {
|
|
console.log("[Wails] Disconnected from backend");
|
|
websocket = null;
|
|
removeKeyListener();
|
|
connectionState = "disconnected";
|
|
showReconnectOverlay();
|
|
connect();
|
|
}
|
|
|
|
function connect() {
|
|
connectTimer = setInterval(function () {
|
|
if (websocket == null) {
|
|
websocket = new WebSocket("ws://localhost:34115/ws")
|
|
websocket.onopen = handleConnect;
|
|
websocket.onerror = function (e) {
|
|
e.stopImmediatePropagation();
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
websocket = null;
|
|
return false
|
|
}
|
|
}
|
|
}, 300);
|
|
}
|
|
|
|
function handleMessage(e) {
|
|
addScript(e.data);
|
|
}
|
|
|
|
// Key listener
|
|
var delta = 300;
|
|
var lastKeypressTime = 0;
|
|
function KeyHandler(event) {
|
|
if (event.key === "`") {
|
|
var thisKeypressTime = new Date();
|
|
if (thisKeypressTime - lastKeypressTime <= delta) {
|
|
console.log("Double tap!")
|
|
// optional - if we'd rather not detect a triple-press
|
|
// as a second double-press, reset the timestamp
|
|
thisKeypressTime = 0;
|
|
}
|
|
lastKeypressTime = thisKeypressTime;
|
|
}
|
|
}
|
|
|
|
function addKeyListener() {
|
|
document.body.addEventListener('keydown', KeyHandler);
|
|
}
|
|
|
|
function removeKeyListener() {
|
|
document.body.removeEventListener('keydown', KeyHandler);
|
|
}
|
|
|
|
connect();
|
|
|
|
|
|
}());
|
|
|
|
</script>
|
|
|
|
</body>
|
|
|
|
</html> |