/* * Copyright (c) 2022, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include namespace Web::Painting { class InlinePaintable final : public Paintable { JS_CELL(InlinePaintable, Paintable); public: static JS::NonnullGCPtr create(Layout::InlineNode const&); virtual void paint(PaintContext&, PaintPhase) const override; virtual void before_paint(PaintContext& context, PaintPhase) const override; virtual void after_paint(PaintContext& context, PaintPhase) const override; Layout::InlineNode const& layout_node() const; auto const& box_model() const { return layout_node().box_model(); } CSSPixelRect bounding_rect() const; Vector const& fragments() const { return m_fragments; } Vector& fragments() { return m_fragments; } virtual bool is_inline_paintable() const override { return true; } virtual TraversalDecision hit_test(CSSPixelPoint, HitTestType, Function const& callback) const override; void set_box_shadow_data(Vector&& box_shadow_data) { m_box_shadow_data = move(box_shadow_data); } Vector const& box_shadow_data() const { return m_box_shadow_data; } void set_outline_data(Optional outline_data) { m_outline_data = outline_data; } Optional const& outline_data() const { return m_outline_data; } void set_outline_offset(CSSPixels outline_offset) { m_outline_offset = outline_offset; } CSSPixels outline_offset() const { return m_outline_offset; } void set_enclosing_scroll_frame(RefPtr scroll_frame) { m_enclosing_scroll_frame = scroll_frame; } void set_enclosing_clip_frame(RefPtr clip_frame) { m_enclosing_clip_frame = clip_frame; } Optional scroll_frame_id() const; Optional enclosing_scroll_frame_offset() const; Optional clip_rect() const; private: InlinePaintable(Layout::InlineNode const&); template void for_each_fragment(Callback) const; Optional m_clip_rect; RefPtr m_enclosing_scroll_frame; RefPtr m_enclosing_clip_frame; Vector m_box_shadow_data; Optional m_outline_data; CSSPixels m_outline_offset { 0 }; Vector m_fragments; }; }