GDBrowser/assets/dragscroll.js
2019-10-24 19:27:09 -07:00

39 lines
No EOL
1.2 KiB
JavaScript

function somethingSelected() {
return typeof window.getSelection == 'function' && window.getSelection().toString() != "";
}
const remover = / |\n|\t/g;
$('.dragscroll').each(function(_, el) {
// Can't directly .mousemove() because need reference to el
let mouseDown = false;
let previouslyMouseDown = mouseDown;
el.addEventListener('mousedown', function() {
mouseDown = true;
});
el.addEventListener('mouseup', function(e) {
mouseDown = false;
})
el.addEventListener('mouseleave', function() {mouseDown=false});
el.addEventListener('mousemove', function(e) {
if (!mouseDown) {
if (previouslyMouseDown) {
el.style.removeProperty('user-select');
el.style.removeProperty('-webkit-user-select');
previouslyMouseDown = false;
}
return;
}
if (somethingSelected())
return;
if (!previouslyMouseDown) {
for (let el of e.target.childNodes) {
if (el.nodeType === Node.TEXT_NODE && el.textContent.replace(remover, '').length)
return;
}
el.style['user-select'] = 'none';
el.style['-webkit-user-select'] = 'none';
previouslyMouseDown = true;
}
el.scrollLeft -= e.movementX;
el.scrollTop -= e.movementY;
}, {passive: true});
});