/* * Copyright (c) 2018-2023, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include #include #include #include #include #include #include namespace Web::CSS { class StyleProperties : public RefCounted { public: StyleProperties() = default; static NonnullRefPtr create() { return adopt_ref(*new StyleProperties); } template inline void for_each_property(Callback callback) const { for (size_t i = 0; i < m_property_values.size(); ++i) { if (m_property_values[i].style) callback((CSS::PropertyID)i, *m_property_values[i].style); } } enum class Important { No, Yes }; enum class Inherited { No, Yes }; struct StyleAndSourceDeclaration { RefPtr style; JS::GCPtr declaration; Important important { Important::No }; Inherited inherited { Inherited::No }; }; using PropertyValues = Array; auto& properties() { return m_property_values; } auto const& properties() const { return m_property_values; } HashMap> const& animated_property_values() const { return m_animated_property_values; } void reset_animated_properties(); bool is_property_important(CSS::PropertyID property_id) const; bool is_property_inherited(CSS::PropertyID property_id) const; void set_property(CSS::PropertyID, NonnullRefPtr value, CSS::CSSStyleDeclaration const* source_declaration = nullptr, Inherited = Inherited::No, Important = Important::No); void set_animated_property(CSS::PropertyID, NonnullRefPtr value); NonnullRefPtr property(CSS::PropertyID) const; RefPtr maybe_null_property(CSS::PropertyID) const; CSS::CSSStyleDeclaration const* property_source_declaration(CSS::PropertyID) const; CSS::Size size_value(CSS::PropertyID) const; LengthPercentage length_percentage_or_fallback(CSS::PropertyID, LengthPercentage const& fallback) const; Optional length_percentage(CSS::PropertyID) const; LengthBox length_box(CSS::PropertyID left_id, CSS::PropertyID top_id, CSS::PropertyID right_id, CSS::PropertyID bottom_id, const CSS::Length& default_value) const; Color color_or_fallback(CSS::PropertyID, Layout::NodeWithStyle const&, Color fallback) const; Optional text_anchor() const; Optional text_align() const; Optional text_justify() const; CSS::Length border_spacing_horizontal() const; CSS::Length border_spacing_vertical() const; Optional caption_side() const; CSS::Clip clip() const; CSS::Display display() const; Optional float_() const; Optional clear() const; struct ContentDataAndQuoteNestingLevel { CSS::ContentData content_data; u32 final_quote_nesting_level { 0 }; }; ContentDataAndQuoteNestingLevel content(u32 initial_quote_nesting_level) const; Optional cursor() const; Optional white_space() const; Optional line_style(CSS::PropertyID) const; Optional outline_style() const; Vector text_decoration_line() const; Optional text_decoration_style() const; Optional text_transform() const; Vector text_shadow(Layout::Node const&) const; Optional list_style_type() const; Optional list_style_position() const; Optional flex_direction() const; Optional flex_wrap() const; Optional flex_basis() const; float flex_grow() const; float flex_shrink() const; int order() const; Optional accent_color(Layout::NodeWithStyle const&) const; Optional align_content() const; Optional align_items() const; Optional align_self() const; Optional appearance() const; CSS::BackdropFilter backdrop_filter() const; float opacity() const; Optional visibility() const; Optional image_rendering() const; Optional justify_content() const; Optional justify_items() const; Optional justify_self() const; Optional overflow_x() const; Optional overflow_y() const; Vector box_shadow(Layout::Node const&) const; Optional box_sizing() const; Optional pointer_events() const; Variant vertical_align() const; Optional font_variant() const; CSS::GridTrackSizeList grid_auto_columns() const; CSS::GridTrackSizeList grid_auto_rows() const; CSS::GridTrackSizeList grid_template_columns() const; CSS::GridTrackSizeList grid_template_rows() const; [[nodiscard]] CSS::GridAutoFlow grid_auto_flow() const; CSS::GridTrackPlacement grid_column_end() const; CSS::GridTrackPlacement grid_column_start() const; CSS::GridTrackPlacement grid_row_end() const; CSS::GridTrackPlacement grid_row_start() const; Optional border_collapse() const; Vector> grid_template_areas() const; String grid_area() const; Optional object_fit() const; CSS::ObjectPosition object_position() const; Optional table_layout() const; static Vector transformations_for_style_value(StyleValue const& value); Vector transformations() const; Optional transform_box() const; CSS::TransformOrigin transform_origin() const; Optional mask_type() const; Color stop_color() const; float stop_opacity() const; float fill_opacity() const; float stroke_opacity() const; Optional fill_rule() const; Gfx::Font const& first_available_computed_font() const { return m_font_list->first(); } Gfx::FontCascadeList const& computed_font_list() const { VERIFY(m_font_list); return *m_font_list; } void set_computed_font_list(NonnullRefPtr font_list) const { m_font_list = move(font_list); } [[nodiscard]] CSSPixels compute_line_height(CSSPixelRect const& viewport_rect, Length::FontMetrics const& font_metrics, Length::FontMetrics const& root_font_metrics) const; [[nodiscard]] CSSPixels compute_line_height(Layout::Node const&) const; [[nodiscard]] CSSPixels line_height() const { return *m_line_height; } void set_line_height(Badge const&, CSSPixels line_height) { m_line_height = line_height; } bool operator==(StyleProperties const&) const; Optional position() const; Optional z_index() const; void set_math_depth(int math_depth); int math_depth() const { return m_math_depth; } QuotesData quotes() const; Optional scrollbar_width() const; static NonnullRefPtr font_fallback(bool monospace, bool bold); static float resolve_opacity_value(CSS::StyleValue const& value); private: friend class StyleComputer; PropertyValues m_property_values; HashMap> m_animated_property_values; Optional overflow(CSS::PropertyID) const; Vector shadow(CSS::PropertyID, Layout::Node const&) const; int m_math_depth { InitialValues::math_depth() }; mutable RefPtr m_font_list; Optional m_line_height; }; }