Commit 5ccdf0ee authored by Tom Quirk's avatar Tom Quirk

Addressing reviewer feedback

- break up onPresentationMousemove for better readability
parent 9333bb66
...@@ -223,24 +223,31 @@ export default { ...@@ -223,24 +223,31 @@ export default {
y: clientY, y: clientY,
}; };
}, },
getDragDelta(clientX, clientY) {
return {
deltaX: this.lastDragPosition.x - clientX,
deltaY: this.lastDragPosition.y - clientY,
};
},
exceedsDragThreshold(clientX, clientY) {
const { deltaX, deltaY } = this.getDragDelta(clientX, clientY);
return Math.abs(deltaX) > CLICK_DRAG_BUFFER_PX || Math.abs(deltaY) > CLICK_DRAG_BUFFER_PX;
},
shouldDragDesign(clientX, clientY) {
return (
this.lastDragPosition &&
(this.isDraggingDesign || this.exceedsDragThreshold(clientX, clientY))
);
},
onPresentationMousemove({ clientX, clientY }) { onPresentationMousemove({ clientX, clientY }) {
const { presentationViewport } = this.$refs; const { presentationViewport } = this.$refs;
if (!this.lastDragPosition || !presentationViewport) return; if (!presentationViewport || !this.shouldDragDesign(clientX, clientY)) return;
const { scrollLeft, scrollTop } = presentationViewport;
const deltaX = this.lastDragPosition.x - clientX;
const deltaY = this.lastDragPosition.y - clientY;
// only respond to mousemove events after the
// mousemove's position exceeds the buffer amount
if (
!this.isDraggingDesign &&
Math.abs(deltaX) <= CLICK_DRAG_BUFFER_PX &&
Math.abs(deltaY) <= CLICK_DRAG_BUFFER_PX
)
return;
this.isDraggingDesign = true; this.isDraggingDesign = true;
const { scrollLeft, scrollTop } = presentationViewport;
const { deltaX, deltaY } = this.getDragDelta(clientX, clientY);
presentationViewport.scrollTo(scrollLeft + deltaX, scrollTop + deltaY); presentationViewport.scrollTo(scrollLeft + deltaX, scrollTop + deltaY);
this.lastDragPosition = { this.lastDragPosition = {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment