mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-07-29 04:09:13 +00:00
LibWeb: Start integrating the editing API with user keyboard input
This reworks EventHandler so text insertion, backspace, delete and return actions are now handled by the Editing API. This was the whole point of the execCommand spec, to provide an implementation of both editing commands and the expected editing behavior on user input. Responsibility of firing the `input` event is moved from EventHandler to the Editing API, which also gets rid of duplicate events whenever dealing with `<input>` or `<textarea>` events. The `beforeinput` event still needs to be fired by `EventHandler` however, since that is never fired by `execCommand()`.
This commit is contained in:
parent
564f5ca2cc
commit
ac46ec0b2e
Notes:
github-actions[bot]
2025-05-16 22:30:34 +00:00
Author: https://github.com/gmta
Commit: ac46ec0b2e
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/4779
9 changed files with 84 additions and 80 deletions
|
@ -226,7 +226,7 @@ public:
|
|||
|
||||
virtual void handle_insert(String const&) override;
|
||||
virtual void handle_delete(DeleteDirection) override;
|
||||
virtual EventResult handle_return_key() override;
|
||||
virtual EventResult handle_return_key(FlyString const& ui_input_type) override;
|
||||
virtual void select_all() override;
|
||||
virtual void set_selection_anchor(GC::Ref<DOM::Node>, size_t offset) override;
|
||||
virtual void set_selection_focus(GC::Ref<DOM::Node>, size_t offset) override;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue