diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
commit | 26a029d407be480d791972afb5975cf62c9360a6 (patch) | |
tree | f435a8308119effd964b339f76abb83a57c29483 /testing/web-platform/tests/css/css-overflow/overflow-clip-margin-intersection-observer.html | |
parent | Initial commit. (diff) | |
download | firefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz firefox-26a029d407be480d791972afb5975cf62c9360a6.zip |
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/css/css-overflow/overflow-clip-margin-intersection-observer.html')
-rw-r--r-- | testing/web-platform/tests/css/css-overflow/overflow-clip-margin-intersection-observer.html | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/testing/web-platform/tests/css/css-overflow/overflow-clip-margin-intersection-observer.html b/testing/web-platform/tests/css/css-overflow/overflow-clip-margin-intersection-observer.html new file mode 100644 index 0000000000..dcc1e6e7ed --- /dev/null +++ b/testing/web-platform/tests/css/css-overflow/overflow-clip-margin-intersection-observer.html @@ -0,0 +1,55 @@ +<!doctype html> +<meta charset="utf-8"> +<title>Overflow: intersection observer with overflow-clip-margin</title> +<link rel="help" href="https://www.w3.org/TR/css-overflow-3/#propdef-overflow-clip-margin"> +<link rel="author" title="Scott Violet" href="mailto:sky@chromium.org"> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<style> + #clipped_container { + overflow: clip; + width: 100px; + height: 100px; + border: solid; + overflow-clip-margin: 50px; + } + #big_green_div { + position: relative; + width: 1000px; + height: 1000px; + background: green; + left: -200px; + top: -200px; + } + /* These values ensure the element is vertically offscreen. */ + .spacer { width: 150px; height: calc(100vh + 10px); } +</style> +<div class="spacer"></div> +<div id="clipped_container"> + <div id="big_green_div"></div> +</div> + +<script> +let t = async_test("ParentWithOverflowClipMargin"); +let options = { + threshold: 0, + rootMargin: '0px' +} +// The 'big_green_div' is initially on screen due to +// overflow-clip-margin of the parent. Once the observer is notified, the +// overflow-clip-margin is reduced so that 'big_green_div' is no longer +// on screen, and the observer should again be notified. +let gotIntersects = false; +let intersectionObserver = new IntersectionObserver((entries, observer) => { + t.step(function() { assert_equals(1, entries.length); }); + let entry = entries[0]; + if (!gotIntersects) { + t.step(function() { assert_true(entry.isIntersecting); }); + gotIntersects = true; + document.getElementById('clipped_container').style.overflowClipMargin = "0px"; + } else { + t.step(function() { assert_false(entry.isIntersecting); }); + t.done(); + }}, options); +intersectionObserver.observe(document.getElementById('big_green_div')); +</script> |