Bug 205446

Summary: Cross-frame pointer events lost when preventing default
Product: WebKit Reporter: Ashley Gullen <ashley>
Component: UI EventsAssignee: Nobody <webkit-unassigned>
Status: NEW    
Severity: Normal CC: graouts, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: Safari 13   
Hardware: Unspecified   
OS: Unspecified   

Ashley Gullen
Reported 2019-12-19 05:36:06 PST
Steps to reproduce: 1. Visit https://www.scirra.com/labs/bugs/pointer-frames/frame.html 2. Place a pointer down (using mouse on desktop or touch on mobile) inside the frame on the left, drag to the right outside the frame, and release 3. Observe the events printed in the frame The frame should see either a pointerup event when releasing, or a pointercancel event when it loses the pointer. Both Firefox and EdgeHTML fire a pointerup event (but Chrome has the same bug). Instead, the frame receives neither a pointerup or pointercancel event. In more complex web apps, this causes code that tracks pointers to get permanently stuck, since it will never see an event indicating the pointer ended. This only happens when preventDefault() is called on the pointerdown event. However sometimes this has to be done for unrelated reasons. It should not cause a framed page to lose pointer events.
Attachments
Ashley Gullen
Comment 1 2019-12-19 05:36:30 PST
Note this also reproduces in Safari TP 97.
Radar WebKit Bug Importer
Comment 2 2019-12-20 10:41:30 PST
Note You need to log in before you can comment on or make changes to this bug.