refactor: use icon button and popup
This commit is contained in:
parent
6b56500a52
commit
045f3976a5
3 changed files with 51 additions and 11 deletions
|
|
@ -15,3 +15,4 @@ slotmap = "1.0.6"
|
||||||
tokio = { version = "1.15.0", features = ["full"] }
|
tokio = { version = "1.15.0", features = ["full"] }
|
||||||
zbus = "2.0.1"
|
zbus = "2.0.1"
|
||||||
libcosmic-widgets = { git = "https://github.com/pop-os/libcosmic", branch = "lucy/widgets" }
|
libcosmic-widgets = { git = "https://github.com/pop-os/libcosmic", branch = "lucy/widgets" }
|
||||||
|
cosmic-panel-config = {git = "https://github.com/pop-os/cosmic-panel", features = ["gtk4"]}
|
||||||
|
|
@ -7,9 +7,10 @@ pub mod task;
|
||||||
pub mod ui;
|
pub mod ui;
|
||||||
pub mod widgets;
|
pub mod widgets;
|
||||||
|
|
||||||
use gtk4::{gio::ApplicationFlags, prelude::*, Orientation, Separator};
|
use gtk4::{glib, gio::ApplicationFlags, prelude::*, Orientation, Separator};
|
||||||
use once_cell::sync::Lazy;
|
use once_cell::sync::Lazy;
|
||||||
use tokio::runtime::Runtime;
|
use tokio::runtime::Runtime;
|
||||||
|
use cosmic_panel_config::config::CosmicPanelConfig;
|
||||||
|
|
||||||
static RT: Lazy<Runtime> = Lazy::new(|| Runtime::new().expect("failed to build tokio runtime"));
|
static RT: Lazy<Runtime> = Lazy::new(|| Runtime::new().expect("failed to build tokio runtime"));
|
||||||
|
|
||||||
|
|
@ -26,8 +27,9 @@ fn build_ui(application: >k4::Application) {
|
||||||
let window = gtk4::ApplicationWindow::builder()
|
let window = gtk4::ApplicationWindow::builder()
|
||||||
.application(application)
|
.application(application)
|
||||||
.title("COSMIC Network Applet")
|
.title("COSMIC Network Applet")
|
||||||
.default_width(400)
|
.default_width(1)
|
||||||
.default_height(300)
|
.default_height(1)
|
||||||
|
.decorated(false)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
view! {
|
view! {
|
||||||
|
|
@ -40,14 +42,44 @@ fn build_ui(application: >k4::Application) {
|
||||||
set_margin_end: 24
|
set_margin_end: 24
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ui::current_networks::add_current_networks(&main_box);
|
|
||||||
|
let config = CosmicPanelConfig::load_from_env().unwrap_or_default();
|
||||||
|
let popover = gtk4::builders::PopoverBuilder::new()
|
||||||
|
.autohide(true)
|
||||||
|
.has_arrow(false)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
let button = gtk4::Button::new();
|
||||||
|
button.add_css_class("panel_icon");
|
||||||
|
button.connect_clicked(glib::clone!(@weak popover => move |_| {
|
||||||
|
popover.show();
|
||||||
|
}));
|
||||||
|
|
||||||
|
// TODO cleanup
|
||||||
|
let image = gtk4::Image::from_icon_name("preferences-system-network");
|
||||||
|
image.add_css_class("panel_icon");
|
||||||
|
image.set_pixel_size(config.get_applet_icon_size().try_into().unwrap());
|
||||||
|
button.set_child(Some(&image));
|
||||||
|
|
||||||
|
view! {
|
||||||
|
icon_box = gtk4::Box {
|
||||||
|
set_orientation: Orientation::Vertical,
|
||||||
|
set_spacing: 0,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
popover.set_child(Some(&main_box));
|
||||||
|
|
||||||
|
icon_box.append(&button);
|
||||||
|
icon_box.append(&popover);
|
||||||
|
|
||||||
|
ui::current_networks::add_current_networks(&main_box, &image);
|
||||||
main_box.append(&Separator::new(Orientation::Horizontal));
|
main_box.append(&Separator::new(Orientation::Horizontal));
|
||||||
ui::toggles::add_toggles(&main_box);
|
ui::toggles::add_toggles(&main_box);
|
||||||
let available_wifi_separator = Separator::new(Orientation::Horizontal);
|
let available_wifi_separator = Separator::new(Orientation::Horizontal);
|
||||||
main_box.append(&available_wifi_separator);
|
main_box.append(&available_wifi_separator);
|
||||||
available_wifi_separator.hide();
|
available_wifi_separator.hide();
|
||||||
ui::available_wifi::add_available_wifi(&main_box, available_wifi_separator);
|
ui::available_wifi::add_available_wifi(&main_box, available_wifi_separator);
|
||||||
window.set_child(Some(&main_box));
|
window.set_child(Some(&icon_box));
|
||||||
|
|
||||||
window.show();
|
window.show();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -18,16 +18,16 @@ use gtk4::{
|
||||||
use std::{cell::RefCell, net::IpAddr, rc::Rc};
|
use std::{cell::RefCell, net::IpAddr, rc::Rc};
|
||||||
use zbus::Connection;
|
use zbus::Connection;
|
||||||
|
|
||||||
pub fn add_current_networks(target: >k4::Box) {
|
pub fn add_current_networks(target: >k4::Box, icon_image: >k4::Image) {
|
||||||
let networks_list = ListBox::builder().show_separators(true).build();
|
let networks_list = ListBox::builder().show_separators(true).build();
|
||||||
let entries = Rc::<RefCell<Vec<ListBoxRow>>>::default();
|
let entries = Rc::<RefCell<Vec<ListBoxRow>>>::default();
|
||||||
let (tx, rx) = MainContext::channel::<Vec<ActiveConnectionInfo>>(PRIORITY_DEFAULT);
|
let (tx, rx) = MainContext::channel::<Vec<ActiveConnectionInfo>>(PRIORITY_DEFAULT);
|
||||||
crate::task::spawn(handle_devices(tx));
|
crate::task::spawn(handle_devices(tx));
|
||||||
rx.attach(
|
rx.attach(
|
||||||
None,
|
None,
|
||||||
clone!(@weak networks_list, @strong entries => @default-return Continue(true), move |connections| {
|
clone!(@weak networks_list, @weak icon_image, @strong entries => @default-return Continue(true), move |connections| {
|
||||||
let mut entries = entries.borrow_mut();
|
let mut entries = entries.borrow_mut();
|
||||||
display_active_connections(connections, &networks_list, &mut *entries);
|
display_active_connections(connections, &networks_list, &mut *entries, &icon_image);
|
||||||
Continue(true)
|
Continue(true)
|
||||||
}),
|
}),
|
||||||
);
|
);
|
||||||
|
|
@ -38,6 +38,7 @@ fn display_active_connections(
|
||||||
connections: Vec<ActiveConnectionInfo>,
|
connections: Vec<ActiveConnectionInfo>,
|
||||||
target: &ListBox,
|
target: &ListBox,
|
||||||
entries: &mut Vec<ListBoxRow>,
|
entries: &mut Vec<ListBoxRow>,
|
||||||
|
icon_image: >k4::Image,
|
||||||
) {
|
) {
|
||||||
for old_entry in entries.drain(..) {
|
for old_entry in entries.drain(..) {
|
||||||
target.remove(&old_entry);
|
target.remove(&old_entry);
|
||||||
|
|
@ -49,7 +50,10 @@ fn display_active_connections(
|
||||||
hw_address,
|
hw_address,
|
||||||
speed,
|
speed,
|
||||||
ip_addresses,
|
ip_addresses,
|
||||||
} => render_wired_connection(name, speed, ip_addresses),
|
} => {
|
||||||
|
icon_image.set_icon_name(Some("network-wired-symbolic"));
|
||||||
|
render_wired_connection(name, speed, ip_addresses)
|
||||||
|
},
|
||||||
ActiveConnectionInfo::WiFi {
|
ActiveConnectionInfo::WiFi {
|
||||||
name,
|
name,
|
||||||
hw_address,
|
hw_address,
|
||||||
|
|
@ -57,7 +61,10 @@ fn display_active_connections(
|
||||||
rsn_flags,
|
rsn_flags,
|
||||||
wpa_flags,
|
wpa_flags,
|
||||||
} => continue,
|
} => continue,
|
||||||
ActiveConnectionInfo::Vpn { name, ip_addresses } => render_vpn(name, ip_addresses),
|
ActiveConnectionInfo::Vpn { name, ip_addresses } => {
|
||||||
|
icon_image.set_icon_name(Some("network-vpn-symbolic"));
|
||||||
|
render_vpn(name, ip_addresses)
|
||||||
|
},
|
||||||
};
|
};
|
||||||
let entry = ListBoxRow::builder().child(&entry).build();
|
let entry = ListBoxRow::builder().child(&entry).build();
|
||||||
target.append(&entry);
|
target.append(&entry);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue