Changed map interaction to ignore events not on the canvas

This removes the need for calling prevent interaction all over the code also allowed pointer events to go through the empty parts of the dice tray
This commit is contained in:
Mitchell McCaffrey 2020-05-27 15:26:42 +10:00
parent 7f0b4e32af
commit 0d37f8c6e3
6 changed files with 11 additions and 32 deletions

View File

@ -18,6 +18,7 @@ function MapDice() {
bottom: 0, bottom: 0,
flexDirection: "column", flexDirection: "column",
alignItems: "flex-start", alignItems: "flex-start",
pointerEvents: "none",
}} }}
ml={1} ml={1}
> >
@ -29,6 +30,7 @@ function MapDice() {
display: "block", display: "block",
backgroundColor: "overlay", backgroundColor: "overlay",
borderRadius: "50%", borderRadius: "50%",
pointerEvents: "all",
}} }}
m={2} m={2}
> >

View File

@ -75,6 +75,7 @@ function MapInteraction({ map, children, controls, selectedToolId }) {
const pinchPreviousDistanceRef = useRef(); const pinchPreviousDistanceRef = useRef();
const pinchPreviousOriginRef = useRef(); const pinchPreviousOriginRef = useRef();
const isDraggingCanvas = useRef(false);
const bind = useGesture({ const bind = useGesture({
onWheel: ({ delta }) => { onWheel: ({ delta }) => {
@ -120,8 +121,12 @@ function MapInteraction({ map, children, controls, selectedToolId }) {
pinchPreviousDistanceRef.current = distance; pinchPreviousDistanceRef.current = distance;
pinchPreviousOriginRef.current = { x: originX, y: originY }; pinchPreviousOriginRef.current = { x: originX, y: originY };
}, },
onDragStart: ({ event }) => {
isDraggingCanvas.current =
event.target === mapLayerRef.current.getCanvas()._canvas;
},
onDrag: ({ delta, xy, first, last, pinching }) => { onDrag: ({ delta, xy, first, last, pinching }) => {
if (preventMapInteraction || pinching) { if (preventMapInteraction || pinching || !isDraggingCanvas.current) {
return; return;
} }

View File

@ -1,11 +1,7 @@
import React, { useEffect, useState, useContext } from "react"; import React, { useEffect, useState } from "react";
import Modal from "react-modal"; import Modal from "react-modal";
import { useThemeUI } from "theme-ui"; import { useThemeUI } from "theme-ui";
import MapInteractionContext from "../../contexts/MapInteractionContext";
import usePrevious from "../../helpers/usePrevious";
function MapMenu({ function MapMenu({
isOpen, isOpen,
onRequestClose, onRequestClose,
@ -24,17 +20,6 @@ function MapMenu({
// callback // callback
const [modalContentNode, setModalContentNode] = useState(null); const [modalContentNode, setModalContentNode] = useState(null);
// Toggle map interaction when menu is opened
const wasOpen = usePrevious(isOpen);
const { setPreventMapInteraction } = useContext(MapInteractionContext);
useEffect(() => {
if (isOpen && !wasOpen) {
setPreventMapInteraction(true);
} else if (wasOpen && !isOpen) {
setPreventMapInteraction(false);
}
}, [isOpen, setPreventMapInteraction, wasOpen]);
useEffect(() => { useEffect(() => {
// Close modal if interacting with any other element // Close modal if interacting with any other element
function handlePointerDown(event) { function handlePointerDown(event) {

View File

@ -5,7 +5,6 @@ import SelectMapModal from "../../modals/SelectMapModal";
import SelectMapIcon from "../../icons/SelectMapIcon"; import SelectMapIcon from "../../icons/SelectMapIcon";
import MapDataContext from "../../contexts/MapDataContext"; import MapDataContext from "../../contexts/MapDataContext";
import MapInteractionContext from "../../contexts/MapInteractionContext";
function SelectMapButton({ function SelectMapButton({
onMapChange, onMapChange,
@ -15,16 +14,13 @@ function SelectMapButton({
}) { }) {
const [isModalOpen, setIsModalOpen] = useState(false); const [isModalOpen, setIsModalOpen] = useState(false);
const { setPreventMapInteraction } = useContext(MapInteractionContext);
const { updateMapState } = useContext(MapDataContext); const { updateMapState } = useContext(MapDataContext);
function openModal() { function openModal() {
currentMapState && updateMapState(currentMapState.mapId, currentMapState); currentMapState && updateMapState(currentMapState.mapId, currentMapState);
setIsModalOpen(true); setIsModalOpen(true);
setPreventMapInteraction(true);
} }
function closeModal() { function closeModal() {
setIsModalOpen(false); setIsModalOpen(false);
setPreventMapInteraction(false);
} }
function handleDone() { function handleDone() {

View File

@ -17,7 +17,6 @@ import LoadingOverlay from "../../LoadingOverlay";
import DiceTray from "../../../dice/diceTray/DiceTray"; import DiceTray from "../../../dice/diceTray/DiceTray";
import MapInteractionContext from "../../../contexts/MapInteractionContext";
import DiceLoadingContext from "../../../contexts/DiceLoadingContext"; import DiceLoadingContext from "../../../contexts/DiceLoadingContext";
function DiceTrayOverlay({ isOpen }) { function DiceTrayOverlay({ isOpen }) {
@ -212,8 +211,6 @@ function DiceTrayOverlay({ isOpen }) {
assetLoadFinish(); assetLoadFinish();
} }
const { setPreventMapInteraction } = useContext(MapInteractionContext);
return ( return (
<Box <Box
sx={{ sx={{
@ -227,6 +224,7 @@ function DiceTrayOverlay({ isOpen }) {
display: isOpen ? "block" : "none", display: isOpen ? "block" : "none",
position: "relative", position: "relative",
overflow: "hidden", overflow: "hidden",
pointerEvents: "all",
}} }}
bg="background" bg="background"
> >
@ -234,11 +232,9 @@ function DiceTrayOverlay({ isOpen }) {
onSceneMount={handleSceneMount} onSceneMount={handleSceneMount}
onPointerDown={() => { onPointerDown={() => {
sceneInteractionRef.current = true; sceneInteractionRef.current = true;
setPreventMapInteraction(true);
}} }}
onPointerUp={() => { onPointerUp={() => {
sceneInteractionRef.current = false; sceneInteractionRef.current = false;
setPreventMapInteraction(false);
}} }}
/> />
<DiceControls <DiceControls

View File

@ -1,22 +1,17 @@
import React, { useState, useContext } from "react"; import React, { useState } from "react";
import { IconButton } from "theme-ui"; import { IconButton } from "theme-ui";
import SelectDiceIcon from "../../../icons/SelectDiceIcon"; import SelectDiceIcon from "../../../icons/SelectDiceIcon";
import SelectDiceModal from "../../../modals/SelectDiceModal"; import SelectDiceModal from "../../../modals/SelectDiceModal";
import MapInteractionContext from "../../../contexts/MapInteractionContext";
function SelectDiceButton({ onDiceChange, currentDice }) { function SelectDiceButton({ onDiceChange, currentDice }) {
const [isModalOpen, setIsModalOpen] = useState(false); const [isModalOpen, setIsModalOpen] = useState(false);
const { setPreventMapInteraction } = useContext(MapInteractionContext);
function openModal() { function openModal() {
setIsModalOpen(true); setIsModalOpen(true);
setPreventMapInteraction(true);
} }
function closeModal() { function closeModal() {
setIsModalOpen(false); setIsModalOpen(false);
setPreventMapInteraction(false);
} }
function handleDone(dice) { function handleDone(dice) {