react-swipeable icon indicating copy to clipboard operation
react-swipeable copied to clipboard

`preventScrollOnSwipe` does not work while focused on input

Open willashley23 opened this issue 1 year ago • 0 comments

Describe the bug When an input field is focused on ios Safari, preventScroll flag does not work as intended, IE, the page still scrolls.

Steps or Sandbox to reproduce This has to be reproduced inside an ios simulator like xCode or on your mobile device directly

  • Wrap a div with scroll handlers:
const handlers = useSwipeable({
    onSwiping: ({ deltaY }) => {
      if (deltaY > 100) {
        document.getElementById('AddModal').close();
      }
    },
    delta: { left: 100, right: 100, down: 100 },
    preventScrollOnSwipe: true,
  });
  • Place an input inside of this container
  • Place a ref on this input
  • when the component mounts, focus the input:
  useEffect(() => {
    inputRef.current.focus();
  }, []);

-While focused on the input, attempt to scroll down

  • observe the bug: the page will scroll when it shouldnt. You can verify this by removing focus from the input and then attempting to swipe again, and it will trigger the handler and prevent scrolling

Expected behavior It should prevent scrolling behavior if I swipe while focused on an input

** Device/Browser ** Safari iOS 17.0

willashley23 avatar Oct 22 '23 21:10 willashley23