summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormatcool <26722564+matcool@users.noreply.github.com>2023-04-03 18:26:13 -0300
committerAndreas Kling <kling@serenityos.org>2023-04-05 16:23:56 +0200
commitcc33a57620574658425f240c715f2107c6d02433 (patch)
tree476b4e8e20a21e5e46aafc7b676e2d3013f3e1aa
parent9b4b12f133850dcc3b3c27c240dabbe1faefd17f (diff)
downloadserenity-cc33a57620574658425f240c715f2107c6d02433.zip
LibWeb: Use intrinsic aspect ratio when calculating max content height
-rw-r--r--Tests/LibWeb/Layout/expected/flex-item-on-row-with-intrinsic-aspect-ratio.txt4
-rw-r--r--Tests/LibWeb/Layout/input/flex-item-on-row-with-intrinsic-aspect-ratio.html12
-rw-r--r--Userland/Libraries/LibWeb/Layout/FormattingContext.cpp3
3 files changed, 19 insertions, 0 deletions
diff --git a/Tests/LibWeb/Layout/expected/flex-item-on-row-with-intrinsic-aspect-ratio.txt b/Tests/LibWeb/Layout/expected/flex-item-on-row-with-intrinsic-aspect-ratio.txt
new file mode 100644
index 0000000000..6da0287415
--- /dev/null
+++ b/Tests/LibWeb/Layout/expected/flex-item-on-row-with-intrinsic-aspect-ratio.txt
@@ -0,0 +1,4 @@
+Viewport <#document> at (0,0) content-size 800x600 children: not-inline
+ BlockContainer <html> at (0,0) content-size 800x200 children: not-inline
+ Box <body> at (0,0) content-size 800x200 flex-container(row) children: not-inline
+ ImageBox <img> at (0,0) content-size 400x200 flex-item children: not-inline
diff --git a/Tests/LibWeb/Layout/input/flex-item-on-row-with-intrinsic-aspect-ratio.html b/Tests/LibWeb/Layout/input/flex-item-on-row-with-intrinsic-aspect-ratio.html
new file mode 100644
index 0000000000..ed59d6391e
--- /dev/null
+++ b/Tests/LibWeb/Layout/input/flex-item-on-row-with-intrinsic-aspect-ratio.html
@@ -0,0 +1,12 @@
+<!DOCTYPE html><html><head><style>
+ * {
+ margin: 0;
+ padding: 0;
+ }
+ body {
+ display: flex;
+ }
+ img {
+ width: 400px;
+ }
+</style></head><body><img src=""> \ No newline at end of file
diff --git a/Userland/Libraries/LibWeb/Layout/FormattingContext.cpp b/Userland/Libraries/LibWeb/Layout/FormattingContext.cpp
index 803b051940..421643823e 100644
--- a/Userland/Libraries/LibWeb/Layout/FormattingContext.cpp
+++ b/Userland/Libraries/LibWeb/Layout/FormattingContext.cpp
@@ -1205,6 +1205,9 @@ CSSPixels FormattingContext::calculate_min_content_height(Layout::Box const& box
CSSPixels FormattingContext::calculate_max_content_height(Layout::Box const& box, AvailableSize const& available_width) const
{
+ if (box.has_intrinsic_aspect_ratio() && available_width.is_definite())
+ return available_width.to_px() / *box.intrinsic_aspect_ratio();
+
if (box.has_intrinsic_height())
return *box.intrinsic_height();