mirror of
https://github.com/wailsapp/wails.git
synced 2025-05-02 03:51:18 +08:00
229 lines
7.3 KiB
HTML
229 lines
7.3 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: 14em;
|
|
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);
|
|
}
|
|
};
|
|
|
|
// Adds a script to the Dom.
|
|
// Removes it if second parameter is true.
|
|
function addScript(script, remove) {
|
|
var s = document.createElement("script");
|
|
s.textContent = script;
|
|
document.head.appendChild(s);
|
|
|
|
// Remove internal messages from the DOM
|
|
if (remove) {
|
|
s.parentNode.removeChild(s);
|
|
}
|
|
}
|
|
|
|
// Adapted from webview - thanks zserge!
|
|
function injectCSS(css) {
|
|
var elem = document.createElement("style");
|
|
elem.setAttribute("type", "text/css");
|
|
if (elem.styleSheet) {
|
|
elem.styleSheet.cssText = css;
|
|
} else {
|
|
elem.appendChild(document.createTextNode(css));
|
|
}
|
|
var head = document.head || document.getElementsByTagName("head")[0];
|
|
head.appendChild(elem);
|
|
}
|
|
|
|
function handleConnect() {
|
|
log("Connected to backend");
|
|
hideReconnectOverlay();
|
|
clearInterval(connectTimer);
|
|
websocket.onclose = handleDisconnect;
|
|
websocket.onmessage = handleMessage;
|
|
connectionState = "connected";
|
|
// websocket.onerror = function () { }
|
|
}
|
|
|
|
function handleDisconnect() {
|
|
log("Disconnected from backend");
|
|
websocket = null;
|
|
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 log(message) {
|
|
console.log(
|
|
"%c wails headless %c " + message + " ",
|
|
"background: #aa0000; color: #fff; border-radius: 3px 0px 0px 3px; padding: 1px; font-size: 0.7rem",
|
|
"background: #009900; color: #fff; border-radius: 0px 3px 3px 0px; padding: 1px; font-size: 0.7rem"
|
|
);
|
|
}
|
|
|
|
function handleMessage(message) {
|
|
// As a bridge we ignore js and css injections
|
|
debugger;
|
|
|
|
switch (message.data[0]) {
|
|
// Wails library - inject!
|
|
case "w":
|
|
addScript(message.data.slice(1));
|
|
|
|
// Now wails runtime is loaded, wails for the ready event
|
|
// and callback to the main app
|
|
window.wails.events.on("wails:loaded", function () {
|
|
log("Wails Ready");
|
|
});
|
|
log("Loaded Wails Runtime");
|
|
break;
|
|
|
|
// Notification
|
|
case "n":
|
|
log("Notification: " + message.data.slice(1))
|
|
addScript(message.data.slice(1), true);
|
|
break;
|
|
|
|
// Binding
|
|
case "b":
|
|
var binding = message.data.slice(1)
|
|
//log("Binding: " + binding)
|
|
window.wails._.newBinding(binding);
|
|
break;
|
|
|
|
// Call back
|
|
case "c":
|
|
var callbackData = message.data.slice(1);
|
|
log("Callback = " + callbackData);
|
|
window.wails._.callback(callbackData);
|
|
break;
|
|
|
|
// CSS
|
|
case "s":
|
|
addScript(message.data.slice(1), true);
|
|
break;
|
|
|
|
// JS
|
|
case "j":
|
|
addScript(message.data.slice(1));
|
|
break;
|
|
|
|
// HTML
|
|
case "h":
|
|
addScript(message.data.slice(1), true);
|
|
break;
|
|
|
|
default:
|
|
log("Ignored message: " + message.data.slice(0, 100))
|
|
}
|
|
}
|
|
|
|
connect();
|
|
|
|
}());
|
|
|
|
</script>
|
|
|
|
</body>
|
|
|
|
</html> |