menu: Add stack tab specific menu
This commit is contained in:
parent
58a024ba67
commit
75990ff056
10 changed files with 197 additions and 47 deletions
|
|
@ -121,6 +121,7 @@ pub struct Tab<Message: TabMessage> {
|
|||
font: Font,
|
||||
close_message: Option<Message>,
|
||||
press_message: Option<Message>,
|
||||
right_click_message: Option<Message>,
|
||||
rule_theme: TabRuleTheme,
|
||||
background_theme: TabBackgroundTheme,
|
||||
active: bool,
|
||||
|
|
@ -135,6 +136,7 @@ impl<Message: TabMessage> Tab<Message> {
|
|||
font: cosmic::font::FONT,
|
||||
close_message: None,
|
||||
press_message: None,
|
||||
right_click_message: None,
|
||||
rule_theme: TabRuleTheme::Default,
|
||||
background_theme: TabBackgroundTheme::Default,
|
||||
active: false,
|
||||
|
|
@ -146,6 +148,11 @@ impl<Message: TabMessage> Tab<Message> {
|
|||
self
|
||||
}
|
||||
|
||||
pub fn on_right_click(mut self, message: Message) -> Self {
|
||||
self.right_click_message = Some(message);
|
||||
self
|
||||
}
|
||||
|
||||
pub fn on_close(mut self, message: Message) -> Self {
|
||||
self.close_message = Some(message);
|
||||
self
|
||||
|
|
@ -238,6 +245,7 @@ impl<Message: TabMessage> Tab<Message> {
|
|||
background: self.background_theme.into(),
|
||||
elements: items,
|
||||
press_message: self.press_message,
|
||||
right_click_message: self.right_click_message,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -256,6 +264,7 @@ pub(super) struct TabInternal<'a, Message: TabMessage, Renderer> {
|
|||
background: theme::Container,
|
||||
elements: Vec<Element<'a, Message, Renderer>>,
|
||||
press_message: Option<Message>,
|
||||
right_click_message: Option<Message>,
|
||||
}
|
||||
|
||||
impl<'a, Message, Renderer> Widget<Message, Renderer> for TabInternal<'a, Message, Renderer>
|
||||
|
|
@ -382,6 +391,15 @@ where
|
|||
return event::Status::Captured;
|
||||
}
|
||||
}
|
||||
if matches!(
|
||||
event,
|
||||
event::Event::Mouse(mouse::Event::ButtonPressed(mouse::Button::Right))
|
||||
) {
|
||||
if let Some(message) = self.right_click_message.clone() {
|
||||
shell.publish(message);
|
||||
return event::Status::Captured;
|
||||
}
|
||||
}
|
||||
if matches!(
|
||||
event,
|
||||
event::Event::Mouse(mouse::Event::ButtonReleased(mouse::Button::Left))
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue