feat: load & watch cosmic.css

This commit is contained in:
Ashley Wulber 2022-08-17 19:20:05 -04:00
parent 8485b82e9e
commit aaffa76b98
No known key found for this signature in database
GPG key ID: 5216D4F46A90A820
3 changed files with 63 additions and 22 deletions

View file

@ -10,28 +10,42 @@ pub mod x;
pub use libcosmic_widgets as widgets;
use adw::StyleManager;
use gtk4::{gdk, gio::{self, FileMonitorFlags, FileMonitorEvent, FileMonitor}, glib, prelude::*};
use gtk4::{
gdk,
gio::{self, FileMonitor, FileMonitorEvent, FileMonitorFlags},
glib,
prelude::*,
};
pub fn init() -> Option<FileMonitor> {
pub fn init() -> (Option<FileMonitor>, Option<FileMonitor>) {
let _ = gtk4::init();
adw::init();
let user_provider = gtk4::CssProvider::new();
let gtk_user_provider = gtk4::CssProvider::new();
if let Some(display) = gdk::Display::default() {
gtk4::StyleContext::add_provider_for_display(
&display,
&user_provider,
&gtk_user_provider,
gtk4::STYLE_PROVIDER_PRIORITY_USER,
);
}
let cosmic_user_provider = gtk4::CssProvider::new();
if let Some(display) = gdk::Display::default() {
gtk4::StyleContext::add_provider_for_display(
&display,
&cosmic_user_provider,
gtk4::STYLE_PROVIDER_PRIORITY_APPLICATION,
);
}
let path = xdg::BaseDirectories::with_prefix("gtk-4.0")
.ok()
.and_then(|xdg_dirs| xdg_dirs.find_config_file("gtk.css"))
.unwrap_or_else(|| "~/.config/gtk-4.0/gtk.css".into());
.ok()
.and_then(|xdg_dirs| xdg_dirs.find_config_file("gtk.css"))
.unwrap_or_else(|| "~/.config/gtk-4.0/gtk.css".into());
let file = gio::File::for_path(path);
if let Ok(monitor) = file.monitor(FileMonitorFlags::all(), None::<&gio::Cancellable>) {
monitor.connect_changed(glib::clone!(@strong user_provider => move |_monitor, file, _other_file, event| {
let gtk_css_monitor = file.monitor(FileMonitorFlags::all(), None::<&gio::Cancellable>).ok().map(|monitor| {
monitor.connect_changed(glib::clone!(@strong gtk_user_provider => move |_monitor, file, _other_file, event| {
match event {
FileMonitorEvent::Deleted | FileMonitorEvent::MovedOut | FileMonitorEvent::Renamed => {
if adw::is_initialized() {
@ -41,18 +55,46 @@ pub fn init() -> Option<FileMonitor> {
} else {
adw_user_colors_lib::colors::ColorOverrides::light_default().as_css()
};
user_provider
gtk_user_provider
.load_from_data(css.as_bytes());
}
},
FileMonitorEvent::ChangesDoneHint | FileMonitorEvent::Created | FileMonitorEvent::MovedIn => {
user_provider.load_from_file(file);
gtk_user_provider.load_from_file(file);
},
_ => {} // ignored
}
}));
Some(monitor)
} else {
None
}
}
monitor
});
let path = xdg::BaseDirectories::with_prefix("gtk-4.0")
.ok()
.and_then(|xdg_dirs| xdg_dirs.find_config_file("cosmic.css"))
.unwrap_or_else(|| "~/.config/gtk-4.0/cosmic.css".into());
let file = gio::File::for_path(path);
cosmic_user_provider.load_from_file(&file);
let cosmic_css_monitor = file.monitor(FileMonitorFlags::all(), None::<&gio::Cancellable>).ok().map(|monitor| {
monitor.connect_changed(glib::clone!(@strong cosmic_user_provider => move |_monitor, file, _other_file, event| {
match event {
FileMonitorEvent::Deleted | FileMonitorEvent::MovedOut | FileMonitorEvent::Renamed => {
if adw::is_initialized() {
let manager = StyleManager::default();
let css = if manager.is_dark() {
adw_user_colors_lib::colors::ColorOverrides::dark_default().as_css()
} else {
adw_user_colors_lib::colors::ColorOverrides::light_default().as_css()
};
cosmic_user_provider
.load_from_data(css.as_bytes());
}
},
FileMonitorEvent::ChangesDoneHint | FileMonitorEvent::Created | FileMonitorEvent::MovedIn => {
cosmic_user_provider.load_from_file(file);
},
_ => {} // ignored
}
}));
monitor
});
(gtk_css_monitor, cosmic_css_monitor)
}

View file

@ -55,9 +55,7 @@ impl CosmicWaylandDisplay {
}
let wayland_display = unsafe {
wayland_client::Display::from_external_display(
display.wl_display().c_ptr() as *mut _
)
wayland_client::Display::from_external_display(display.wl_display().c_ptr() as *mut _)
}; // XXX is this sound?
let mut event_queue = wayland_display.create_event_queue();
@ -176,8 +174,8 @@ impl ObjectImpl for LayerShellWindowInner {
fn signals() -> &'static [Signal] {
static SIGNALS: Lazy<Vec<Signal>> = Lazy::new(|| {
vec![Signal::builder("is-active-notify")
.param_types(&[bool::static_type().into()])
.build()]
.param_types(&[bool::static_type().into()])
.build()]
});
SIGNALS.as_ref()
}

View file

@ -1,6 +1,7 @@
use relm4::{
component::ComponentSenderInner,
gtk::{prelude::*, Align, Box as GtkBox, Label, Orientation, Widget},
ComponentParts, ComponentSender, SimpleComponent, component::ComponentSenderInner,
ComponentParts, ComponentSender, SimpleComponent,
};
use std::{cell::RefCell, sync::Arc};