- 
                Notifications
    You must be signed in to change notification settings 
- Fork 1.3k
Open
Description
Description/Steps to reproduce
- Use a Pen tablet. Any tablet that reports pen pressure and will trigger PointerEvents.
- Make sure the Pen tablet/digitiser reports Pen Pressure. For Wacom digitisers, make sure that:
- Start -> Wacom Tablet Properties -> "Mapping" Tab -> "Use Windows Ink" is checked.
 
- Visit this Sketch.
- Try to draw with the pen tablet.
Link to reproduction test-case
Expected result
- Draws freehand drawings
Actual result
- Draws nothing
Additional information
- Only applicable on Windows 10 + Firefox 59.
- Firefox 59 on OSX doesn't have this issue.
- Firefox 58 does not have this issue since it doesn't implement the PointerEvents API.
- Turning off Pen Pressure (Windows Ink on Wacoms) fixes this since it causes the device to report as a e.pointerType = 'mouse'instead of a'pen'.- However Firefox 59 logs wrong e.clientX/e.clientYvalues if a pen is used that doesn't identify itself as apointerType = 'pen'.
- This is a Firefox 59 + Windows 10 bug I've reported here that has nothing to do with PaperJS.
 
- However Firefox 59 logs wrong 
Workaround
I do this as a temp. workaround.
;(() => {
  const isFirefox59 = () => window.navigator.userAgent.includes('Firefox/59.0')
  const isWindows64 = () => window.navigator.platform.includes('Win64')
  if (isFirefox59() && isWindows64()) {
    console.warn('Detected Firefox 59+ on Windows 10. Some PointerEvents are remapped to MouseEvents. For more info see: https://github.com/paperjs/paper.js/issues/1463')
    window.addEventListener('pointerdown', e => {
      e.target.dispatchEvent(new MouseEvent('mousedown', e))
      e.stopPropagation()
      e.preventDefault()
    })
    window.addEventListener('pointermove', e => {
      e.target.dispatchEvent(new MouseEvent('mousemove', e))
      e.stopPropagation()
      e.preventDefault()
    })
    window.addEventListener('pointerup', e => {
      e.target.dispatchEvent(new MouseEvent('mouseup', e))
      e.stopPropagation()
      e.preventDefault()
    })
  }
})()