Use more menu theming from libcosmic

This commit is contained in:
Jeremy Soller 2023-10-26 11:25:14 -06:00
parent 49dcb4a84e
commit a472b47ee3
No known key found for this signature in database
GPG key ID: DCFCA852D3906975
4 changed files with 37 additions and 26 deletions

27
Cargo.lock generated
View file

@ -839,6 +839,7 @@ dependencies = [
[[package]]
name = "cosmic-config"
version = "0.1.0"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"atomicwrites",
"cosmic-config-derive",
@ -852,6 +853,7 @@ dependencies = [
[[package]]
name = "cosmic-config-derive"
version = "0.1.0"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"quote",
"syn 1.0.109",
@ -914,6 +916,7 @@ dependencies = [
[[package]]
name = "cosmic-theme"
version = "0.1.0"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"almost",
"cosmic-config",
@ -2044,6 +2047,7 @@ checksum = "9a3a5bfb195931eeb336b2a7b4d761daec841b97f947d34394601737a7bba5e4"
[[package]]
name = "iced"
version = "0.10.0"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"iced_accessibility",
"iced_core",
@ -2059,6 +2063,7 @@ dependencies = [
[[package]]
name = "iced_accessibility"
version = "0.1.0"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"accesskit",
"accesskit_unix",
@ -2068,6 +2073,7 @@ dependencies = [
[[package]]
name = "iced_core"
version = "0.10.0"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"bitflags 1.3.2",
"iced_accessibility",
@ -2082,6 +2088,7 @@ dependencies = [
[[package]]
name = "iced_futures"
version = "0.7.0"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"futures",
"iced_core",
@ -2093,6 +2100,7 @@ dependencies = [
[[package]]
name = "iced_graphics"
version = "0.9.0"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"bitflags 1.3.2",
"bytemuck",
@ -2110,6 +2118,7 @@ dependencies = [
[[package]]
name = "iced_renderer"
version = "0.1.0"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"iced_graphics",
"iced_tiny_skia",
@ -2122,6 +2131,7 @@ dependencies = [
[[package]]
name = "iced_runtime"
version = "0.1.1"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"iced_accessibility",
"iced_core",
@ -2133,6 +2143,7 @@ dependencies = [
[[package]]
name = "iced_sctk"
version = "0.1.0"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"enum-repr",
"float-cmp",
@ -2156,6 +2167,7 @@ dependencies = [
[[package]]
name = "iced_style"
version = "0.9.0"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"iced_core",
"once_cell",
@ -2165,6 +2177,7 @@ dependencies = [
[[package]]
name = "iced_tiny_skia"
version = "0.1.0"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"bytemuck",
"cosmic-text 0.9.0",
@ -2182,6 +2195,7 @@ dependencies = [
[[package]]
name = "iced_wgpu"
version = "0.11.1"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"bitflags 1.3.2",
"bytemuck",
@ -2203,6 +2217,7 @@ dependencies = [
[[package]]
name = "iced_widget"
version = "0.1.3"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"iced_renderer",
"iced_runtime",
@ -2217,6 +2232,7 @@ dependencies = [
[[package]]
name = "iced_winit"
version = "0.10.0"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"iced_graphics",
"iced_runtime",
@ -2463,6 +2479,7 @@ checksum = "a08173bc88b7955d1b3145aa561539096c421ac8debde8cbc3612ec635fee29b"
[[package]]
name = "libcosmic"
version = "0.1.0"
source = "git+https://github.com/pop-os/libcosmic?branch=menu#496bebbf985f81b0fa25fbf6d24cbb1cfbb9437f"
dependencies = [
"apply",
"ashpd",
@ -4531,14 +4548,14 @@ checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20"
[[package]]
name = "toml"
version = "0.8.4"
version = "0.8.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "2ef75d881185fd2df4a040793927c153d863651108a93c7e17a9e591baa95cc6"
checksum = "3efaf127c78d5339cc547cce4e4d973bd5e4f56e949a06d091c082ebeef2f800"
dependencies = [
"serde",
"serde_spanned",
"toml_datetime",
"toml_edit 0.20.4",
"toml_edit 0.20.5",
]
[[package]]
@ -4563,9 +4580,9 @@ dependencies = [
[[package]]
name = "toml_edit"
version = "0.20.4"
version = "0.20.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "380f9e8120405471f7c9ad1860a713ef5ece6a670c7eae39225e477340f32fc4"
checksum = "782bf6c2ddf761c1e7855405e8975472acf76f7f36d0d4328bd3b7a2fae12a85"
dependencies = [
"indexmap 2.0.2",
"serde",

View file

@ -19,9 +19,10 @@ features = ["syntect", "vi"]
#path = "../cosmic-text"
[dependencies.libcosmic]
#git = "https://github.com/pop-os/libcosmic"
git = "https://github.com/pop-os/libcosmic"
branch = "menu"
default-features = false
path = "../libcosmic"
#path = "../libcosmic"
[features]
default = ["wayland"]

View file

@ -3,10 +3,7 @@
use cosmic::{
app::{message, Command, Core, Settings},
executor,
iced::{
widget::{column, text},
Length, Limits,
},
iced::{widget::text, Length, Limits},
widget::{self, icon, segmented_button, view_switcher},
ApplicationExt, Element,
};
@ -230,9 +227,11 @@ impl cosmic::Application for App {
Command::none()
}
fn view(&self) -> Element<Message> {
let menu_bar = menu_bar();
fn header_start(&self) -> Vec<Element<Message>> {
vec![menu_bar()]
}
fn view(&self) -> Element<Message> {
let mut tab_column = widget::column::with_capacity(3).padding([0, 16]);
tab_column = tab_column.push(
@ -287,7 +286,7 @@ impl cosmic::Application for App {
}
project_row = project_row.push(tab_column);
let content: Element<_> = column![menu_bar, project_row].into();
let content: Element<_> = project_row.into();
// Uncomment to debug layout:
//content.explain(cosmic::iced::Color::WHITE)

View file

@ -5,9 +5,8 @@ use cosmic::{
iced::{widget::horizontal_rule, Alignment, Length},
theme,
widget::{
self, button, horizontal_space,
self, horizontal_space,
menu::{ItemHeight, ItemWidth, MenuBar, MenuTree},
text,
},
Element,
};
@ -17,14 +16,14 @@ use crate::Message;
pub fn menu_bar<'a>() -> Element<'a, Message> {
//TODO: port to libcosmic
let menu_root = |label| {
button(label)
widget::button(label)
.padding([4, 12])
.style(theme::Button::MenuRoot)
};
macro_rules! menu_button {
($($x:expr),+ $(,)?) => (
button(
widget::button(
widget::Row::with_children(
vec![$(Element::from($x)),+]
)
@ -37,14 +36,12 @@ pub fn menu_bar<'a>() -> Element<'a, Message> {
);
}
let menu_folder = |label| menu_button!(text(label), horizontal_space(Length::Fill), text(">"));
let menu_folder = |label| menu_button!(label, horizontal_space(Length::Fill), ">");
let menu_item = |label, message| MenuTree::new(menu_button!(text(label)).on_press(message));
let menu_item = |label, message| MenuTree::new(menu_button!(label).on_press(message));
let menu_key = |label, key, message| {
MenuTree::new(
menu_button!(text(label), horizontal_space(Length::Fill), text(key)).on_press(message),
)
MenuTree::new(menu_button!(label, horizontal_space(Length::Fill), key).on_press(message))
};
MenuBar::new(vec![
@ -120,11 +117,8 @@ pub fn menu_bar<'a>() -> Element<'a, Message> {
],
),
])
.cross_offset(0)
.item_height(ItemHeight::Dynamic(40))
.item_width(ItemWidth::Uniform(240))
.main_offset(0)
.padding(8)
.spacing(4.0)
.into()
}