Branch: refs/heads/main
Home: https://github.com/WebKit/WebKit
Commit: 9e2aadd3a06e6cf5ef09873cf5c1d5ef2a848d79
https://github.com/WebKit/WebKit/commit/9e2aadd3a06e6cf5ef09873cf5c1d5ef2a848d79
Author: Dana Estra <[email protected]>
Date: 2024-05-09 (Thu, 09 May 2024)
Changed paths:
M
Source/WebCore/Modules/modern-media-controls/controls/macos-fullscreen-media-controls.js
M Source/WebCore/Modules/modern-media-controls/media/media-controller.js
M Source/WebCore/dom/Document.cpp
Log Message:
-----------
Fix event handling conflicts between webkit fullscreen controls and
fullscreen controls of youtube.com and vimeo.com
https://bugs.webkit.org/show_bug.cgi?id=273889
rdar://126728057
Reviewed by Jer Noble.
Currently, when on youtube.com and an element is in in-window or standard
fullscreen and we are displaying the default
WebKit media controls, pressing the spacebar to toggle playback does not work
because both our event handler and youtube's
Are being executed. When in fullscreen, the keyboard events are sent to the
HTML body, on which YouTube has a Keyup event
Listener that toggles playback if the key is a space. Because our media
controls script is loaded after youtube's, our event
Listeners have no chance of handling the event and stopping propagation.
To fix this, this change makes it so that when a keyboard event is fired while
a page is in fullscreen, the event is
first sent to the fullscreen element to be handled, which now has an event
listener attached to it for keydown and
Keyup events and stops propagation after handling the spacebar event.
There is also a problem on YouTube.com and Vimeo.com where the website toggles
playback when the user clicks or drags the
fullscreen bottom controls bar. To fix this, I attached a click event listener
to the controls bar. The event handler
Stops propagation. There is no need for the webpage's event handlers to be
executed at all if the user
Is clicking on our controls bar.
*
Source/WebCore/Modules/modern-media-controls/controls/macos-fullscreen-media-controls.js:
* Source/WebCore/Modules/modern-media-controls/media/media-controller.js:
(MediaController):
(MediaController.prototype.handleEvent):
* Source/WebCore/dom/Document.cpp:
(WebCore::eventTargetElementForDocument):
Canonical link: https://commits.webkit.org/278573@main
To unsubscribe from these emails, change your notification settings at
https://github.com/WebKit/WebKit/settings/notifications
_______________________________________________
webkit-changes mailing list
[email protected]
https://lists.webkit.org/mailman/listinfo/webkit-changes