mirror of
https://github.com/LadybirdBrowser/ladybird
synced 2026-05-01 03:57:15 +02:00
LibWeb: Add overflow-clip-margin-* properties
The corner radius isn't quite right yet, but this gives us another couple WPT passes for these.
This commit is contained in:
committed by
Alexander Kalenik
parent
3253ddfcb2
commit
a7267f711b
Notes:
github-actions[bot]
2026-02-14 21:59:33 +00:00
Author: https://github.com/Psychpsyo Commit: https://github.com/LadybirdBrowser/ladybird/commit/a7267f711bc Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/7833 Reviewed-by: https://github.com/Calme1709 Reviewed-by: https://github.com/kalenikaliaksandr
@@ -0,0 +1,42 @@
|
||||
<!doctype html>
|
||||
<meta charset="utf-8">
|
||||
<title>Verifies overflow-clip-margin extends outside bounds</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">
|
||||
<link rel="match" href="../../../../expected/wpt-import/css/css-overflow/overflow-clip-margin-001-ref.html">
|
||||
<style>
|
||||
.container {
|
||||
display: flex;
|
||||
}
|
||||
.parent {
|
||||
width: 100px;
|
||||
height: 100px;
|
||||
flex: none;
|
||||
overflow: clip;
|
||||
overflow-clip-margin: 10px;
|
||||
}
|
||||
.child {
|
||||
width: 200px;
|
||||
height: 200px;
|
||||
position: relative;
|
||||
top: -50px;
|
||||
left: -50px;
|
||||
background-color: green;
|
||||
}
|
||||
.spacer {
|
||||
flex: none;
|
||||
height: 100px;
|
||||
width: 100px;
|
||||
}
|
||||
|
||||
</style>
|
||||
<p>You should see two green squares touching each other. The one on the
|
||||
right should be slightly larger.</p>
|
||||
<div class="spacer"></div>
|
||||
<div class="container">
|
||||
<div class="spacer" style="width: 90px; background-color: green"></div>
|
||||
<div class="spacer" style="width: 10px"></div>
|
||||
<div class="parent">
|
||||
<div class="child"></div>
|
||||
</div>
|
||||
</div>
|
||||
@@ -0,0 +1,18 @@
|
||||
<!doctype html>
|
||||
<meta charset="utf-8">
|
||||
<title>Verifies overflow-clip-margin doesn't impact paint effects</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">
|
||||
<link rel="match" href="../../../../expected/wpt-import/css/css-overflow/overflow-clip-margin-003-ref.html">
|
||||
<style>
|
||||
.parent {
|
||||
width: 100px;
|
||||
height: 100px;
|
||||
background-color: green;
|
||||
overflow: clip;
|
||||
overflow-clip-margin: 1px;
|
||||
box-shadow: 20px 20px 5px red;
|
||||
}
|
||||
</style>
|
||||
<p>You should see a green box with a red box shadow.
|
||||
<div class="parent"></div>
|
||||
@@ -0,0 +1,42 @@
|
||||
<!doctype html>
|
||||
<meta charset="utf-8">
|
||||
<title>Verifies overflow-clip-margin extends outside bounds with contain: paint</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">
|
||||
<link rel="match" href="../../../../expected/wpt-import/css/css-overflow/overflow-clip-margin-004-ref.html">
|
||||
<style>
|
||||
.container {
|
||||
display: flex;
|
||||
}
|
||||
.parent {
|
||||
width: 100px;
|
||||
height: 100px;
|
||||
flex: none;
|
||||
contain: paint;
|
||||
overflow-clip-margin: 10px;
|
||||
}
|
||||
.child {
|
||||
width: 200px;
|
||||
height: 200px;
|
||||
position: relative;
|
||||
top: -50px;
|
||||
left: -50px;
|
||||
background-color: green;
|
||||
}
|
||||
.spacer {
|
||||
flex: none;
|
||||
height: 100px;
|
||||
width: 100px;
|
||||
}
|
||||
|
||||
</style>
|
||||
<p>You should see two green squares touching each other. The one on the
|
||||
right should be slightly larger.</p>
|
||||
<div class="spacer"></div>
|
||||
<div class="container">
|
||||
<div class="spacer" style="width: 90px; background-color: green"></div>
|
||||
<div class="spacer" style="width: 10px"></div>
|
||||
<div class="parent">
|
||||
<div class="child"></div>
|
||||
</div>
|
||||
</div>
|
||||
@@ -0,0 +1,18 @@
|
||||
<!doctype html>
|
||||
<meta charset="utf-8">
|
||||
<title>Verifies overflow-clip-margin doesn't impact paint effects</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">
|
||||
<link rel="match" href="../../../../expected/wpt-import/css/css-overflow/overflow-clip-margin-006-ref.html">
|
||||
<style>
|
||||
.parent {
|
||||
width: 100px;
|
||||
height: 100px;
|
||||
background-color: green;
|
||||
contain: paint;
|
||||
overflow-clip-margin: 1px;
|
||||
box-shadow: 20px 20px 5px red;
|
||||
}
|
||||
</style>
|
||||
<p>You should see a green box with a red box shadow.
|
||||
<div class="parent"></div>
|
||||
@@ -0,0 +1,28 @@
|
||||
<!doctype html>
|
||||
<html class="reftest">
|
||||
<meta charset="utf-8">
|
||||
<title>Overflow-clip-margin can be inherited even if it has no effect on specified element</title>
|
||||
<link rel="help" href="https://www.w3.org/TR/css-overflow-3/#propdef-overflow-clip-margin">
|
||||
<link rel="author" title="Vladimir Levin" href="mailto:vmpstr@chromium.org">
|
||||
<link rel="match" href="../../../../expected/wpt-import/css/css-overflow/overflow-clip-margin-009-ref.html">
|
||||
<style>
|
||||
.prop {
|
||||
overflow-clip-margin: 20px;
|
||||
}
|
||||
.container {
|
||||
width: 100px;
|
||||
height: 100px;
|
||||
overflow-clip-margin: inherit;
|
||||
overflow: clip;
|
||||
}
|
||||
.child {
|
||||
width: 200px;
|
||||
height: 200px;
|
||||
background: lightblue;
|
||||
}
|
||||
</style>
|
||||
<div class=prop>
|
||||
<div class=container>
|
||||
<div class=child></div>
|
||||
</div>
|
||||
</div>
|
||||
@@ -0,0 +1,35 @@
|
||||
<!doctype html>
|
||||
<meta charset="utf-8">
|
||||
<title>Overflow-clip-margin: child of a small-border-box out-of-view large-clip-margin parent is shown</title>
|
||||
<link rel="help" href="https://www.w3.org/TR/css-overflow-3/#propdef-overflow-clip-margin">
|
||||
<link rel="author" title="Xianzhu Wang" href="mailto:wangxianzhu@chromium.org">
|
||||
<link rel="match" href="../../../../expected/wpt-import/css/css-overflow/overflow-clip-margin-011-ref.html">
|
||||
<style>
|
||||
.overflow-hidden {
|
||||
width: 200px;
|
||||
height: 200px;
|
||||
overflow: hidden;
|
||||
}
|
||||
.parent {
|
||||
width: 100px;
|
||||
height: 100px;
|
||||
position: relative;
|
||||
top: 500px;
|
||||
overflow: clip;
|
||||
overflow-clip-margin: 500px;
|
||||
z-index: 1;
|
||||
background: red;
|
||||
}
|
||||
.child {
|
||||
width: 100px;
|
||||
height: 100px;
|
||||
position: relative;
|
||||
top: -500px;
|
||||
background: green;
|
||||
}
|
||||
</style>
|
||||
<div class="overflow-hidden">
|
||||
<div class="parent">
|
||||
<div class="child">
|
||||
</div>
|
||||
</div>
|
||||
@@ -0,0 +1,64 @@
|
||||
<!DOCTYPE html>
|
||||
<html class="reftest-wait">
|
||||
<head>
|
||||
<title>CSS Overflow: overflow-clip-margin: invalidation on change</title>
|
||||
<link rel="help" href="https://www.w3.org/TR/css-overflow-3/#propdef-overflow-clip-margin">
|
||||
<meta name="assert" content="overflow-clip-margin: toggling should invalidate.">
|
||||
<link rel="author" title="Scott Violet" href="mailto:sky@chromium.org">
|
||||
<link rel="match" href="../../../../expected/wpt-import/css/css-overflow/overflow-clip-margin-invalidation-ref.html">
|
||||
<style>
|
||||
.container {
|
||||
display: flex;
|
||||
}
|
||||
.parent {
|
||||
flex: none;
|
||||
width: 100px;
|
||||
height: 100px;
|
||||
flex: none;
|
||||
overflow: clip;
|
||||
}
|
||||
.child {
|
||||
width: 200px;
|
||||
height: 200px;
|
||||
position: relative;
|
||||
top: -50px;
|
||||
left: -50px;
|
||||
background-color: green;
|
||||
}
|
||||
.spacer {
|
||||
flex: none;
|
||||
height: 100px;
|
||||
width: 100px;
|
||||
}
|
||||
.margin {
|
||||
overflow-clip-margin: 10px;
|
||||
}
|
||||
</style>
|
||||
<script src="../../common/reftest-wait.js"></script>
|
||||
<script src="../../common/rendering-utils.js"></script>
|
||||
</head>
|
||||
<body>
|
||||
<div class="spacer"></div>
|
||||
<div class="container">
|
||||
<div class="spacer"></div>
|
||||
<div id="div_with_margin" class="parent margin">
|
||||
<div class="child"></div>
|
||||
</div>
|
||||
<div class="spacer"></div>
|
||||
<div class="container">
|
||||
<div class="spacer"></div>
|
||||
<div id="div_without_margin" class="parent">
|
||||
<div class="child"></div>
|
||||
</div>
|
||||
</body>
|
||||
<script>
|
||||
async function runTest() {
|
||||
document.getElementById('div_with_margin').classList.remove("margin");
|
||||
document.getElementById('div_without_margin').classList.add("margin");
|
||||
takeScreenshot();
|
||||
}
|
||||
onload = () => {
|
||||
waitForAtLeastOneFrame().then(() => { runTest() });
|
||||
}
|
||||
</script>
|
||||
</html>
|
||||
Reference in New Issue
Block a user