WIP navigation demo for subpages on Desktop page
This commit is contained in:
parent
0ad2ffe2d4
commit
aa7b66c925
3 changed files with 174 additions and 94 deletions
|
|
@ -10,7 +10,7 @@ use cosmic::{
|
||||||
iced_lazy::responsive,
|
iced_lazy::responsive,
|
||||||
iced_winit::window::{close, drag, toggle_maximize, minimize},
|
iced_winit::window::{close, drag, toggle_maximize, minimize},
|
||||||
theme::{self, Theme},
|
theme::{self, Theme},
|
||||||
widget::{button, nav_button, header_bar, settings, scrollable, toggler, spin_button::{SpinButtonModel, SpinMessage}},
|
widget::{button, icon, list, nav_bar, nav_button, header_bar, settings, scrollable, toggler, spin_button::{SpinButtonModel, SpinMessage}},
|
||||||
Element,
|
Element,
|
||||||
ElementExt,
|
ElementExt,
|
||||||
};
|
};
|
||||||
|
|
@ -19,12 +19,11 @@ use theme::Button as ButtonTheme;
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug, Default, Eq, PartialEq)]
|
#[derive(Clone, Copy, Debug, Default, Eq, PartialEq)]
|
||||||
pub enum Page {
|
pub enum Page {
|
||||||
//TODO: what should the default page be?
|
|
||||||
#[default]
|
|
||||||
Demo,
|
Demo,
|
||||||
WiFi,
|
WiFi,
|
||||||
Networking,
|
Networking,
|
||||||
Bluetooth,
|
Bluetooth,
|
||||||
|
#[default] //TODO: what should the default page be?
|
||||||
Desktop,
|
Desktop,
|
||||||
InputDevices,
|
InputDevices,
|
||||||
Displays,
|
Displays,
|
||||||
|
|
@ -93,6 +92,169 @@ pub enum Message {
|
||||||
SpinButton(SpinMessage)
|
SpinButton(SpinMessage)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl Window {
|
||||||
|
fn view_demo(&self) -> Element<Message> {
|
||||||
|
let choose_theme = [Theme::Light, Theme::Dark].iter().fold(
|
||||||
|
row![].spacing(10).align_items(Alignment::Center),
|
||||||
|
|row, theme| {
|
||||||
|
row.push(radio(
|
||||||
|
format!("{:?}", theme),
|
||||||
|
*theme,
|
||||||
|
Some(self.theme),
|
||||||
|
Message::ThemeChanged,
|
||||||
|
))
|
||||||
|
},
|
||||||
|
);
|
||||||
|
|
||||||
|
settings::view_column(vec![
|
||||||
|
text("Demo").size(32).into(),
|
||||||
|
settings::view_section("Debug")
|
||||||
|
.add(settings::item("Debug theme", choose_theme))
|
||||||
|
.add(settings::item(
|
||||||
|
"Debug layout",
|
||||||
|
toggler(String::from("Debug layout"), self.debug, Message::Debug)
|
||||||
|
))
|
||||||
|
.into(),
|
||||||
|
settings::view_section("Buttons")
|
||||||
|
.add(settings::item_row(vec![
|
||||||
|
button(ButtonTheme::Primary)
|
||||||
|
.text("Primary")
|
||||||
|
.on_press(Message::ButtonPressed)
|
||||||
|
.into(),
|
||||||
|
button(ButtonTheme::Secondary)
|
||||||
|
.text("Secondary")
|
||||||
|
.on_press(Message::ButtonPressed)
|
||||||
|
.into(),
|
||||||
|
button(ButtonTheme::Positive)
|
||||||
|
.text("Positive")
|
||||||
|
.on_press(Message::ButtonPressed)
|
||||||
|
.into(),
|
||||||
|
button(ButtonTheme::Destructive)
|
||||||
|
.text("Destructive")
|
||||||
|
.on_press(Message::ButtonPressed)
|
||||||
|
.into(),
|
||||||
|
button(ButtonTheme::Text)
|
||||||
|
.text("Text")
|
||||||
|
.on_press(Message::ButtonPressed)
|
||||||
|
.into()
|
||||||
|
]))
|
||||||
|
.add(settings::item_row(vec![
|
||||||
|
button(ButtonTheme::Primary).text("Primary").into(),
|
||||||
|
button(ButtonTheme::Secondary).text("Secondary").into(),
|
||||||
|
button(ButtonTheme::Positive).text("Positive").into(),
|
||||||
|
button(ButtonTheme::Destructive).text("Destructive").into(),
|
||||||
|
button(ButtonTheme::Text).text("Text").into(),
|
||||||
|
]))
|
||||||
|
.into(),
|
||||||
|
settings::view_section("Controls")
|
||||||
|
.add(settings::item("Toggler", toggler(None, self.toggler_value, Message::TogglerToggled)))
|
||||||
|
.add(settings::item(
|
||||||
|
"Pick List (TODO)",
|
||||||
|
pick_list(
|
||||||
|
vec!["Option 1", "Option 2", "Option 3", "Option 4",],
|
||||||
|
self.pick_list_selected,
|
||||||
|
Message::PickListSelected
|
||||||
|
)
|
||||||
|
.padding([8, 0, 8, 16])
|
||||||
|
))
|
||||||
|
.add(settings::item(
|
||||||
|
"Slider",
|
||||||
|
slider(0.0..=100.0, self.slider_value, Message::SliderChanged)
|
||||||
|
.width(Length::Units(250))
|
||||||
|
))
|
||||||
|
.add(settings::item(
|
||||||
|
"Progress",
|
||||||
|
progress_bar(0.0..=100.0, self.slider_value)
|
||||||
|
.width(Length::Units(250))
|
||||||
|
.height(Length::Units(4))
|
||||||
|
))
|
||||||
|
.add(settings::item_row(vec![
|
||||||
|
checkbox("Checkbox", self.checkbox_value, Message::CheckboxToggled).into()
|
||||||
|
]))
|
||||||
|
.add(settings::item(
|
||||||
|
format!("Spin Button (Range {}:{})", self.spin_button.min, self.spin_button.max),
|
||||||
|
self.spin_button.view(Message::SpinButton),
|
||||||
|
))
|
||||||
|
.into()
|
||||||
|
])
|
||||||
|
.into()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn view_desktop(&self) -> Element<Message> {
|
||||||
|
settings::view_column(vec![
|
||||||
|
text("Desktop").size(32).into(),
|
||||||
|
|
||||||
|
//TODO: simplify these buttons!
|
||||||
|
|
||||||
|
container(settings::item_row(vec![
|
||||||
|
icon("video-display-symbolic", 16).style(theme::Svg::Symbolic).into(),
|
||||||
|
column!(
|
||||||
|
text("Desktop Options").size(16),
|
||||||
|
text("Super Key action, hot corners, window control options.").size(12),
|
||||||
|
).into(),
|
||||||
|
horizontal_space(iced::Length::Fill).into(),
|
||||||
|
icon("go-next-symbolic", 16).style(theme::Svg::Symbolic).into(),
|
||||||
|
]).spacing(16))
|
||||||
|
.padding([20, 32])
|
||||||
|
.style(theme::Container::Custom(list::column::style))
|
||||||
|
.into(),
|
||||||
|
|
||||||
|
container(settings::item_row(vec![
|
||||||
|
icon("preferences-desktop-wallpaper-symbolic", 16).style(theme::Svg::Symbolic).into(),
|
||||||
|
column!(
|
||||||
|
text("Wallpaper").size(16),
|
||||||
|
text("Background images, colors, and slideshow options.").size(12),
|
||||||
|
).into(),
|
||||||
|
horizontal_space(iced::Length::Fill).into(),
|
||||||
|
icon("go-next-symbolic", 16).style(theme::Svg::Symbolic).into(),
|
||||||
|
]).spacing(16))
|
||||||
|
.padding([20, 32])
|
||||||
|
.style(theme::Container::Custom(list::column::style))
|
||||||
|
.into(),
|
||||||
|
|
||||||
|
container(settings::item_row(vec![
|
||||||
|
icon("preferences-pop-desktop-appearance-symbolic", 16).style(theme::Svg::Symbolic).into(),
|
||||||
|
column!(
|
||||||
|
text("Appearance").size(16),
|
||||||
|
text("Accent colors and COSMIC theming").size(12),
|
||||||
|
).into(),
|
||||||
|
horizontal_space(iced::Length::Fill).into(),
|
||||||
|
icon("go-next-symbolic", 16).style(theme::Svg::Symbolic).into(),
|
||||||
|
]).spacing(16))
|
||||||
|
.padding([20, 32])
|
||||||
|
.style(theme::Container::Custom(list::column::style))
|
||||||
|
.into(),
|
||||||
|
|
||||||
|
container(settings::item_row(vec![
|
||||||
|
icon("preferences-pop-desktop-dock-symbolic", 16).style(theme::Svg::Symbolic).into(),
|
||||||
|
column!(
|
||||||
|
text("Dock & Top Panel").size(16),
|
||||||
|
text("Customize size, positions, and more for Dock and Top Panel.").size(12),
|
||||||
|
).into(),
|
||||||
|
horizontal_space(iced::Length::Fill).into(),
|
||||||
|
icon("go-next-symbolic", 16).style(theme::Svg::Symbolic).into(),
|
||||||
|
]).spacing(16))
|
||||||
|
.padding([20, 32])
|
||||||
|
.style(theme::Container::Custom(list::column::style))
|
||||||
|
.into(),
|
||||||
|
|
||||||
|
container(settings::item_row(vec![
|
||||||
|
icon("preferences-pop-desktop-workspaces-symbolic", 16).style(theme::Svg::Symbolic).into(),
|
||||||
|
column!(
|
||||||
|
text("Workspaces").size(16),
|
||||||
|
text("Set workspace number, behavior, and placement.").size(12),
|
||||||
|
).into(),
|
||||||
|
horizontal_space(iced::Length::Fill).into(),
|
||||||
|
icon("go-next-symbolic", 16).style(theme::Svg::Symbolic).into(),
|
||||||
|
]).spacing(16))
|
||||||
|
.padding([20, 32])
|
||||||
|
.style(theme::Container::Custom(list::column::style))
|
||||||
|
.into(),
|
||||||
|
])
|
||||||
|
.into()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl Application for Window {
|
impl Application for Window {
|
||||||
type Executor = iced::executor::Default;
|
type Executor = iced::executor::Default;
|
||||||
type Flags = ();
|
type Flags = ();
|
||||||
|
|
@ -171,7 +333,7 @@ impl Application for Window {
|
||||||
let content = responsive(|size| {
|
let content = responsive(|size| {
|
||||||
let condensed = size.width < 900.0;
|
let condensed = size.width < 900.0;
|
||||||
|
|
||||||
let sidebar: Element<_> = iced::widget::container(scrollable(iced::widget::column!(
|
let sidebar: Element<_> = container(scrollable(column!(
|
||||||
cosmic::nav_button!("document-properties-symbolic", "Demo", condensed, self.page == Page::Demo)
|
cosmic::nav_button!("document-properties-symbolic", "Demo", condensed, self.page == Page::Demo)
|
||||||
.on_press(Message::Page(Page::Demo)),
|
.on_press(Message::Page(Page::Demo)),
|
||||||
cosmic::nav_button!("network-wireless-symbolic", "Wi-Fi", condensed, self.page == Page::WiFi)
|
cosmic::nav_button!("network-wireless-symbolic", "Wi-Fi", condensed, self.page == Page::WiFi)
|
||||||
|
|
@ -180,7 +342,7 @@ impl Application for Window {
|
||||||
.on_press(Message::Page(Page::Networking)),
|
.on_press(Message::Page(Page::Networking)),
|
||||||
cosmic::nav_button!("bluetooth-active-symbolic", "Bluetooth", condensed, self.page == Page::Bluetooth)
|
cosmic::nav_button!("bluetooth-active-symbolic", "Bluetooth", condensed, self.page == Page::Bluetooth)
|
||||||
.on_press(Message::Page(Page::Bluetooth)),
|
.on_press(Message::Page(Page::Bluetooth)),
|
||||||
cosmic::nav_button!("preferences-desktop-wallpaper-symbolic", "Desktop", condensed, self.page == Page::Desktop)
|
cosmic::nav_button!("video-display-symbolic", "Desktop", condensed, self.page == Page::Desktop)
|
||||||
.on_press(Message::Page(Page::Desktop)),
|
.on_press(Message::Page(Page::Desktop)),
|
||||||
cosmic::nav_button!("input-keyboard-symbolic", "Input Devices", condensed, self.page == Page::InputDevices)
|
cosmic::nav_button!("input-keyboard-symbolic", "Input Devices", condensed, self.page == Page::InputDevices)
|
||||||
.on_press(Message::Page(Page::InputDevices)),
|
.on_press(Message::Page(Page::InputDevices)),
|
||||||
|
|
@ -208,94 +370,12 @@ impl Application for Window {
|
||||||
.height(Length::Fill)
|
.height(Length::Fill)
|
||||||
.padding(11)
|
.padding(11)
|
||||||
.max_width(300)
|
.max_width(300)
|
||||||
.style(theme::Container::Custom(cosmic::widget::nav_bar::nav_bar_sections_style))
|
.style(theme::Container::Custom(nav_bar::nav_bar_sections_style))
|
||||||
.into();
|
.into();
|
||||||
|
|
||||||
let choose_theme = [Theme::Light, Theme::Dark].iter().fold(
|
|
||||||
row![].spacing(10).align_items(Alignment::Center),
|
|
||||||
|row, theme| {
|
|
||||||
row.push(radio(
|
|
||||||
format!("{:?}", theme),
|
|
||||||
*theme,
|
|
||||||
Some(self.theme),
|
|
||||||
Message::ThemeChanged,
|
|
||||||
))
|
|
||||||
},
|
|
||||||
);
|
|
||||||
|
|
||||||
let content: Element<_> = match self.page {
|
let content: Element<_> = match self.page {
|
||||||
Page::Demo => settings::view_column(vec![
|
Page::Demo => self.view_demo(),
|
||||||
text("Demo").size(32).into(),
|
Page::Desktop => self.view_desktop(),
|
||||||
settings::view_section("Debug")
|
|
||||||
.add(settings::item("Debug theme", choose_theme))
|
|
||||||
.add(settings::item(
|
|
||||||
"Debug layout",
|
|
||||||
toggler(String::from("Debug layout"), self.debug, Message::Debug)
|
|
||||||
))
|
|
||||||
.into(),
|
|
||||||
settings::view_section("Buttons")
|
|
||||||
.add(settings::item_row(vec![
|
|
||||||
button(ButtonTheme::Primary)
|
|
||||||
.text("Primary")
|
|
||||||
.on_press(Message::ButtonPressed)
|
|
||||||
.into(),
|
|
||||||
button(ButtonTheme::Secondary)
|
|
||||||
.text("Secondary")
|
|
||||||
.on_press(Message::ButtonPressed)
|
|
||||||
.into(),
|
|
||||||
button(ButtonTheme::Positive)
|
|
||||||
.text("Positive")
|
|
||||||
.on_press(Message::ButtonPressed)
|
|
||||||
.into(),
|
|
||||||
button(ButtonTheme::Destructive)
|
|
||||||
.text("Destructive")
|
|
||||||
.on_press(Message::ButtonPressed)
|
|
||||||
.into(),
|
|
||||||
button(ButtonTheme::Text)
|
|
||||||
.text("Text")
|
|
||||||
.on_press(Message::ButtonPressed)
|
|
||||||
.into()
|
|
||||||
]))
|
|
||||||
.add(settings::item_row(vec![
|
|
||||||
button(ButtonTheme::Primary).text("Primary").into(),
|
|
||||||
button(ButtonTheme::Secondary).text("Secondary").into(),
|
|
||||||
button(ButtonTheme::Positive).text("Positive").into(),
|
|
||||||
button(ButtonTheme::Destructive).text("Destructive").into(),
|
|
||||||
button(ButtonTheme::Text).text("Text").into(),
|
|
||||||
]))
|
|
||||||
.into(),
|
|
||||||
settings::view_section("Controls")
|
|
||||||
.add(settings::item("Toggler", toggler(None, self.toggler_value, Message::TogglerToggled)))
|
|
||||||
.add(settings::item(
|
|
||||||
"Pick List (TODO)",
|
|
||||||
pick_list(
|
|
||||||
vec!["Option 1", "Option 2", "Option 3", "Option 4",],
|
|
||||||
self.pick_list_selected,
|
|
||||||
Message::PickListSelected
|
|
||||||
)
|
|
||||||
.padding([8, 0, 8, 16])
|
|
||||||
))
|
|
||||||
.add(settings::item(
|
|
||||||
"Slider",
|
|
||||||
slider(0.0..=100.0, self.slider_value, Message::SliderChanged)
|
|
||||||
.width(Length::Units(250))
|
|
||||||
))
|
|
||||||
.add(settings::item(
|
|
||||||
"Progress",
|
|
||||||
progress_bar(0.0..=100.0, self.slider_value)
|
|
||||||
.width(Length::Units(250))
|
|
||||||
.height(Length::Units(4))
|
|
||||||
))
|
|
||||||
.add(settings::item_row(vec![
|
|
||||||
checkbox("Checkbox", self.checkbox_value, Message::CheckboxToggled).into()
|
|
||||||
]))
|
|
||||||
.add(settings::item(
|
|
||||||
format!("Spin Button (Range {}:{})", self.spin_button.min, self.spin_button.max),
|
|
||||||
self.spin_button.view(Message::SpinButton),
|
|
||||||
))
|
|
||||||
.into()
|
|
||||||
])
|
|
||||||
.into(),
|
|
||||||
_ => settings::view_column(vec![
|
_ => settings::view_column(vec![
|
||||||
text("Unimplemented page").into()
|
text("Unimplemented page").into()
|
||||||
]).into(),
|
]).into(),
|
||||||
|
|
|
||||||
|
|
@ -53,7 +53,7 @@ impl<'a, Message: 'static> From<ListColumn<'a, Message>> for Element<'a, Message
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn style(theme: &crate::Theme) -> iced::widget::container::Appearance {
|
pub fn style(theme: &crate::Theme) -> iced::widget::container::Appearance {
|
||||||
let cosmic = &theme.cosmic().primary;
|
let cosmic = &theme.cosmic().primary;
|
||||||
iced::widget::container::Appearance {
|
iced::widget::container::Appearance {
|
||||||
text_color: Some(cosmic.on.into()),
|
text_color: Some(cosmic.on.into()),
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,7 @@
|
||||||
// Copyright 2022 System76 <info@system76.com>
|
// Copyright 2022 System76 <info@system76.com>
|
||||||
// SPDX-License-Identifier: MPL-2.0
|
// SPDX-License-Identifier: MPL-2.0
|
||||||
|
|
||||||
mod column;
|
pub mod column;
|
||||||
// mod item;
|
// mod item;
|
||||||
|
|
||||||
pub use self::column::{ListColumn, list_column};
|
pub use self::column::{ListColumn, list_column};
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue