39 lines
1.2 KiB
JavaScript
39 lines
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});
|
||
|
});
|