mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-23 08:00:20 +00:00
LibHTML: Detect link clicks
Clicking on a link in an HtmlView will now call on_link_click(String) if present, allowing you to implement basic hypertext navigation. :^)
This commit is contained in:
parent
b477aff843
commit
92aae72025
Notes:
sideshowbarker
2024-07-19 11:53:48 +09:00
Author: https://github.com/awesomekling Commit: https://github.com/SerenityOS/serenity/commit/92aae720255
2 changed files with 28 additions and 0 deletions
|
@ -103,3 +103,28 @@ void HtmlView::mousemove_event(GMouseEvent& event)
|
|||
update();
|
||||
event.accept();
|
||||
}
|
||||
|
||||
void HtmlView::mousedown_event(GMouseEvent& event)
|
||||
{
|
||||
if (!m_layout_root)
|
||||
return GScrollableWidget::mousemove_event(event);
|
||||
|
||||
bool hovered_node_changed = false;
|
||||
auto result = m_layout_root->hit_test(event.position());
|
||||
if (result.layout_node) {
|
||||
auto* node = result.layout_node->node();
|
||||
m_document->set_hovered_node(const_cast<Node*>(node));
|
||||
hovered_node_changed = node == m_document->hovered_node();
|
||||
if (node) {
|
||||
dbg() << "HtmlView: mousedown: " << node->tag_name() << "{" << node << "}";
|
||||
if (auto* link = node->enclosing_link_element()) {
|
||||
dbg() << "HtmlView: clicking on a link to " << link->href();
|
||||
if (on_link_click)
|
||||
on_link_click(link->href());
|
||||
}
|
||||
}
|
||||
}
|
||||
if (hovered_node_changed)
|
||||
update();
|
||||
event.accept();
|
||||
}
|
||||
|
|
|
@ -12,12 +12,15 @@ public:
|
|||
const Document* document() const { return m_document; }
|
||||
void set_document(Document*);
|
||||
|
||||
Function<void(const String&)> on_link_click;
|
||||
|
||||
protected:
|
||||
HtmlView(GWidget* parent = nullptr);
|
||||
|
||||
virtual void resize_event(GResizeEvent&) override;
|
||||
virtual void paint_event(GPaintEvent&) override;
|
||||
virtual void mousemove_event(GMouseEvent&) override;
|
||||
virtual void mousedown_event(GMouseEvent&) override;
|
||||
|
||||
private:
|
||||
void layout_and_sync_size();
|
||||
|
|
Loading…
Reference in a new issue