File: nested-parent-changes-transform-twice.html

package info (click to toggle)
firefox 149.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,767,760 kB
  • sloc: cpp: 7,416,064; javascript: 6,752,859; ansic: 3,774,850; python: 1,250,473; xml: 641,578; asm: 439,191; java: 186,617; sh: 56,634; makefile: 18,856; objc: 13,092; perl: 12,763; pascal: 5,960; yacc: 4,583; cs: 3,846; lex: 1,720; ruby: 1,002; php: 436; lisp: 258; awk: 105; sql: 66; sed: 53; csh: 10; exp: 6
file content (76 lines) | stat: -rw-r--r-- 1,561 bytes parent folder | download | duplicates (4)
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
<!doctype html>
<html class=reftest-wait>
<title>Nested View Transitions: child only has old and parent changes transform (twice)</title>
<link rel="help" href="https://drafts.csswg.org/css-view-transitions-2/">
<link rel="match" href="green-rect-ref.html">
<script src="/common/reftest-wait.js"></script>
<script src="resources/compute-test.js"></script>
<script src="/dom/events/scrolling/scroll_support.js"></script>

<style>
:root { view-transition-name: none; }

.container {
  width: 100px;
  height: 100px;
  position: relative;
  background: red;

  view-transition-name: container;
  view-transition-group: contain;
}

.container.shifted {
  top: 150px;
}
.container.shifted_again {
  left: 150px;
}

.contained {
  width: 100px;
  height: 100px;
  background: green;

  view-transition-name: contained;
}

.hidden {
  display: none;
}

::view-transition-group(*) {
  animation-play-state: paused;
}

::view-transition-old(*) {
  animation: unset;
  opacity: 1;
}

::view-transition-new(*) {
  animation: unset;
  opacity: 0;
}

</style>

<div id=container class=container>
  <div id=contained class=contained></div>
</div>

<script>
function runTest() {
  const transition = document.startViewTransition(() => {
    container.classList.add("shifted");
    contained.classList.add("hidden");
  });

  transition.ready.then(() => requestAnimationFrame(() => requestAnimationFrame(() => {
    container.classList.add("shifted_again");
    requestAnimationFrame(takeScreenshot);
  })));
}

onload = () => waitForCompositorReady().then(runTest);
</script>