mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-24 18:32:28 -05:00
LibWeb: Avoid text-aligning content that is too long for its line box
Previously, we would always respect the `text-align` property, even if the text being aligned was too long for its line box and would be clipped. This led to seeing the clipped middle/end of strings when we should instead always see the beginning of the text.
This commit is contained in:
parent
54fb9477a4
commit
de9604212f
3 changed files with 38 additions and 12 deletions
9
Tests/LibWeb/Layout/expected/text-align-overflow.txt
Normal file
9
Tests/LibWeb/Layout/expected/text-align-overflow.txt
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
Viewport <#document> at (0,0) content-size 800x600 children: not-inline
|
||||||
|
BlockContainer <html> at (0,0) content-size 800x33.46875 [BFC] children: not-inline
|
||||||
|
BlockContainer <body> at (8,8) content-size 784x17.46875 children: not-inline
|
||||||
|
BlockContainer <div.outer> at (18,8) content-size 80x17.46875 children: not-inline
|
||||||
|
BlockContainer <span.text> at (18,8) content-size 80x17.46875 [BFC] children: inline
|
||||||
|
line 0 width: 189.875, height: 17.46875, bottom: 17.46875, baseline: 13.53125
|
||||||
|
frag 0 from TextNode start: 0, length: 22, rect: [18,8 189.875x17.46875]
|
||||||
|
"My super long message!"
|
||||||
|
TextNode <#text>
|
13
Tests/LibWeb/Layout/input/text-align-overflow.html
Normal file
13
Tests/LibWeb/Layout/input/text-align-overflow.html
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
<!DOCTYPE html><style>
|
||||||
|
.outer {
|
||||||
|
margin-left: 10px;
|
||||||
|
width: 80px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text {
|
||||||
|
display: block;
|
||||||
|
text-align: center;
|
||||||
|
overflow: hidden;
|
||||||
|
white-space: nowrap;
|
||||||
|
}
|
||||||
|
</style><div class="outer"><span class="text">My super long message!
|
|
@ -170,6 +170,9 @@ void LineBuilder::update_last_line()
|
||||||
|
|
||||||
CSSPixels excess_horizontal_space = m_available_width_for_current_line - line_box.width();
|
CSSPixels excess_horizontal_space = m_available_width_for_current_line - line_box.width();
|
||||||
|
|
||||||
|
// If (after justification, if any) the inline contents of a line box are too long to fit within it,
|
||||||
|
// then the contents are start-aligned: any content that doesn't fit overflows the line box’s end edge.
|
||||||
|
if (excess_horizontal_space > 0) {
|
||||||
switch (text_align) {
|
switch (text_align) {
|
||||||
case CSS::TextAlign::Center:
|
case CSS::TextAlign::Center:
|
||||||
case CSS::TextAlign::LibwebCenter:
|
case CSS::TextAlign::LibwebCenter:
|
||||||
|
@ -183,6 +186,7 @@ void LineBuilder::update_last_line()
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
auto strut_baseline = [&] {
|
auto strut_baseline = [&] {
|
||||||
auto& font = m_context.containing_block().font();
|
auto& font = m_context.containing_block().font();
|
||||||
|
|
Loading…
Add table
Reference in a new issue