mirror of
https://github.com/pierre42100/ComunicWeb
synced 2024-11-29 15:26:27 +00:00
Made the window draggable
This commit is contained in:
parent
f1399d2aef
commit
ade339bf1b
@ -36,7 +36,7 @@ class CallWindow extends CustomEvents {
|
|||||||
|
|
||||||
|
|
||||||
// Construct head
|
// Construct head
|
||||||
const windowHead = createElem2({
|
this.windowHead = createElem2({
|
||||||
appendTo: this.rootEl,
|
appendTo: this.rootEl,
|
||||||
type: "div",
|
type: "div",
|
||||||
class: "head",
|
class: "head",
|
||||||
@ -47,12 +47,82 @@ class CallWindow extends CustomEvents {
|
|||||||
|
|
||||||
// Close button
|
// Close button
|
||||||
this.closeButton = createElem2({
|
this.closeButton = createElem2({
|
||||||
appendTo: windowHead.querySelector(".pull-right"),
|
appendTo: this.windowHead.querySelector(".pull-right"),
|
||||||
type: "a",
|
type: "a",
|
||||||
innerHTML: "<i class='fa fa-times'></i>",
|
innerHTML: "<i class='fa fa-times'></i>",
|
||||||
onclick: () => this.Close()
|
onclick: () => this.Close()
|
||||||
})
|
})
|
||||||
|
|
||||||
|
this.makeWindowDraggable()
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make the call window draggable
|
||||||
|
*/
|
||||||
|
makeWindowDraggable() {
|
||||||
|
|
||||||
|
const checkWindowMinPosition = () => {
|
||||||
|
|
||||||
|
if(window.innerHeight < this.rootEl.style.top.replace("px", ""))
|
||||||
|
this.rootEl.style.top = "0px";
|
||||||
|
|
||||||
|
if(window.innerWidth < this.rootEl.style.left.replace("px", ""))
|
||||||
|
this.rootEl.style.left = "0px";
|
||||||
|
|
||||||
|
if(this.rootEl.style.left.replace("px", "") < 0)
|
||||||
|
this.rootEl.style.left = "0px";
|
||||||
|
|
||||||
|
if(this.rootEl.style.top.replace("px", "") < 49)
|
||||||
|
this.rootEl.style.top = "50px";
|
||||||
|
}
|
||||||
|
|
||||||
|
//Enable dragging
|
||||||
|
{
|
||||||
|
var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0;
|
||||||
|
|
||||||
|
this.windowHead.addEventListener("mousedown", (e) => {
|
||||||
|
e = e || window.event;
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
//Check if the window is currently in full screen mode
|
||||||
|
if(IsFullScreen())
|
||||||
|
return;
|
||||||
|
|
||||||
|
//get the mouse cursor position at startup
|
||||||
|
pos3 = e.clientX;
|
||||||
|
pos4 = e.clientY;
|
||||||
|
document.onmouseup = closeDragElement;
|
||||||
|
document.onmousemove = elementDrag;
|
||||||
|
});
|
||||||
|
|
||||||
|
const elementDrag = (e) => {
|
||||||
|
e = e || window.event;
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
//Calculate new cursor position
|
||||||
|
pos1 = pos3 - e.clientX;
|
||||||
|
pos2 = pos4 - e.clientY;
|
||||||
|
pos3 = e.clientX;
|
||||||
|
pos4 = e.clientY;
|
||||||
|
|
||||||
|
//Set element new position
|
||||||
|
this.rootEl.style.top = (this.rootEl.offsetTop - pos2) + "px";
|
||||||
|
this.rootEl.style.left = (this.rootEl.offsetLeft - pos1) + "px";
|
||||||
|
|
||||||
|
checkWindowMinPosition();
|
||||||
|
}
|
||||||
|
|
||||||
|
const closeDragElement = () => {
|
||||||
|
|
||||||
|
//Stop moving when mouse button is released
|
||||||
|
document.onmouseup = null;
|
||||||
|
document.onmousemove = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
window.addEventListener("resize", () => {
|
||||||
|
checkWindowMinPosition();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user