Style improvements
This commit is contained in:
parent
276ecc7d6c
commit
df72ee5f05
2 changed files with 131 additions and 40 deletions
|
|
@ -1,16 +1,15 @@
|
|||
tile-windows = Tile Windows
|
||||
floating-window-exceptions = Floating Window Exceptions
|
||||
tile-windows = Automatically tile windows
|
||||
shortcuts = Shortcuts
|
||||
launcher = Launcher
|
||||
navigate-windows = Navigate Windows
|
||||
toggle-tiling = Toggle Tiling
|
||||
view-all = View All
|
||||
show-window-titles = Show Window Titles
|
||||
show-active-hint = Show Active Hint
|
||||
active-border-radius = Active Border Radius
|
||||
active-hint-color = Active Hint Color
|
||||
navigate-windows = Navigate windows
|
||||
move-window = Move window
|
||||
toggle-floating-window = Toggle floating window
|
||||
view-all-shortcuts = View all shortcuts...
|
||||
show-active-hint = Show active hint
|
||||
gaps = Gaps
|
||||
floating-window-exceptions = Floating window exceptions...
|
||||
window-management-settings = Window management settings...
|
||||
|
||||
// Commands
|
||||
super = Super
|
||||
arrow-keys = Arrow keys
|
||||
shift = Shift
|
||||
arrow-keys = arrows
|
||||
|
|
@ -1,11 +1,14 @@
|
|||
use crate::fl;
|
||||
use cosmic::app::Core;
|
||||
use cosmic::applet::button_theme;
|
||||
use cosmic::iced::wayland::popup::{destroy_popup, get_popup};
|
||||
use cosmic::iced::window::Id;
|
||||
use cosmic::iced::{Command, Length, Limits, Subscription};
|
||||
use cosmic::iced_core::{Alignment, Color};
|
||||
use cosmic::iced_style::application;
|
||||
use cosmic::iced_widget::row;
|
||||
use cosmic::widget::{column, container, divider, spin_button, text};
|
||||
use cosmic::widget::button::StyleSheet;
|
||||
use cosmic::widget::{button, container, spin_button, text};
|
||||
use cosmic::{Element, Theme};
|
||||
use cosmic_time::{anim, chain, id, Timeline};
|
||||
use once_cell::sync::Lazy;
|
||||
|
|
@ -37,6 +40,9 @@ pub enum Message {
|
|||
ToggleTileWindows(chain::Toggler, bool),
|
||||
ToggleShowActiveHint(chain::Toggler, bool),
|
||||
HandleGaps(spin_button::Message),
|
||||
ViewAllShortcuts,
|
||||
OpenFloatingWindowExceptions,
|
||||
OpenWindowManagementSettings,
|
||||
}
|
||||
|
||||
impl cosmic::Application for Window {
|
||||
|
|
@ -120,6 +126,9 @@ impl cosmic::Application for Window {
|
|||
self.gaps.update(spin_button::Message::Decrement)
|
||||
}
|
||||
},
|
||||
Message::ViewAllShortcuts => println!("View all shortcuts..."),
|
||||
Message::OpenFloatingWindowExceptions => println!("Floating window exceptions..."),
|
||||
Message::OpenWindowManagementSettings => println!("Window management settings..."),
|
||||
}
|
||||
Command::none()
|
||||
}
|
||||
|
|
@ -133,10 +142,10 @@ impl cosmic::Application for Window {
|
|||
}
|
||||
|
||||
fn view_window(&self, _id: Id) -> Element<Self::Message> {
|
||||
let content_list = cosmic::widget::column()
|
||||
.padding(20)
|
||||
.spacing(10)
|
||||
.push(
|
||||
let content_list = cosmic::widget::list_column()
|
||||
.padding(0)
|
||||
.spacing(5)
|
||||
.add(
|
||||
container(
|
||||
anim!(
|
||||
TILE_WINDOWS,
|
||||
|
|
@ -148,28 +157,49 @@ impl cosmic::Application for Window {
|
|||
.text_size(14)
|
||||
.width(Length::Fill),
|
||||
)
|
||||
.padding([0, 12]),
|
||||
.padding([0, 15, 5, 15]),
|
||||
)
|
||||
.push(divider::horizontal::light())
|
||||
.push(
|
||||
column()
|
||||
.push(row!(
|
||||
text(fl!("launcher")).size(14).width(Length::Fill),
|
||||
text(format!("{} + /", fl!("super"))).size(14),
|
||||
))
|
||||
.push(row!(
|
||||
text(fl!("navigate-windows")).size(14).width(Length::Fill),
|
||||
text(format!("{} + {}", fl!("super"), fl!("arrow-keys"))).size(14),
|
||||
))
|
||||
.push(row!(
|
||||
text(fl!("toggle-tiling")).size(14).width(Length::Fill),
|
||||
text(format!("{} + Y", fl!("super"))).size(14),
|
||||
))
|
||||
.spacing(10)
|
||||
.padding([0, 20, 0, 20]),
|
||||
.add(
|
||||
row!(
|
||||
text(fl!("navigate-windows")).size(14).width(Length::Fill),
|
||||
text(format!("{} + {}", fl!("super"), fl!("arrow-keys"))).size(14),
|
||||
)
|
||||
.padding([5, 15, 5, 15]),
|
||||
)
|
||||
.push(divider::horizontal::light())
|
||||
.push(
|
||||
.add(
|
||||
row!(
|
||||
text(fl!("move-window")).size(14).width(Length::Fill),
|
||||
text(format!(
|
||||
"{} + {} + {}",
|
||||
fl!("shift"),
|
||||
fl!("super"),
|
||||
fl!("arrow-keys")
|
||||
))
|
||||
.size(14),
|
||||
)
|
||||
.padding([5, 15, 5, 15]),
|
||||
)
|
||||
.add(
|
||||
row!(
|
||||
text(fl!("toggle-floating-window"))
|
||||
.size(14)
|
||||
.width(Length::Fill),
|
||||
text(format!("{} + G", fl!("super"))).size(14),
|
||||
)
|
||||
.padding([5, 15, 5, 15]),
|
||||
)
|
||||
.add(
|
||||
container(
|
||||
button(text(fl!("view-all-shortcuts")).size(14))
|
||||
.width(Length::Fill)
|
||||
.style(popup_button_style())
|
||||
.padding(10)
|
||||
.on_press(Message::ViewAllShortcuts),
|
||||
)
|
||||
.width(Length::Fill)
|
||||
.padding([0, 5, 0, 5]),
|
||||
)
|
||||
.add(
|
||||
container(
|
||||
anim!(
|
||||
SHOW_ACTIVE_HINTS,
|
||||
|
|
@ -181,20 +211,82 @@ impl cosmic::Application for Window {
|
|||
.text_size(14)
|
||||
.width(Length::Fill),
|
||||
)
|
||||
.padding([0, 12]),
|
||||
.padding([5, 15, 5, 15]),
|
||||
)
|
||||
.push(
|
||||
.add(
|
||||
row!(
|
||||
text(fl!("gaps")).size(14).width(Length::Fill),
|
||||
spin_button(self.gaps.value.to_string(), Message::HandleGaps),
|
||||
)
|
||||
.padding([0, 10, 0, 10]),
|
||||
.padding([0, 15, 0, 15])
|
||||
.align_items(Alignment::Center),
|
||||
)
|
||||
.add(
|
||||
container(
|
||||
button(text(fl!("floating-window-exceptions")).size(14))
|
||||
.width(Length::Fill)
|
||||
.padding(10)
|
||||
.style(popup_button_style())
|
||||
.on_press(Message::OpenFloatingWindowExceptions),
|
||||
)
|
||||
.width(Length::Fill)
|
||||
.padding([0, 5, 0, 5]),
|
||||
)
|
||||
.add(
|
||||
container(
|
||||
button(text(fl!("window-management-settings")).size(14))
|
||||
.width(Length::Fill)
|
||||
.padding(10)
|
||||
.style(popup_button_style())
|
||||
.on_press(Message::OpenWindowManagementSettings),
|
||||
)
|
||||
.width(Length::Fill)
|
||||
.padding([0, 5, 0, 5]),
|
||||
);
|
||||
|
||||
self.core.applet.popup_container(content_list).into()
|
||||
self.core
|
||||
.applet
|
||||
.popup_container(content_list)
|
||||
.padding(1)
|
||||
.style(popup_style())
|
||||
.into()
|
||||
}
|
||||
|
||||
fn style(&self) -> Option<<Theme as application::StyleSheet>::Style> {
|
||||
Some(cosmic::applet::style())
|
||||
}
|
||||
}
|
||||
|
||||
fn popup_button_style() -> cosmic::theme::Button {
|
||||
cosmic::theme::Button::Custom {
|
||||
active: Box::new(|active, t| cosmic::widget::button::Appearance {
|
||||
border_radius: 8.0.into(),
|
||||
..t.active(active, &cosmic::theme::Button::Icon)
|
||||
}),
|
||||
hovered: Box::new(|hovered, t| cosmic::widget::button::Appearance {
|
||||
border_radius: 8.0.into(),
|
||||
..t.hovered(hovered, &cosmic::theme::Button::Text)
|
||||
}),
|
||||
pressed: Box::new(|pressed, t| cosmic::widget::button::Appearance {
|
||||
border_radius: 8.0.into(),
|
||||
..t.pressed(pressed, &cosmic::theme::Button::Text)
|
||||
}),
|
||||
disabled: Box::new(|t| cosmic::widget::button::Appearance {
|
||||
border_radius: 8.0.into(),
|
||||
..t.disabled(&cosmic::theme::Button::Standard)
|
||||
}),
|
||||
}
|
||||
}
|
||||
|
||||
fn popup_style() -> cosmic::theme::Container {
|
||||
cosmic::theme::Container::Custom(Box::new(|theme| {
|
||||
cosmic::iced_style::container::Appearance {
|
||||
icon_color: Some(theme.cosmic().background.on.into()),
|
||||
text_color: Some(theme.cosmic().background.on.into()),
|
||||
background: Some(Color::from(theme.cosmic().background.base).into()),
|
||||
border_radius: 8.0.into(),
|
||||
border_width: 2.0,
|
||||
border_color: theme.cosmic().bg_divider().into(),
|
||||
}
|
||||
}))
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue