reconnect window
This commit is contained in:
parent
ec081018c2
commit
aff6d66622
@ -1,13 +1,36 @@
|
|||||||
@import url(https://fonts.googleapis.com/css?family=Roboto:100,300,600);
|
html,
|
||||||
|
body,
|
||||||
|
.page {
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
body {
|
body {
|
||||||
background: #434d5a;
|
background: #434d5a;
|
||||||
font-family: "Roboto";
|
font-family: "Roboto";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.page {
|
||||||
|
top: 0px;
|
||||||
|
left: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.window {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
|
background: rgba(0, 0, 0, 1);
|
||||||
|
padding: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
h1 {
|
h1 {
|
||||||
color: #7e8c9f;
|
color: #7e8c9f;
|
||||||
padding: 0;
|
font-size: 50px;
|
||||||
margin: 0;
|
margin: 2em 0px;
|
||||||
|
padding: 0px;
|
||||||
-webkit-user-select: none;
|
-webkit-user-select: none;
|
||||||
-moz-user-select: none;
|
-moz-user-select: none;
|
||||||
-ms-user-select: none;
|
-ms-user-select: none;
|
||||||
@ -16,6 +39,15 @@ h1 {
|
|||||||
text-align: center;
|
text-align: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 #enc {
|
||||||
|
font-size: 80px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
#picker {
|
#picker {
|
||||||
display: flex;
|
display: flex;
|
||||||
justify-content: space-around;
|
justify-content: space-around;
|
||||||
@ -28,3 +60,21 @@ h1 {
|
|||||||
align-content: center;
|
align-content: center;
|
||||||
justify-content: space-around;
|
justify-content: space-around;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#reconnect {
|
||||||
|
position: fixed;
|
||||||
|
visibility: hidden;
|
||||||
|
background: rgba(0, 0, 0, .5);
|
||||||
|
z-index: 2;
|
||||||
|
display: flex;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
#reconnect .window div {
|
||||||
|
color: rgb(165, 165, 165);
|
||||||
|
font-family: monospace;
|
||||||
|
font-size: 2em;
|
||||||
|
font-weight: bold;
|
||||||
|
margin-bottom: .5em;
|
||||||
|
}
|
@ -16,10 +16,19 @@
|
|||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
|
<div id="reconnect" class="page">
|
||||||
|
<div class="window">
|
||||||
|
<div>Disconnected from server</div>
|
||||||
|
<button type="button" onclick="reconnect(this)">Reconnect</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="page">
|
||||||
<div>
|
<div>
|
||||||
<h1> Tropicananass Leds </h1>
|
<h1> Tropicananass Leds </h1>
|
||||||
</div>
|
</div>
|
||||||
<div id="picker"></div>
|
<div id="picker"></div>
|
||||||
|
</div>
|
||||||
</body>
|
</body>
|
||||||
|
|
||||||
</html>
|
</html>
|
@ -1,26 +1,32 @@
|
|||||||
let socket = new WebSocket("ws://192.168.1.130:8080");
|
let socket;
|
||||||
|
|
||||||
|
function reconnect() {
|
||||||
|
socket = new WebSocket("ws://192.168.1.130:8080");
|
||||||
|
|
||||||
socket.onopen = function(e) {
|
socket.onopen = function(e) {
|
||||||
alert("[open] Connection established");
|
console.log("[open] ws: Connection established");
|
||||||
|
document.getElementById("reconnect").style.visibility = 'hidden';
|
||||||
};
|
};
|
||||||
|
|
||||||
socket.onmessage = function(event) {
|
socket.onmessage = function(event) {
|
||||||
alert(`[message] Data received from server: ${event.data}`);
|
console.log(`[message] ws: Data received from server: ${event.data}`);
|
||||||
};
|
};
|
||||||
|
|
||||||
socket.onclose = function(event) {
|
socket.onclose = function(event) {
|
||||||
if (event.wasClean) {
|
if (event.wasClean) {
|
||||||
alert(`[close] Connection closed cleanly, code=${event.code} reason=${event.reason}`);
|
console.log(`[close] ws: Connection closed cleanly, code=${event.code} reason=${event.reason}`);
|
||||||
} else {
|
} else {
|
||||||
// e.g. server process killed or network down
|
// e.g. server process killed or network down
|
||||||
// event.code is usually 1006 in this case
|
// event.code is usually 1006 in this case
|
||||||
alert('[close] Connection died');
|
console.log('[close] ws: Connection died');
|
||||||
|
document.getElementById("reconnect").style.visibility = 'visible';
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
socket.onerror = function(error) {
|
socket.onerror = function(error) {
|
||||||
alert(`[error] ${error.message}`);
|
console.log(`[error] ws: ${error.message}`);
|
||||||
};
|
};
|
||||||
|
}
|
||||||
|
|
||||||
var colorPicker = new iro.ColorPicker('#picker', {
|
var colorPicker = new iro.ColorPicker('#picker', {
|
||||||
colors: [
|
colors: [
|
||||||
@ -33,7 +39,15 @@ var colorPicker = new iro.ColorPicker('#picker', {
|
|||||||
}, {
|
}, {
|
||||||
component: iro.ui.Box,
|
component: iro.ui.Box,
|
||||||
options: {}
|
options: {}
|
||||||
}],
|
},
|
||||||
|
{
|
||||||
|
component: iro.ui.Slider,
|
||||||
|
options: {
|
||||||
|
// can also be 'saturation', 'value', 'red', 'green', 'blue', 'alpha' or 'kelvin'
|
||||||
|
sliderType: 'value'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
display: "flex",
|
display: "flex",
|
||||||
handleRadius: 14,
|
handleRadius: 14,
|
||||||
});
|
});
|
||||||
@ -44,6 +58,5 @@ function colorChangeCallback(color) {
|
|||||||
socket.send("{" + color.index + "," + color.hsl.h + "," + color.hsl.s + "," + color.hsl.l + "}");
|
socket.send("{" + color.index + "," + color.hsl.h + "," + color.hsl.s + "," + color.hsl.l + "}");
|
||||||
}
|
}
|
||||||
|
|
||||||
// start listening to the color change event
|
reconnect();
|
||||||
// colorChangeCallback will be called whenever the color changes
|
|
||||||
colorPicker.on("color:change", colorChangeCallback);
|
colorPicker.on("color:change", colorChangeCallback);
|
Loading…
Reference in New Issue
Block a user