summaryrefslogtreecommitdiff
path: root/kvmd/web/js
diff options
context:
space:
mode:
authorDevaev Maxim <[email protected]>2018-07-31 23:04:31 +0300
committerDevaev Maxim <[email protected]>2018-07-31 23:16:09 +0300
commitd9dbddeb2fcda7121738d1378c9e83b78ec25928 (patch)
tree938c4a358c19df50a1e3c71979a13f07b10398cc /kvmd/web/js
parent3a748859ffd961552f272f751c7329e3021ac375 (diff)
some ui fixes
Diffstat (limited to 'kvmd/web/js')
-rw-r--r--kvmd/web/js/stream.js1
-rw-r--r--kvmd/web/js/ui.js13
2 files changed, 9 insertions, 5 deletions
diff --git a/kvmd/web/js/stream.js b/kvmd/web/js/stream.js
index 288762be..feb05d13 100644
--- a/kvmd/web/js/stream.js
+++ b/kvmd/web/js/stream.js
@@ -44,6 +44,7 @@ var stream = new function() {
el_stream_image.style.width = size.width + "px";
el_stream_image.style.height = size.height + "px";
el_stream_image.src = "/streamer/?action=stream&time=" + new Date().getTime();
+ ui.showWindow("stream-window");
}
});
};
diff --git a/kvmd/web/js/ui.js b/kvmd/web/js/ui.js
index c0b07198..06622895 100644
--- a/kvmd/web/js/ui.js
+++ b/kvmd/web/js/ui.js
@@ -58,11 +58,12 @@ var ui = new function() {
this.showWindow = function(id) {
var el_window = $(id);
- if (!__isWindowOnPage(el_window)) {
+ if (!__isWindowOnPage(el_window) || el_window.hasAttribute("data-centered")) {
var view = __getViewGeometry();
var rect = el_window.getBoundingClientRect();
el_window.style.top = Math.max($("ctl").clientHeight, Math.round((view.bottom - rect.height) / 2)) + "px";
el_window.style.left = Math.round((view.right - rect.width) / 2) + "px";
+ el_window.setAttribute("data-centered", "");
}
el_window.style.visibility = "visible";
__raiseWindow(el_window);
@@ -94,13 +95,13 @@ var ui = new function() {
__ctl_items.forEach(function(el_item) {
var el_menu = el_item.parentElement.querySelector(".ctl-dropdown-content");
- if (el_item === el_a && el_menu.style.display === "none") {
+ if (el_item === el_a && window.getComputedStyle(el_menu, null).visibility === "hidden") {
el_item.classList.add("ctl-item-selected");
- el_menu.style.display = "block";
+ el_menu.style.visibility = "visible";
all_hidden &= false;
} else {
el_item.classList.remove("ctl-item-selected");
- el_menu.style.display = "none";
+ el_menu.style.visibility = "hidden";
}
});
@@ -123,7 +124,7 @@ var ui = new function() {
__ctl_items.forEach(function(el_item) {
var el_menu = el_item.parentElement.querySelector(".ctl-dropdown-content");
el_item.classList.remove("ctl-item-selected");
- el_menu.style.display = "none";
+ el_menu.style.visibility = "hidden";
});
};
@@ -159,6 +160,7 @@ var ui = new function() {
}
function doMoving(event) {
+ el_window.removeAttribute("data-centered");
event = (event || window.event);
event.preventDefault();
x = prev_x - event.clientX;
@@ -174,6 +176,7 @@ var ui = new function() {
document.onmouseup = null;
}
+ el_window.setAttribute("data-centered", "");
el_grab.onmousedown = startMoving;
el_window.onclick = () => __raiseWindow(el_window);
};