diff options
| author | 2023-07-12 12:23:18 -0700 | |
|---|---|---|
| committer | 2023-07-12 12:23:18 -0700 | |
| commit | 633f405f3f78bc7f82d2b2061491b0e011137451 (patch) | |
| tree | 5ebfc1f45d216a5c14a90492563599e6969eab4d /widget/src/text_input/editor.rs | |
| parent | 41836dd80d0534608e7aedfbf2319c540a23de1a (diff) | |
| parent | 21bd51426d900e271206f314e0c915dd41065521 (diff) | |
| download | iced-633f405f3f78bc7f82d2b2061491b0e011137451.tar.gz iced-633f405f3f78bc7f82d2b2061491b0e011137451.tar.bz2 iced-633f405f3f78bc7f82d2b2061491b0e011137451.zip | |
Merge remote-tracking branch 'origin/master' into feat/multi-window-support
# Conflicts:
#	Cargo.toml
#	core/src/window/icon.rs
#	core/src/window/id.rs
#	core/src/window/position.rs
#	core/src/window/settings.rs
#	examples/integration/src/main.rs
#	examples/integration_opengl/src/main.rs
#	glutin/src/application.rs
#	native/src/subscription.rs
#	native/src/window.rs
#	runtime/src/window/action.rs
#	src/lib.rs
#	src/window.rs
#	winit/Cargo.toml
#	winit/src/application.rs
#	winit/src/icon.rs
#	winit/src/settings.rs
#	winit/src/window.rs
Diffstat (limited to 'widget/src/text_input/editor.rs')
| -rw-r--r-- | widget/src/text_input/editor.rs | 70 | 
1 files changed, 70 insertions, 0 deletions
| diff --git a/widget/src/text_input/editor.rs b/widget/src/text_input/editor.rs new file mode 100644 index 00000000..f1fd641f --- /dev/null +++ b/widget/src/text_input/editor.rs @@ -0,0 +1,70 @@ +use crate::text_input::{Cursor, Value}; + +pub struct Editor<'a> { +    value: &'a mut Value, +    cursor: &'a mut Cursor, +} + +impl<'a> Editor<'a> { +    pub fn new(value: &'a mut Value, cursor: &'a mut Cursor) -> Editor<'a> { +        Editor { value, cursor } +    } + +    pub fn contents(&self) -> String { +        self.value.to_string() +    } + +    pub fn insert(&mut self, character: char) { +        if let Some((left, right)) = self.cursor.selection(self.value) { +            self.cursor.move_left(self.value); +            self.value.remove_many(left, right); +        } + +        self.value.insert(self.cursor.end(self.value), character); +        self.cursor.move_right(self.value); +    } + +    pub fn paste(&mut self, content: Value) { +        let length = content.len(); +        if let Some((left, right)) = self.cursor.selection(self.value) { +            self.cursor.move_left(self.value); +            self.value.remove_many(left, right); +        } + +        self.value.insert_many(self.cursor.end(self.value), content); + +        self.cursor.move_right_by_amount(self.value, length); +    } + +    pub fn backspace(&mut self) { +        match self.cursor.selection(self.value) { +            Some((start, end)) => { +                self.cursor.move_left(self.value); +                self.value.remove_many(start, end); +            } +            None => { +                let start = self.cursor.start(self.value); + +                if start > 0 { +                    self.cursor.move_left(self.value); +                    self.value.remove(start - 1); +                } +            } +        } +    } + +    pub fn delete(&mut self) { +        match self.cursor.selection(self.value) { +            Some(_) => { +                self.backspace(); +            } +            None => { +                let end = self.cursor.end(self.value); + +                if end < self.value.len() { +                    self.value.remove(end); +                } +            } +        } +    } +} | 
