File: snapevents-at-document-bubble-to-window.html

package info (click to toggle)
thunderbird 1%3A140.4.0esr-1
  • links: PTS, VCS
  • area: main
  • in suites: forky
  • size: 4,609,432 kB
  • sloc: cpp: 7,672,442; javascript: 5,901,613; ansic: 3,898,954; python: 1,413,343; xml: 653,997; asm: 462,286; java: 180,927; sh: 113,489; makefile: 20,460; perl: 14,288; objc: 13,059; yacc: 4,583; pascal: 3,352; lex: 1,720; ruby: 1,222; exp: 762; sql: 715; awk: 580; php: 436; lisp: 430; sed: 70; csh: 10
file content (96 lines) | stat: -rw-r--r-- 3,037 bytes parent folder | download | duplicates (12)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <title> CSS Scroll Snap 2 Test: scrollsnapchange 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/snap-events/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 scrollsnapchanging_promise = waitForSnapEvent(window, "scrollsnapchanging");
      let scrollsnapchange_promise = waitForSnapEvent(window, "scrollsnapchange");
      document.scrollingElement.scrollTo(0, snap_point_2.offsetTop);
      let scrollsnapchanging_evt = await scrollsnapchanging_promise;
      let scrollsnapchange_evt = await scrollsnapchange_promise;

      assertSnapEvent(scrollsnapchanging_evt, { inline: null, block: snap_point_2 });
      assertSnapEvent(scrollsnapchange_evt, { inline: null, block: snap_point_2 });
    }, "scrollsnapchange bubbles when fired at the document (addEventListener).");

    promise_test(async(t) => {
      await waitForScrollReset(t, document.scrollingElement);
      await waitForCompositorCommit();

      let scrollsnapchanging_promise = waitForSnapEvent(window, "scrollsnapchanging",
                                    /*scroll_happens=*/true,
                                    /*use_onsnap_member=*/true);
      let scrollsnapchange_promise = waitForSnapEvent(window, "scrollsnapchange",
                                    /*scroll_happens=*/true,
                                    /*use_onsnap_member=*/true);
      document.scrollingElement.scrollTo(0, snap_point_2.offsetTop);
      let scrollsnapchanging_evt = await scrollsnapchanging_promise;
      let scrollsnapchange_evt = await scrollsnapchange_promise;

      assertSnapEvent(scrollsnapchanging_evt, { inline: null, block: snap_point_2 });
      assertSnapEvent(scrollsnapchange_evt, { inline: null, block: snap_point_2 });
    }, "scrollsnapchange bubbles when fired at the document (onscrollsnapchange).");
  </script>
</body>

</html>