2024-01-05 11:18:38 -07:00
|
|
|
// SPDX-License-Identifier: GPL-3.0-only
|
|
|
|
|
|
|
|
|
|
use cosmic::{
|
|
|
|
|
//TODO: export in cosmic::widget
|
|
|
|
|
iced::{
|
|
|
|
|
widget::{column, horizontal_rule},
|
|
|
|
|
Alignment, Background, Length,
|
|
|
|
|
},
|
|
|
|
|
theme,
|
|
|
|
|
widget::{self, segmented_button},
|
|
|
|
|
Element,
|
|
|
|
|
};
|
|
|
|
|
|
2024-01-09 15:42:42 -07:00
|
|
|
use crate::{fl, Action, Message};
|
2024-01-05 11:18:38 -07:00
|
|
|
|
|
|
|
|
macro_rules! menu_button {
|
|
|
|
|
($($x:expr),+ $(,)?) => (
|
|
|
|
|
widget::button(
|
|
|
|
|
widget::Row::with_children(
|
|
|
|
|
vec![$(Element::from($x)),+]
|
|
|
|
|
)
|
|
|
|
|
.align_items(Alignment::Center)
|
|
|
|
|
)
|
|
|
|
|
.height(Length::Fixed(32.0))
|
|
|
|
|
.padding([4, 16])
|
|
|
|
|
.width(Length::Fill)
|
|
|
|
|
.style(theme::Button::MenuItem)
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
pub fn context_menu<'a>(entity: segmented_button::Entity) -> Element<'a, Message> {
|
|
|
|
|
let menu_action = |label, action| {
|
|
|
|
|
menu_button!(widget::text(label)).on_press(Message::TabContextAction(entity, action))
|
|
|
|
|
};
|
|
|
|
|
|
2024-01-05 16:17:23 -07:00
|
|
|
//TODO: change items based on selection
|
2024-01-05 11:18:38 -07:00
|
|
|
widget::container(column!(
|
2024-01-05 12:33:54 -07:00
|
|
|
menu_action(fl!("new-file"), Action::NewFile),
|
|
|
|
|
menu_action(fl!("new-folder"), Action::NewFolder),
|
|
|
|
|
horizontal_rule(1),
|
2024-01-05 11:18:38 -07:00
|
|
|
menu_action(fl!("copy"), Action::Copy),
|
|
|
|
|
menu_action(fl!("paste"), Action::Paste),
|
|
|
|
|
menu_action(fl!("select-all"), Action::SelectAll),
|
|
|
|
|
horizontal_rule(1),
|
2024-01-05 16:17:23 -07:00
|
|
|
menu_action(fl!("move-to-trash"), Action::MoveToTrash),
|
|
|
|
|
horizontal_rule(1),
|
2024-01-05 14:44:20 -07:00
|
|
|
menu_action(fl!("properties"), Action::Properties),
|
2024-01-05 11:18:38 -07:00
|
|
|
))
|
|
|
|
|
.padding(1)
|
|
|
|
|
//TODO: move style to libcosmic
|
|
|
|
|
.style(theme::Container::custom(|theme| {
|
|
|
|
|
let cosmic = theme.cosmic();
|
|
|
|
|
let component = &cosmic.background.component;
|
|
|
|
|
widget::container::Appearance {
|
|
|
|
|
icon_color: Some(component.on.into()),
|
|
|
|
|
text_color: Some(component.on.into()),
|
|
|
|
|
background: Some(Background::Color(component.base.into())),
|
|
|
|
|
border_radius: 8.0.into(),
|
|
|
|
|
border_width: 1.0,
|
|
|
|
|
border_color: component.divider.into(),
|
|
|
|
|
}
|
|
|
|
|
}))
|
|
|
|
|
.width(Length::Fixed(240.0))
|
|
|
|
|
.into()
|
|
|
|
|
}
|