-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsetupResize.js
33 lines (26 loc) · 980 Bytes
/
setupResize.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
export function setupResize(state, sidebar) {
sidebar.addEventListener("pointerdown", resizePanel);
function resizePanel(e) {
if (!e.target.classList.contains("resize-bar")) return;
e.preventDefault();
window.getSelection
? window.getSelection().removeAllRanges()
: document.selection.empty();
state.resizing = true;
const elToResize = document.getElementById(e.target.dataset.resize);
const resizeDir = e.target.dataset.resizedir;
const moveListener = (e) => {
if (resizeDir === "ns") {
elToResize.style.height = `${elToResize.offsetHeight - e.movementY}px`;
} else if (resizeDir === "ew") {
elToResize.style.width = `${e.clientX}px`;
}
};
const stopResize = (e) => {
window.removeEventListener("pointermove", moveListener);
state.resizing = false;
};
window.addEventListener("pointermove", moveListener);
window.addEventListener("pointerup", stopResize);
}
}