LibWeb: Resolve used insets for flex items

This commit is contained in:
Andreas Kling 2023-07-03 20:32:57 +02:00
parent c83ae729d2
commit 03ec17fd37
Notes: sideshowbarker 2024-07-16 23:23:26 +09:00
3 changed files with 34 additions and 0 deletions

View file

@ -0,0 +1,13 @@
Viewport <#document> at (0,0) content-size 800x600 children: not-inline
BlockContainer <html> at (2,2) content-size 796x41.46875 [BFC] children: not-inline
Box <body> at (12,12) content-size 600x21.46875 flex-container(row) [FFC] children: not-inline
BlockContainer <div.exekiller> at (14,14) content-size 200x17.46875 positioned flex-item [BFC] children: inline
line 0 width: 65.4375, height: 17.46875, bottom: 17.46875, baseline: 13.53125
frag 0 from TextNode start: 0, length: 9, rect: [14,14 65.4375x17.46875]
"exekiller"
TextNode <#text>
BlockContainer <div.athena> at (18,18) content-size 200x17.46875 positioned flex-item [BFC] children: inline
line 0 width: 53.171875, height: 17.46875, bottom: 17.46875, baseline: 13.53125
frag 0 from TextNode start: 0, length: 6, rect: [18,18 53.171875x17.46875]
"athena"
TextNode <#text>

View file

@ -0,0 +1,19 @@
<!DOCTYPE html><style>
* { border: 2px solid black; }
body {
width: 600px;
display: flex;
}
div {
width: 200px;
position: relative;
}
.athena {
background: green;
top: 4px;
left: -200px;
}
.exekiller {
background: red;
}
</style><body><div class="exekiller">exekiller</div><div class="athena">athena</div></body>

View file

@ -216,6 +216,8 @@ void FlexFormattingContext::run(Box const& run_box, LayoutMode, AvailableSpace c
auto& box_state = m_state.get(item.box);
if (auto independent_formatting_context = layout_inside(item.box, LayoutMode::Normal, box_state.available_inner_space_or_constraints_from(m_available_space_for_flex_container->space)))
independent_formatting_context->parent_context_did_dimension_child_root_box();
compute_inset(item.box);
}
}
}