diff options
author | 2024-07-08 01:25:41 +0200 | |
---|---|---|
committer | 2024-07-08 01:25:41 +0200 | |
commit | acf6daff46f8a0363a46f1957f481fa6625c7790 (patch) | |
tree | 22673d11b6878a19eda279ef24add1de11dc3d16 /graphics/src | |
parent | 23d9497e7ff54f48a4c07247d7f1f68270b510d2 (diff) | |
parent | 76f5bc2ccebb4c8b76ef81856c52da5b5e7c8960 (diff) | |
download | iced-acf6daff46f8a0363a46f1957f481fa6625c7790.tar.gz iced-acf6daff46f8a0363a46f1957f481fa6625c7790.tar.bz2 iced-acf6daff46f8a0363a46f1957f481fa6625c7790.zip |
Merge pull request #2321 from PgBiel/select-all
Add "Select All" functionality on Ctrl+A to TextEditor
Diffstat (limited to 'graphics/src')
-rw-r--r-- | graphics/src/text/editor.rs | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/graphics/src/text/editor.rs b/graphics/src/text/editor.rs index c488a51c..36b4ca6e 100644 --- a/graphics/src/text/editor.rs +++ b/graphics/src/text/editor.rs @@ -385,6 +385,27 @@ impl editor::Editor for Editor { })); } } + Action::SelectAll => { + let buffer = editor.buffer(); + if buffer.lines.len() > 1 + || buffer + .lines + .first() + .is_some_and(|line| !line.text().is_empty()) + { + let cursor = editor.cursor(); + editor.set_select_opt(Some(cosmic_text::Cursor { + line: 0, + index: 0, + ..cursor + })); + + editor.action( + font_system.raw(), + motion_to_action(Motion::DocumentEnd), + ); + } + } // Editing events Action::Edit(edit) => { |