1
0
mirror of https://github.com/falk-werner/webfuse-provider synced 2024-10-27 20:44:10 +00:00
falk-werner_webfuse-provider/example/daemon/www/js/connection_view.js

41 lines
1.2 KiB
JavaScript
Raw Normal View History

2019-02-20 19:23:56 +00:00
export class ConnectionView {
2019-02-21 23:35:59 +00:00
constructor(client) {
this.connection = client;
2019-01-28 21:08:37 +00:00
2019-02-13 20:09:43 +00:00
this.element = document.createElement("div");
2019-01-28 21:08:37 +00:00
2019-02-13 20:09:43 +00:00
let urlLabel = document.createElement("span");
urlLabel.textContent = "URL:";
2019-01-28 21:08:37 +00:00
this.element.appendChild(urlLabel);
2019-02-13 20:09:43 +00:00
this.urlTextbox = document.createElement("input");
this.urlTextbox.type = "text";
2019-01-28 21:08:37 +00:00
this.urlTextbox.value = window.location.href.replace(/^http/, "ws");
this.element.appendChild(this.urlTextbox);
2019-02-13 20:09:43 +00:00
this.connectButton = document.createElement("input");
this.connectButton.type = "button";
this.connectButton.value = "connect";
this.connectButton.addEventListener("click", () => { this.onConnectButtonClicked(); });
2019-01-28 21:08:37 +00:00
this.element.appendChild(this.connectButton);
}
onConnectButtonClicked() {
if (!this.connection.isConnected) {
let url = this.urlTextbox.value;
this.connection.connectTo(url);
}
else {
2019-02-21 23:35:59 +00:00
this.connection.disconnect();
2019-01-28 21:08:37 +00:00
}
}
onConnectionOpened() {
2019-02-13 20:09:43 +00:00
this.connectButton.value = "disconnect";
2019-01-28 21:08:37 +00:00
}
onConnectionClosed() {
2019-02-13 20:09:43 +00:00
this.connectButton.value = "connect";
2019-01-28 21:08:37 +00:00
}
}