WIP NotificationPopover
This commit is contained in:
parent
3f9fd84737
commit
f3828f8239
3 changed files with 67 additions and 0 deletions
|
|
@ -3,6 +3,7 @@ use gtk4::{gdk, glib, prelude::*};
|
||||||
mod deref_cell;
|
mod deref_cell;
|
||||||
mod mpris;
|
mod mpris;
|
||||||
mod mpris_player;
|
mod mpris_player;
|
||||||
|
mod notification_popover;
|
||||||
mod notifications;
|
mod notifications;
|
||||||
mod popover_container;
|
mod popover_container;
|
||||||
mod status_area;
|
mod status_area;
|
||||||
|
|
|
||||||
57
src/notification_popover.rs
Normal file
57
src/notification_popover.rs
Normal file
|
|
@ -0,0 +1,57 @@
|
||||||
|
use cascade::cascade;
|
||||||
|
use gtk4::{
|
||||||
|
glib::{self, clone},
|
||||||
|
prelude::*,
|
||||||
|
subclass::prelude::*,
|
||||||
|
};
|
||||||
|
|
||||||
|
use crate::deref_cell::DerefCell;
|
||||||
|
|
||||||
|
#[derive(Default)]
|
||||||
|
pub struct NotificationPopoverInner {
|
||||||
|
label: DerefCell<gtk4::Label>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[glib::object_subclass]
|
||||||
|
impl ObjectSubclass for NotificationPopoverInner {
|
||||||
|
const NAME: &'static str = "S76NotificationPopover";
|
||||||
|
type ParentType = gtk4::Popover;
|
||||||
|
type Type = NotificationPopover;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ObjectImpl for NotificationPopoverInner {
|
||||||
|
fn constructed(&self, obj: &NotificationPopover) {
|
||||||
|
let label = cascade! {
|
||||||
|
gtk4::Label::new(None);
|
||||||
|
};
|
||||||
|
|
||||||
|
cascade! {
|
||||||
|
obj;
|
||||||
|
..set_autohide(false);
|
||||||
|
..set_has_arrow(false);
|
||||||
|
..set_offset(0, 12);
|
||||||
|
..set_child(Some(&label));
|
||||||
|
};
|
||||||
|
|
||||||
|
self.label.set(label);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl WidgetImpl for NotificationPopoverInner {}
|
||||||
|
impl PopoverImpl for NotificationPopoverInner {}
|
||||||
|
|
||||||
|
glib::wrapper! {
|
||||||
|
pub struct NotificationPopover(ObjectSubclass<NotificationPopoverInner>)
|
||||||
|
@extends gtk4::Popover, gtk4::Widget;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl NotificationPopover {
|
||||||
|
pub fn new() -> Self {
|
||||||
|
let obj = glib::Object::new::<Self>(&[]).unwrap();
|
||||||
|
obj
|
||||||
|
}
|
||||||
|
|
||||||
|
fn inner(&self) -> &NotificationPopoverInner {
|
||||||
|
NotificationPopoverInner::from_instance(self)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -8,6 +8,7 @@ use gtk4::{
|
||||||
|
|
||||||
use crate::deref_cell::DerefCell;
|
use crate::deref_cell::DerefCell;
|
||||||
use crate::mpris::MprisControls;
|
use crate::mpris::MprisControls;
|
||||||
|
use crate::notification_popover::NotificationPopover;
|
||||||
use crate::popover_container::PopoverContainer;
|
use crate::popover_container::PopoverContainer;
|
||||||
|
|
||||||
#[derive(Default)]
|
#[derive(Default)]
|
||||||
|
|
@ -15,6 +16,7 @@ pub struct TimeButtonInner {
|
||||||
calendar: DerefCell<gtk4::Calendar>,
|
calendar: DerefCell<gtk4::Calendar>,
|
||||||
button: DerefCell<gtk4::ToggleButton>,
|
button: DerefCell<gtk4::ToggleButton>,
|
||||||
label: DerefCell<gtk4::Label>,
|
label: DerefCell<gtk4::Label>,
|
||||||
|
notification_popover: DerefCell<NotificationPopover>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[glib::object_subclass]
|
#[glib::object_subclass]
|
||||||
|
|
@ -60,9 +62,15 @@ impl ObjectImpl for TimeButtonInner {
|
||||||
..popover().bind_property("visible", &button, "active").flags(glib::BindingFlags::BIDIRECTIONAL).build();
|
..popover().bind_property("visible", &button, "active").flags(glib::BindingFlags::BIDIRECTIONAL).build();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let notification_popover = cascade! {
|
||||||
|
NotificationPopover::new();
|
||||||
|
..set_parent(obj);
|
||||||
|
};
|
||||||
|
|
||||||
self.calendar.set(calendar);
|
self.calendar.set(calendar);
|
||||||
self.button.set(button);
|
self.button.set(button);
|
||||||
self.label.set(label);
|
self.label.set(label);
|
||||||
|
self.notification_popover.set(notification_popover);
|
||||||
|
|
||||||
// TODO: better way to do this?
|
// TODO: better way to do this?
|
||||||
glib::timeout_add_seconds_local(
|
glib::timeout_add_seconds_local(
|
||||||
|
|
@ -77,6 +85,7 @@ impl ObjectImpl for TimeButtonInner {
|
||||||
|
|
||||||
fn dispose(&self, _obj: &TimeButton) {
|
fn dispose(&self, _obj: &TimeButton) {
|
||||||
self.button.unparent();
|
self.button.unparent();
|
||||||
|
self.notification_popover.unparent();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue