diff options
author | martinfalisse <martinmotteditfalisse@gmail.com> | 2022-08-23 20:00:16 +0200 |
---|---|---|
committer | Andreas Kling <kling@serenityos.org> | 2022-08-25 13:47:48 +0200 |
commit | 7bb3a8d646d3b5061370a105d09d8c446c069425 (patch) | |
tree | a6edecc5aadc887b9a0203cfcbf760f6034fad9e /Userland/Libraries/LibWeb/CSS | |
parent | 44d08b81b7210efc697db3c395064280e05e263c (diff) | |
download | serenity-7bb3a8d646d3b5061370a105d09d8c446c069425.zip |
LibWeb: Parse grid-column and grid-row CSS values
Diffstat (limited to 'Userland/Libraries/LibWeb/CSS')
-rw-r--r-- | Userland/Libraries/LibWeb/CSS/Parser/Parser.cpp | 48 | ||||
-rw-r--r-- | Userland/Libraries/LibWeb/CSS/Parser/Parser.h | 1 | ||||
-rw-r--r-- | Userland/Libraries/LibWeb/CSS/Properties.json | 28 | ||||
-rw-r--r-- | Userland/Libraries/LibWeb/CSS/ResolvedCSSStyleDeclaration.cpp | 28 | ||||
-rw-r--r-- | Userland/Libraries/LibWeb/CSS/StyleComputer.cpp | 26 |
5 files changed, 131 insertions, 0 deletions
diff --git a/Userland/Libraries/LibWeb/CSS/Parser/Parser.cpp b/Userland/Libraries/LibWeb/CSS/Parser/Parser.cpp index d7a4b563b9..6e6357ea32 100644 --- a/Userland/Libraries/LibWeb/CSS/Parser/Parser.cpp +++ b/Userland/Libraries/LibWeb/CSS/Parser/Parser.cpp @@ -5352,6 +5352,46 @@ RefPtr<StyleValue> Parser::parse_grid_track_placement(Vector<ComponentValue> con return {}; } +RefPtr<StyleValue> Parser::parse_grid_track_placement_shorthand_value(Vector<ComponentValue> const& component_values) +{ + auto tokens = TokenStream { component_values }; + auto current_token = tokens.next_token().token(); + + if (!tokens.has_next_token()) { + if (current_token.to_string() == "auto"sv) + return GridTrackPlacementShorthandStyleValue::create(CSS::GridTrackPlacement::make_auto()); + if (current_token.is(Token::Type::Number) && current_token.number().is_integer()) + return GridTrackPlacementShorthandStyleValue::create(CSS::GridTrackPlacement(current_token.number_value())); + return {}; + } + + auto calculate_grid_track_placement = [](auto& current_token, auto& tokens) -> CSS::GridTrackPlacement { + auto grid_track_placement = CSS::GridTrackPlacement(); + if (current_token.to_string() == "span"sv) { + grid_track_placement.set_has_span(true); + tokens.skip_whitespace(); + current_token = tokens.next_token().token(); + } + if (current_token.is(Token::Type::Number) && current_token.number().is_integer()) + grid_track_placement.set_position(static_cast<int>(current_token.number_value())); + return grid_track_placement; + }; + + auto first_grid_track_placement = calculate_grid_track_placement(current_token, tokens); + if (!tokens.has_next_token()) + return GridTrackPlacementShorthandStyleValue::create(CSS::GridTrackPlacement(first_grid_track_placement)); + + tokens.skip_whitespace(); + current_token = tokens.next_token().token(); + tokens.skip_whitespace(); + current_token = tokens.next_token().token(); + + auto second_grid_track_placement = calculate_grid_track_placement(current_token, tokens); + if (!tokens.has_next_token()) + return GridTrackPlacementShorthandStyleValue::create(GridTrackPlacementStyleValue::create(first_grid_track_placement), GridTrackPlacementStyleValue::create(second_grid_track_placement)); + return {}; +} + Parser::ParseErrorOr<NonnullRefPtr<StyleValue>> Parser::parse_css_value(PropertyID property_id, TokenStream<ComponentValue>& tokens) { auto function_contains_var_or_attr = [](Function const& function, auto&& recurse) -> bool { @@ -5482,6 +5522,10 @@ Parser::ParseErrorOr<NonnullRefPtr<StyleValue>> Parser::parse_css_value(Property if (auto parsed_value = parse_font_family_value(component_values)) return parsed_value.release_nonnull(); return ParseError::SyntaxError; + case PropertyID::GridColumn: + if (auto parsed_value = parse_grid_track_placement_shorthand_value(component_values)) + return parsed_value.release_nonnull(); + return ParseError::SyntaxError; case PropertyID::GridColumnEnd: if (auto parsed_value = parse_grid_track_placement(component_values)) return parsed_value.release_nonnull(); @@ -5490,6 +5534,10 @@ Parser::ParseErrorOr<NonnullRefPtr<StyleValue>> Parser::parse_css_value(Property if (auto parsed_value = parse_grid_track_placement(component_values)) return parsed_value.release_nonnull(); return ParseError::SyntaxError; + case PropertyID::GridRow: + if (auto parsed_value = parse_grid_track_placement_shorthand_value(component_values)) + return parsed_value.release_nonnull(); + return ParseError::SyntaxError; case PropertyID::GridRowEnd: if (auto parsed_value = parse_grid_track_placement(component_values)) return parsed_value.release_nonnull(); diff --git a/Userland/Libraries/LibWeb/CSS/Parser/Parser.h b/Userland/Libraries/LibWeb/CSS/Parser/Parser.h index 2e9c1453f4..c9b7fbb63b 100644 --- a/Userland/Libraries/LibWeb/CSS/Parser/Parser.h +++ b/Userland/Libraries/LibWeb/CSS/Parser/Parser.h @@ -361,6 +361,7 @@ private: RefPtr<StyleValue> parse_transform_origin_value(Vector<ComponentValue> const&); RefPtr<StyleValue> parse_grid_track_sizes(Vector<ComponentValue> const&); RefPtr<StyleValue> parse_grid_track_placement(Vector<ComponentValue> const&); + RefPtr<StyleValue> parse_grid_track_placement_shorthand_value(Vector<ComponentValue> const&); // calc() parsing, according to https://www.w3.org/TR/css-values-3/#calc-syntax OwnPtr<CalculatedStyleValue::CalcSum> parse_calc_sum(TokenStream<ComponentValue>&); diff --git a/Userland/Libraries/LibWeb/CSS/Properties.json b/Userland/Libraries/LibWeb/CSS/Properties.json index e32e724bba..642916754a 100644 --- a/Userland/Libraries/LibWeb/CSS/Properties.json +++ b/Userland/Libraries/LibWeb/CSS/Properties.json @@ -694,6 +694,20 @@ "normal" ] }, + "grid-column": { + "inherited": false, + "initial": "auto", + "valid-identifiers": [ + "auto" + ], + "valid-types": [ + "string" + ], + "longhands": [ + "grid-column-end", + "grid-column-start" + ] + }, "grid-column-end": { "inherited": false, "initial": "auto", @@ -714,6 +728,20 @@ "string" ] }, + "grid-row": { + "inherited": false, + "initial": "auto", + "valid-identifiers": [ + "auto" + ], + "valid-types": [ + "string" + ], + "longhands": [ + "grid-row-end", + "grid-row-start" + ] + }, "grid-row-end": { "inherited": false, "initial": "auto", diff --git a/Userland/Libraries/LibWeb/CSS/ResolvedCSSStyleDeclaration.cpp b/Userland/Libraries/LibWeb/CSS/ResolvedCSSStyleDeclaration.cpp index 21edc2f84d..3e9e9f1573 100644 --- a/Userland/Libraries/LibWeb/CSS/ResolvedCSSStyleDeclaration.cpp +++ b/Userland/Libraries/LibWeb/CSS/ResolvedCSSStyleDeclaration.cpp @@ -295,10 +295,38 @@ RefPtr<StyleValue> ResolvedCSSStyleDeclaration::style_value_for_property(Layout: return IdentifierStyleValue::create(to_value_id(layout_node.computed_values().flex_wrap())); case CSS::PropertyID::Float: return IdentifierStyleValue::create(to_value_id(layout_node.computed_values().float_())); + case CSS::PropertyID::GridColumn: { + auto maybe_grid_column_end = property(CSS::PropertyID::GridColumnEnd); + auto maybe_grid_column_start = property(CSS::PropertyID::GridColumnStart); + RefPtr<GridTrackPlacementStyleValue> grid_column_start, grid_column_end; + if (maybe_grid_column_end.has_value()) { + VERIFY(maybe_grid_column_end.value().value->is_grid_track_placement()); + grid_column_end = maybe_grid_column_end.value().value->as_grid_track_placement(); + } + if (maybe_grid_column_start.has_value()) { + VERIFY(maybe_grid_column_start.value().value->is_grid_track_placement()); + grid_column_start = maybe_grid_column_start.value().value->as_grid_track_placement(); + } + return GridTrackPlacementShorthandStyleValue::create(grid_column_end.release_nonnull(), grid_column_start.release_nonnull()); + } case CSS::PropertyID::GridColumnEnd: return GridTrackPlacementStyleValue::create(layout_node.computed_values().grid_column_end()); case CSS::PropertyID::GridColumnStart: return GridTrackPlacementStyleValue::create(layout_node.computed_values().grid_column_start()); + case CSS::PropertyID::GridRow: { + auto maybe_grid_row_end = property(CSS::PropertyID::GridRowEnd); + auto maybe_grid_row_start = property(CSS::PropertyID::GridRowStart); + RefPtr<GridTrackPlacementStyleValue> grid_row_start, grid_row_end; + if (maybe_grid_row_end.has_value()) { + VERIFY(maybe_grid_row_end.value().value->is_grid_track_placement()); + grid_row_end = maybe_grid_row_end.value().value->as_grid_track_placement(); + } + if (maybe_grid_row_start.has_value()) { + VERIFY(maybe_grid_row_start.value().value->is_grid_track_placement()); + grid_row_start = maybe_grid_row_start.value().value->as_grid_track_placement(); + } + return GridTrackPlacementShorthandStyleValue::create(grid_row_end.release_nonnull(), grid_row_start.release_nonnull()); + } case CSS::PropertyID::GridRowEnd: return GridTrackPlacementStyleValue::create(layout_node.computed_values().grid_row_end()); case CSS::PropertyID::GridRowStart: diff --git a/Userland/Libraries/LibWeb/CSS/StyleComputer.cpp b/Userland/Libraries/LibWeb/CSS/StyleComputer.cpp index 83fea3dc0d..c1b7125160 100644 --- a/Userland/Libraries/LibWeb/CSS/StyleComputer.cpp +++ b/Userland/Libraries/LibWeb/CSS/StyleComputer.cpp @@ -517,6 +517,32 @@ static void set_property_expanding_shorthands(StyleProperties& style, CSS::Prope return; } + if (property_id == CSS::PropertyID::GridColumn) { + if (value.is_grid_track_placement_shorthand()) { + auto const& shorthand = value.as_grid_track_placement_shorthand(); + style.set_property(CSS::PropertyID::GridColumnStart, shorthand.start()); + style.set_property(CSS::PropertyID::GridColumnEnd, shorthand.end()); + return; + } + + style.set_property(CSS::PropertyID::GridColumnStart, value); + style.set_property(CSS::PropertyID::GridColumnEnd, value); + return; + } + + if (property_id == CSS::PropertyID::GridRow) { + if (value.is_grid_track_placement_shorthand()) { + auto const& shorthand = value.as_grid_track_placement_shorthand(); + style.set_property(CSS::PropertyID::GridRowStart, shorthand.start()); + style.set_property(CSS::PropertyID::GridRowEnd, shorthand.end()); + return; + } + + style.set_property(CSS::PropertyID::GridRowStart, value); + style.set_property(CSS::PropertyID::GridRowEnd, value); + return; + } + style.set_property(property_id, value); } |