diff options
| author | 2024-02-06 00:29:45 +0100 | |
|---|---|---|
| committer | 2024-02-06 00:29:45 +0100 | |
| commit | cb2c8dd86e1f2f0c1eec10d52ee717db6e6f34c2 (patch) | |
| tree | 8cb4297d26b5d53d0f6c0ddc43beef790f8c1b79 /widget | |
| parent | b5b267c31c59d4b80629f8c4ec38d395f8d99eae (diff) | |
| parent | 79b80fafb85386847c1d6338c306b842279b5821 (diff) | |
| download | iced-cb2c8dd86e1f2f0c1eec10d52ee717db6e6f34c2.tar.gz iced-cb2c8dd86e1f2f0c1eec10d52ee717db6e6f34c2.tar.bz2 iced-cb2c8dd86e1f2f0c1eec10d52ee717db6e6f34c2.zip | |
Merge pull request #2174 from hicaru/list_picker_events
List picker events
Diffstat (limited to 'widget')
| -rw-r--r-- | widget/src/helpers.rs | 1 | ||||
| -rw-r--r-- | widget/src/pick_list.rs | 48 | 
2 files changed, 40 insertions, 9 deletions
| diff --git a/widget/src/helpers.rs b/widget/src/helpers.rs index e13e900a..3f34d165 100644 --- a/widget/src/helpers.rs +++ b/widget/src/helpers.rs @@ -271,6 +271,7 @@ pub fn pick_list<'a, Message, Theme, Renderer, T>(  where      T: ToString + PartialEq + 'static,      [T]: ToOwned<Owned = Vec<T>>, +    Message: Clone,      Renderer: core::text::Renderer,      Theme: pick_list::StyleSheet          + scrollable::StyleSheet diff --git a/widget/src/pick_list.rs b/widget/src/pick_list.rs index 475115c2..840c94fa 100644 --- a/widget/src/pick_list.rs +++ b/widget/src/pick_list.rs @@ -34,7 +34,9 @@ pub struct PickList<      Theme: StyleSheet,      Renderer: text::Renderer,  { -    on_selected: Box<dyn Fn(T) -> Message + 'a>, +    on_select: Box<dyn Fn(T) -> Message + 'a>, +    on_open: Option<Message>, +    on_close: Option<Message>,      options: Cow<'a, [T]>,      placeholder: Option<String>,      selected: Option<T>, @@ -53,6 +55,7 @@ impl<'a, T: 'a, Message, Theme, Renderer>  where      T: ToString + PartialEq,      [T]: ToOwned<Owned = Vec<T>>, +    Message: Clone,      Theme: StyleSheet          + scrollable::StyleSheet          + menu::StyleSheet @@ -68,10 +71,12 @@ where      pub fn new(          options: impl Into<Cow<'a, [T]>>,          selected: Option<T>, -        on_selected: impl Fn(T) -> Message + 'a, +        on_select: impl Fn(T) -> Message + 'a,      ) -> Self {          Self { -            on_selected: Box::new(on_selected), +            on_select: Box::new(on_select), +            on_open: None, +            on_close: None,              options: options.into(),              placeholder: None,              selected, @@ -137,6 +142,18 @@ where          self      } +    /// Sets the message that will be produced when the [`PickList`] is opened. +    pub fn on_open(mut self, on_open: Message) -> Self { +        self.on_open = Some(on_open); +        self +    } + +    /// Sets the message that will be produced when the [`PickList`] is closed. +    pub fn on_close(mut self, on_close: Message) -> Self { +        self.on_close = Some(on_close); +        self +    } +      /// Sets the style of the [`PickList`].      pub fn style(          mut self, @@ -152,7 +169,7 @@ impl<'a, T: 'a, Message, Theme, Renderer> Widget<Message, Theme, Renderer>  where      T: Clone + ToString + PartialEq + 'static,      [T]: ToOwned<Owned = Vec<T>>, -    Message: 'a, +    Message: Clone + 'a,      Theme: StyleSheet          + scrollable::StyleSheet          + menu::StyleSheet @@ -212,7 +229,9 @@ where              layout,              cursor,              shell, -            self.on_selected.as_ref(), +            self.on_select.as_ref(), +            self.on_open.as_ref(), +            self.on_close.as_ref(),              self.selected.as_ref(),              &self.options,              || tree.state.downcast_mut::<State<Renderer::Paragraph>>(), @@ -278,7 +297,7 @@ where              self.text_shaping,              self.font.unwrap_or_else(|| renderer.default_font()),              &self.options, -            &self.on_selected, +            &self.on_select,              self.style.clone(),          )      } @@ -290,7 +309,7 @@ impl<'a, T: 'a, Message, Theme, Renderer>  where      T: Clone + ToString + PartialEq + 'static,      [T]: ToOwned<Owned = Vec<T>>, -    Message: 'a, +    Message: Clone + 'a,      Theme: StyleSheet          + scrollable::StyleSheet          + menu::StyleSheet @@ -473,7 +492,9 @@ pub fn update<'a, T, P, Message>(      layout: Layout<'_>,      cursor: mouse::Cursor,      shell: &mut Shell<'_, Message>, -    on_selected: &dyn Fn(T) -> Message, +    on_select: &dyn Fn(T) -> Message, +    on_open: Option<&Message>, +    on_close: Option<&Message>,      selected: Option<&T>,      options: &[T],      state: impl FnOnce() -> &'a mut State<P>, @@ -481,6 +502,7 @@ pub fn update<'a, T, P, Message>(  where      T: PartialEq + Clone + 'a,      P: text::Paragraph + 'a, +    Message: Clone,  {      match event {          Event::Mouse(mouse::Event::ButtonPressed(mouse::Button::Left)) @@ -492,12 +514,20 @@ where                  // bounds or on the drop-down, either way we close the overlay.                  state.is_open = false; +                if let Some(on_close) = on_close { +                    shell.publish(on_close.clone()); +                } +                  event::Status::Captured              } else if cursor.is_over(layout.bounds()) {                  state.is_open = true;                  state.hovered_option =                      options.iter().position(|option| Some(option) == selected); +                if let Some(on_open) = on_open { +                    shell.publish(on_open.clone()); +                } +                  event::Status::Captured              } else {                  event::Status::Ignored @@ -538,7 +568,7 @@ where                  };                  if let Some(next_option) = next_option { -                    shell.publish((on_selected)(next_option.clone())); +                    shell.publish((on_select)(next_option.clone()));                  }                  event::Status::Captured | 
