Make snap events bubble when fired at the document.
The CSS working group came to a resolution[1] that snap events should
bubble when targeted at the document.
This aligns with the behavior of scroll and scrollend events.
[1]https://github.com/w3c/csswg-drafts/issues/10173
Bug: 40286359, 40273052
Change-Id: Ie977a39df04c5ee0bd7f62319119603a59ed7c22
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5513923
Reviewed-by: Steve Kobes <skobes@chromium.org>
Commit-Queue: David Awogbemila <awogbemila@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1296898}
diff --git a/css/css-scroll-snap-2/resources/common.js b/css/css-scroll-snap-2/resources/common.js
index 8dce294..d95b605 100644
--- a/css/css-scroll-snap-2/resources/common.js
+++ b/css/css-scroll-snap-2/resources/common.js
@@ -9,7 +9,8 @@
}
function assertSnapEvent(evt, expected_ids) {
- assert_equals(evt.bubbles, false, "snap events don't bubble");
+ assert_equals(evt.bubbles, evt.target == document,
+ "snap events don't bubble except when fired at the document");
assert_false(evt.cancelable, "snap events are not cancelable.");
assert_equals(evt.snapTargetBlock, expected_ids.block,
"snap event supplied expected target in block axis");
diff --git a/css/css-scroll-snap-2/snapevents-at-document-bubble-to-window.html b/css/css-scroll-snap-2/snapevents-at-document-bubble-to-window.html
new file mode 100644
index 0000000..e50be0b
--- /dev/null
+++ b/css/css-scroll-snap-2/snapevents-at-document-bubble-to-window.html
@@ -0,0 +1,96 @@
+<!DOCTYPE html>
+<html>
+
+<head>
+ <meta charset="utf-8">
+ <title> CSS Scroll Snap 2 Test: snapchanged event on the document bubbles</title>
+ <link rel="help" href="https://drafts.csswg.org/css-scroll-snap-2/#snap-events">
+ <script src="/resources/testharness.js"></script>
+ <script src="/resources/testharnessreport.js"></script>
+ <script src="/css/css-scroll-snap-2/resources/common.js"></script>
+ <script src="/dom/events/scrolling/scroll_support.js"></script>
+</head>
+
+<body>
+ <style>
+ :root {
+ margin: 0;
+ padding: 0;
+ scroll-snap-type: y mandatory;
+ }
+
+ div {
+ position: absolute;
+ margin: 0px;
+ }
+
+ #spacer {
+ width: 200vw;
+ height: 200vh;
+ }
+
+ .snap_point {
+ width: 40vw;
+ height: 40vh;
+ scroll-snap-align: start;
+ }
+
+ #snap_point_1 {
+ left: 0px;
+ top: 0px;
+ background-color: red;
+ }
+
+ #snap_point_2 {
+ top: 40vh;
+ left: 40vw;
+ background-color: orange;
+ }
+
+ #snap_point_3 {
+ left: 80vw;
+ top: 80vh;
+ background-color: blue;
+ }
+ </style>
+ <div id="spacer"></div>
+ <div id="snap_point_1" class="snap_point"></div>
+ <div id="snap_point_2" class="snap_point"></div>
+ <div id="snap_point_3" class="snap_point"></div>
+
+ <script>
+
+ promise_test(async(t) => {
+ await waitForCompositorCommit();
+
+ let snapchanging_promise = waitForSnapEvent(window, "snapchanging");
+ let snapchanged_promise = waitForSnapEvent(window, "snapchanged");
+ document.scrollingElement.scrollTo(0, snap_point_2.offsetTop);
+ let snapchanging_evt = await snapchanging_promise;
+ let snapchanged_evt = await snapchanged_promise;
+
+ assertSnapEvent(snapchanging_evt, { inline: null, block: snap_point_2 });
+ assertSnapEvent(snapchanged_evt, { inline: null, block: snap_point_2 });
+ }, "snapchanged bubbles when fired at the document (addEventListener).");
+
+ promise_test(async(t) => {
+ await waitForScrollReset(t, document.scrollingElement);
+ await waitForCompositorCommit();
+
+ let snapchanging_promise = waitForSnapEvent(window, "snapchanging",
+ /*scroll_happens=*/true,
+ /*use_onsnap_member=*/true);
+ let snapchanged_promise = waitForSnapEvent(window, "snapchanged",
+ /*scroll_happens=*/true,
+ /*use_onsnap_member=*/true);
+ document.scrollingElement.scrollTo(0, snap_point_2.offsetTop);
+ let snapchanging_evt = await snapchanging_promise;
+ let snapchanged_evt = await snapchanged_promise;
+
+ assertSnapEvent(snapchanging_evt, { inline: null, block: snap_point_2 });
+ assertSnapEvent(snapchanged_evt, { inline: null, block: snap_point_2 });
+ }, "snapchanged bubbles when fired at the document (onsnapchanged).");
+ </script>
+</body>
+
+</html>