diff options
| author | 2021-05-25 16:34:17 +0700 | |
|---|---|---|
| committer | 2021-05-25 16:34:17 +0700 | |
| commit | e292821c3780fc5a57c835815efc7a232ce4dc32 (patch) | |
| tree | 8659fb678d989a2f97876b20aa501d5415af4b02 /examples/pane_grid | |
| parent | df971ac99beedb41537763f95f7b14d8bf7475a8 (diff) | |
| parent | d4c5f3ee950262c578c7b9b2a4aab60d3c5edaed (diff) | |
| download | iced-e292821c3780fc5a57c835815efc7a232ce4dc32.tar.gz iced-e292821c3780fc5a57c835815efc7a232ce4dc32.tar.bz2 iced-e292821c3780fc5a57c835815efc7a232ce4dc32.zip | |
Merge pull request #892 from clarkmoody/title-bar-events
PaneGrid Events in Title Bar Area
Diffstat (limited to 'examples/pane_grid')
| -rw-r--r-- | examples/pane_grid/src/main.rs | 106 | 
1 files changed, 93 insertions, 13 deletions
| diff --git a/examples/pane_grid/src/main.rs b/examples/pane_grid/src/main.rs index 4b87a568..81cf1770 100644 --- a/examples/pane_grid/src/main.rs +++ b/examples/pane_grid/src/main.rs @@ -11,7 +11,7 @@ pub fn main() -> iced::Result {  }  struct Example { -    panes: pane_grid::State<Content>, +    panes: pane_grid::State<Pane>,      panes_created: usize,      focus: Option<pane_grid::Pane>,  } @@ -24,6 +24,7 @@ enum Message {      Clicked(pane_grid::Pane),      Dragged(pane_grid::DragEvent),      Resized(pane_grid::ResizeEvent), +    TogglePin(pane_grid::Pane),      Close(pane_grid::Pane),      CloseFocused,  } @@ -34,7 +35,7 @@ impl Application for Example {      type Flags = ();      fn new(_flags: ()) -> (Self, Command<Message>) { -        let (panes, _) = pane_grid::State::new(Content::new(0)); +        let (panes, _) = pane_grid::State::new(Pane::new(0));          (              Example { @@ -60,7 +61,7 @@ impl Application for Example {                  let result = self.panes.split(                      axis,                      &pane, -                    Content::new(self.panes_created), +                    Pane::new(self.panes_created),                  );                  if let Some((pane, _)) = result { @@ -74,7 +75,7 @@ impl Application for Example {                      let result = self.panes.split(                          axis,                          &pane, -                        Content::new(self.panes_created), +                        Pane::new(self.panes_created),                      );                      if let Some((pane, _)) = result { @@ -106,6 +107,12 @@ impl Application for Example {                  self.panes.swap(&pane, &target);              }              Message::Dragged(_) => {} +            Message::TogglePin(pane) => { +                if let Some(Pane { is_pinned, .. }) = self.panes.get_mut(&pane) +                { +                    *is_pinned = !*is_pinned; +                } +            }              Message::Close(pane) => {                  if let Some((_, sibling)) = self.panes.close(&pane) {                      self.focus = Some(sibling); @@ -113,8 +120,14 @@ impl Application for Example {              }              Message::CloseFocused => {                  if let Some(pane) = self.focus { -                    if let Some((_, sibling)) = self.panes.close(&pane) { -                        self.focus = Some(sibling); +                    if let Some(Pane { is_pinned, .. }) = self.panes.get(&pane) +                    { +                        if !is_pinned { +                            if let Some((_, sibling)) = self.panes.close(&pane) +                            { +                                self.focus = Some(sibling); +                            } +                        }                      }                  }              } @@ -143,12 +156,20 @@ impl Application for Example {          let focus = self.focus;          let total_panes = self.panes.len(); -        let pane_grid = PaneGrid::new(&mut self.panes, |pane, content| { -            let is_focused = focus == Some(pane); +        let pane_grid = PaneGrid::new(&mut self.panes, |id, pane| { +            let is_focused = focus == Some(id); + +            let text = if pane.is_pinned { "Unpin" } else { "Pin" }; +            let pin_button = +                Button::new(&mut pane.pin_button, Text::new(text).size(14)) +                    .on_press(Message::TogglePin(id)) +                    .style(style::Button::Pin) +                    .padding(3);              let title = Row::with_children(vec