diff options
| author | 2021-07-20 21:44:33 +0700 | |
|---|---|---|
| committer | 2021-07-20 21:44:33 +0700 | |
| commit | 8e29709b69ec0eae211887c8c6d91558175997b5 (patch) | |
| tree | c6fe2b40d4be34867e61b9061d27ae44916ad4ab /native | |
| parent | a6dbaf0f5fd3590a8cfe92f924184c5d78e00152 (diff) | |
| parent | 82db3c78b6cfa2cc55ece6ffa46811bfb5195f60 (diff) | |
| download | iced-8e29709b69ec0eae211887c8c6d91558175997b5.tar.gz iced-8e29709b69ec0eae211887c8c6d91558175997b5.tar.bz2 iced-8e29709b69ec0eae211887c8c6d91558175997b5.zip | |
Merge pull request #945 from derezzedex/menu
feat: add menus
Diffstat (limited to '')
| -rw-r--r-- | native/src/lib.rs | 4 | ||||
| -rw-r--r-- | native/src/program.rs | 2 | ||||
| -rw-r--r-- | native/src/widget/text_input.rs | 35 | 
3 files changed, 16 insertions, 25 deletions
| diff --git a/native/src/lib.rs b/native/src/lib.rs index cd214e36..cbb02506 100644 --- a/native/src/lib.rs +++ b/native/src/lib.rs @@ -61,8 +61,8 @@ mod debug;  mod debug;  pub use iced_core::{ -    Align, Background, Color, Font, HorizontalAlignment, Length, Padding, -    Point, Rectangle, Size, Vector, VerticalAlignment, +    menu, Align, Background, Color, Font, HorizontalAlignment, Length, Menu, +    Padding, Point, Rectangle, Size, Vector, VerticalAlignment,  };  pub use iced_futures::{executor, futures, Command}; diff --git a/native/src/program.rs b/native/src/program.rs index 066c29d8..75fab094 100644 --- a/native/src/program.rs +++ b/native/src/program.rs @@ -11,7 +11,7 @@ pub trait Program: Sized {      type Renderer: Renderer;      /// The type of __messages__ your [`Program`] will produce. -    type Message: std::fmt::Debug + Send; +    type Message: std::fmt::Debug + Clone + Send;      /// The type of [`Clipboard`] your [`Program`] will use.      type Clipboard: Clipboard; diff --git a/native/src/widget/text_input.rs b/native/src/widget/text_input.rs index 20117fa0..f06f057b 100644 --- a/native/src/widget/text_input.rs +++ b/native/src/widget/text_input.rs @@ -362,7 +362,7 @@ where              Event::Keyboard(keyboard::Event::CharacterReceived(c))                  if self.state.is_focused                      && self.state.is_pasting.is_none() -                    && !self.state.keyboard_modifiers.is_command_pressed() +                    && !self.state.keyboard_modifiers.command()                      && !c.is_control() =>              {                  let mut editor = @@ -450,7 +450,7 @@ where                          if platform::is_jump_modifier_pressed(modifiers)                              && !self.is_secure                          { -                            if modifiers.shift { +                            if modifiers.shift() {                                  self.state                                      .cursor                                      .select_left_by_words(&self.value); @@ -459,7 +459,7 @@ where                                      .cursor                                      .move_left_by_words(&self.value);                              } -                        } else if modifiers.shift { +                        } else if modifiers.shift() {                              self.state.cursor.select_left(&self.value)                          } else {                              self.state.cursor.move_left(&self.value); @@ -469,7 +469,7 @@ where                          if platform::is_jump_modifier_pressed(modifiers)                              && !self.is_secure                          { -                            if modifiers.shift { +                            if modifiers.shift() {                                  self.state                                      .cursor                                      .select_right_by_words(&self.value); @@ -478,14 +478,14 @@ where                                      .cursor                                      .move_right_by_words(&self.value);                              } -                        } else if modifiers.shift { +                        } else if modifiers.shift() {                              self.state.cursor.select_right(&self.value)                          } else {                              self.state.cursor.move_right(&self.value);                          }                      }                      keyboard::KeyCode::Home => { -                        if modifiers.shift { +                        if modifiers.shift() {                              self.state.cursor.select_range(                                  self.state.cursor.start(&self.value),                                  0, @@ -495,7 +495,7 @@ where                          }                      }                      keyboard::KeyCode::End => { -                        if modifiers.shift { +                        if modifiers.shift() {                              self.state.cursor.select_range(                                  self.state.cursor.start(&self.value),                                  self.value.len(), @@ -505,10 +505,7 @@ where                          }                      }                      keyboard::KeyCode::C -                        if self -                            .state -                            .keyboard_modifiers -                            .is_command_pressed() => +                        if self.state.keyboard_modifiers.command() =>                      {                          match self.state.cursor.selection(&self.value) {                              Some((start, end)) => { @@ -520,10 +517,7 @@ where                          }                      }                      keyboard::KeyCode::X -                        if self -                            .state -                            .keyboard_modifiers -                            .is_command_pressed() => +                        if self.state.keyboard_modifiers.command() =>                      {                          match self.state.cursor.selection(&self.value) {                              Some((start, end)) => { @@ -545,7 +539,7 @@ where                          messages.push(message);                      }                      keyboard::KeyCode::V => { -                        if self.state.keyboard_modifiers.is_command_pressed() { +                        if self.state.keyboard_modifiers.command() {                              let content = match self.state.is_pasting.take() {                                  Some(content) => content,                                  None => { @@ -576,10 +570,7 @@ where                          }                      }                      keyboard::KeyCode::A -                        if self -                            .state -                            .keyboard_modifiers -                            .is_command_pressed() => +                        if self.state.keyboard_modifiers.command() =>                      {                          self.state.cursor.select_all(&self.value);                      } @@ -858,9 +849,9 @@ mod platform {      pub fn is_jump_modifier_pressed(modifiers: keyboard::Modifiers) -> bool {          if cfg!(target_os = "macos") { -            modifiers.alt +            modifiers.alt()          } else { -            modifiers.control +            modifiers.control()          }      }  } | 
