diff options
author | Hugo Hörnquist <hugo@lysator.liu.se> | 2021-12-12 23:29:41 +0100 |
---|---|---|
committer | Hugo Hörnquist <hugo@lysator.liu.se> | 2021-12-12 23:30:34 +0100 |
commit | a5c4962f1b3c9b2e4c23a7e3912af2dfcb4f0507 (patch) | |
tree | 9223166e6522b20f3e77474066729d4c3fd0d304 /static/dragable.ts | |
parent | Add TODO about broken color files. (diff) | |
download | calp-a5c4962f1b3c9b2e4c23a7e3912af2dfcb4f0507.tar.gz calp-a5c4962f1b3c9b2e4c23a7e3912af2dfcb4f0507.tar.xz |
Merge draggable into popup-element.
Diffstat (limited to '')
-rw-r--r-- | static/dragable.ts | 46 |
1 files changed, 0 insertions, 46 deletions
diff --git a/static/dragable.ts b/static/dragable.ts deleted file mode 100644 index b32bb608..00000000 --- a/static/dragable.ts +++ /dev/null @@ -1,46 +0,0 @@ -export { bind_popup_control } - -/* - Apply to a given component to make it draggable. - Drag area (usually a title bar) should be be the only argument. - It is REQUIRED that the object which should be moved have the class - 'popup-container'; -*/ - - -/* - Given the navbar of a popup, make it dragable. - */ -function bind_popup_control(nav: HTMLElement) { - - // if (!nav.closest('popup-element')) { - // console.log(nav); - // throw TypeError('not a popup container'); - // } - - nav.addEventListener('mousedown', function(e) { - /* Ignore mousedown on children */ - if (e.target != nav) return; - nav.style.cursor = "grabbing"; - nav.dataset.grabbed = "true"; - nav.dataset.grabPoint = e.clientX + ";" + e.clientY; - // let popup = nav.closest(".popup-container"); - let popup = nav.closest("popup-element") as HTMLElement; - nav.dataset.startPoint = popup.offsetLeft + ";" + popup.offsetTop; - }) - window.addEventListener('mousemove', function(e) { - if (nav.dataset.grabbed) { - let [x, y] = nav.dataset.grabPoint!.split(";").map(Number); - let [startX, startY] = nav.dataset.startPoint!.split(";").map(Number); - // let popup = nav.closest(".popup-container"); - let popup = nav.closest("popup-element") as HTMLElement; - - popup.style.left = startX + (e.clientX - x) + "px"; - popup.style.top = startY + (e.clientY - y) + "px"; - } - }); - window.addEventListener('mouseup', function() { - nav.dataset.grabbed = ""; - nav.style.cursor = ""; - }); -} |