LibWeb: Make ObjectPosition more reusable

This commit is contained in:
Psychpsyo 2025-11-12 21:40:32 +01:00 committed by Sam Atkins
parent ada3810779
commit 27e4793c5d
Notes: github-actions[bot] 2025-11-21 11:15:39 +00:00
3 changed files with 28 additions and 23 deletions

View file

@ -324,6 +324,25 @@ Color ComputedProperties::color_or_fallback(PropertyID id, ColorResolutionContex
return value.to_color(color_resolution_context).value();
}
Position ComputedProperties::position_value(PropertyID id) const
{
auto const& position = property(id).as_position();
Position position_value;
auto const& edge_x = position.edge_x();
auto const& edge_y = position.edge_y();
if (edge_x->is_edge()) {
auto const& edge = edge_x->as_edge();
position_value.edge_x = edge.edge().value_or(PositionEdge::Left);
position_value.offset_x = edge.offset();
}
if (edge_y->is_edge()) {
auto const& edge = edge_y->as_edge();
position_value.edge_y = edge.edge().value_or(PositionEdge::Top);
position_value.offset_y = edge.offset();
}
return position_value;
}
// https://drafts.csswg.org/css-values-4/#linked-properties
HashMap<PropertyID, StyleValueVector> ComputedProperties::assemble_coordinated_value_list(PropertyID base_property_id, Vector<PropertyID> const& property_ids) const
{
@ -2024,24 +2043,9 @@ ObjectFit ComputedProperties::object_fit() const
return keyword_to_object_fit(value.to_keyword()).release_value();
}
ObjectPosition ComputedProperties::object_position() const
Position ComputedProperties::object_position() const
{
auto const& value = property(PropertyID::ObjectPosition);
auto const& position = value.as_position();
ObjectPosition object_position;
auto const& edge_x = position.edge_x();
auto const& edge_y = position.edge_y();
if (edge_x->is_edge()) {
auto const& edge = edge_x->as_edge();
object_position.edge_x = edge.edge().value_or(PositionEdge::Left);
object_position.offset_x = edge.offset();
}
if (edge_y->is_edge()) {
auto const& edge = edge_y->as_edge();
object_position.edge_y = edge.edge().value_or(PositionEdge::Top);
object_position.offset_y = edge.offset();
}
return object_position;
return position_value(PropertyID::ObjectPosition);
}
TableLayout ComputedProperties::table_layout() const

View file

@ -176,7 +176,7 @@ public:
CSS::EmptyCells empty_cells() const;
Vector<Vector<String>> grid_template_areas() const;
ObjectFit object_fit() const;
ObjectPosition object_position() const;
Position object_position() const;
TableLayout table_layout() const;
Direction direction() const;
UnicodeBidi unicode_bidi() const;
@ -288,6 +288,7 @@ private:
Overflow overflow(PropertyID) const;
Vector<ShadowData> shadow(PropertyID, Layout::Node const&) const;
Position position_value(PropertyID) const;
GC::Ptr<CSSStyleDeclaration const> m_transition_property_source;

View file

@ -63,7 +63,7 @@ struct QuotesData {
Vector<Array<FlyString, 2>> strings {};
};
struct ObjectPosition {
struct Position {
PositionEdge edge_x { PositionEdge::Left };
LengthPercentage offset_x { Percentage(50) };
PositionEdge edge_y { PositionEdge::Top };
@ -238,7 +238,7 @@ public:
static Vector<Vector<String>> grid_template_areas() { return {}; }
static Time transition_delay() { return Time::make_seconds(0); }
static ObjectFit object_fit() { return ObjectFit::Fill; }
static ObjectPosition object_position() { return {}; }
static Position object_position() { return {}; }
static Color outline_color() { return Color::Black; }
static Length outline_offset() { return Length::make_px(0); }
static OutlineStyle outline_style() { return OutlineStyle::None; }
@ -566,7 +566,7 @@ public:
EmptyCells empty_cells() const { return m_inherited.empty_cells; }
Vector<Vector<String>> const& grid_template_areas() const { return m_noninherited.grid_template_areas; }
ObjectFit object_fit() const { return m_noninherited.object_fit; }
ObjectPosition object_position() const { return m_noninherited.object_position; }
Position object_position() const { return m_noninherited.object_position; }
Direction direction() const { return m_inherited.direction; }
UnicodeBidi unicode_bidi() const { return m_noninherited.unicode_bidi; }
WritingMode writing_mode() const { return m_inherited.writing_mode; }
@ -833,7 +833,7 @@ protected:
CSSPixels outline_width { InitialValues::outline_width() };
TableLayout table_layout { InitialValues::table_layout() };
ObjectFit object_fit { InitialValues::object_fit() };
ObjectPosition object_position { InitialValues::object_position() };
Position object_position { InitialValues::object_position() };
UnicodeBidi unicode_bidi { InitialValues::unicode_bidi() };
UserSelect user_select { InitialValues::user_select() };
Isolation isolation { InitialValues::isolation() };
@ -1031,7 +1031,7 @@ public:
void set_table_layout(TableLayout value) { m_noninherited.table_layout = value; }
void set_quotes(QuotesData value) { m_inherited.quotes = move(value); }
void set_object_fit(ObjectFit value) { m_noninherited.object_fit = value; }
void set_object_position(ObjectPosition value) { m_noninherited.object_position = move(value); }
void set_object_position(Position value) { m_noninherited.object_position = move(value); }
void set_direction(Direction value) { m_inherited.direction = value; }
void set_unicode_bidi(UnicodeBidi value) { m_noninherited.unicode_bidi = value; }
void set_writing_mode(WritingMode value) { m_inherited.writing_mode = value; }