153 lines
4.8 KiB
Rust
153 lines
4.8 KiB
Rust
use gtk;
|
|
use gtk::prelude::*;
|
|
use gdk_pixbuf::Pixbuf;
|
|
|
|
use hammond_data::dbqueries;
|
|
use hammond_data::models::Podcast;
|
|
use hammond_data::index_feed::Database;
|
|
|
|
use widgets::podcast::*;
|
|
use static_resource;
|
|
|
|
fn show_empty_view(stack: >k::Stack) {
|
|
let builder = gtk::Builder::new_from_string(include_str!("../../gtk/empty_view.ui"));
|
|
let view: gtk::Box = builder.get_object("empty_view").unwrap();
|
|
stack.add_named(&view, "empty");
|
|
stack.set_visible_child_name("empty");
|
|
|
|
info!("Empty view.");
|
|
}
|
|
|
|
fn populate_flowbox(db: &Database, stack: >k::Stack, flowbox: >k::FlowBox) {
|
|
let podcasts = {
|
|
let db = db.lock().unwrap();
|
|
dbqueries::get_podcasts(&db)
|
|
};
|
|
|
|
if let Ok(pds) = podcasts {
|
|
pds.iter().for_each(|parent| {
|
|
let f = create_flowbox_child(db, parent);
|
|
flowbox.add(&f);
|
|
});
|
|
} else {
|
|
show_empty_view(stack);
|
|
}
|
|
flowbox.show_all();
|
|
}
|
|
|
|
fn create_flowbox_child(db: &Database, pd: &Podcast) -> gtk::FlowBoxChild {
|
|
let builder = gtk::Builder::new_from_string(include_str!("../../gtk/podcasts_child.ui"));
|
|
|
|
// Copy of gnome-music AlbumWidget
|
|
let box_: gtk::Box = builder.get_object("fb_child").unwrap();
|
|
let pd_title: gtk::Label = builder.get_object("pd_title").unwrap();
|
|
let pd_cover: gtk::Image = builder.get_object("pd_cover").unwrap();
|
|
let banner: gtk::Image = builder.get_object("banner").unwrap();
|
|
let banner_title: gtk::Label = builder.get_object("banner_label").unwrap();
|
|
|
|
pd_title.set_text(pd.title());
|
|
|
|
let cover = get_pixbuf_from_path(pd.image_uri(), pd.title());
|
|
if let Some(img) = cover {
|
|
pd_cover.set_from_pixbuf(&img);
|
|
};
|
|
|
|
configure_banner(db, pd, &banner, &banner_title);
|
|
|
|
let fbc = gtk::FlowBoxChild::new();
|
|
// There's probably a better way to store the id somewhere.
|
|
fbc.set_name(&pd.id().to_string());
|
|
fbc.add(&box_);
|
|
fbc
|
|
}
|
|
|
|
fn configure_banner(db: &Database, pd: &Podcast, banner: >k::Image, banner_title: >k::Label) {
|
|
// TODO: move .ui files into gresources and refactor.
|
|
static_resource::init();
|
|
|
|
let bann = Pixbuf::new_from_resource_at_scale("/org/gtk/hammond/banner.png", 256, 256, true);
|
|
if let Ok(b) = bann {
|
|
banner.set_from_pixbuf(&b);
|
|
|
|
let new_episodes = {
|
|
let tempdb = db.lock().unwrap();
|
|
dbqueries::get_pd_unplayed_episodes(&tempdb, pd)
|
|
};
|
|
|
|
if let Ok(n) = new_episodes {
|
|
if !n.is_empty() {
|
|
banner_title.set_text(&n.len().to_string());
|
|
banner.show();
|
|
banner_title.show();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
fn on_flowbox_child_activate(db: &Database, stack: >k::Stack, parent: &Podcast) {
|
|
let old = stack.get_child_by_name("pdw").unwrap();
|
|
let pdw = podcast_widget(db, stack, parent);
|
|
|
|
stack.remove(&old);
|
|
stack.add_named(&pdw, "pdw");
|
|
stack.set_visible_child(&pdw);
|
|
|
|
// aggresive memory cleanup
|
|
// probably not needed
|
|
old.destroy();
|
|
}
|
|
|
|
fn setup_podcasts_flowbox(db: &Database, stack: >k::Stack) {
|
|
let builder = gtk::Builder::new_from_string(include_str!("../../gtk/podcasts_view.ui"));
|
|
let fb_parent: gtk::Box = builder.get_object("fb_parent").unwrap();
|
|
|
|
let flowbox: gtk::FlowBox = builder.get_object("flowbox").unwrap();
|
|
init_flowbox(db, stack, &flowbox);
|
|
|
|
stack.add_named(&fb_parent, "fb_parent");
|
|
stack.set_visible_child(&fb_parent);
|
|
}
|
|
|
|
pub fn setup_stack(db: &Database) -> gtk::Stack {
|
|
let stack = gtk::Stack::new();
|
|
stack.set_transition_type(gtk::StackTransitionType::SlideLeftRight);
|
|
setup_podcast_widget(&stack);
|
|
setup_podcasts_flowbox(db, &stack);
|
|
stack
|
|
}
|
|
|
|
pub fn update_podcasts_view(db: &Database, stack: >k::Stack) {
|
|
let builder = gtk::Builder::new_from_string(include_str!("../../gtk/podcasts_view.ui"));
|
|
let fb_parent: gtk::Box = builder.get_object("fb_parent").unwrap();
|
|
|
|
let flowbox: gtk::FlowBox = builder.get_object("flowbox").unwrap();
|
|
init_flowbox(db, stack, &flowbox);
|
|
|
|
let old = stack.get_child_by_name("fb_parent").unwrap();
|
|
let vis = stack.get_visible_child_name().unwrap();
|
|
|
|
stack.remove(&old);
|
|
stack.add_named(&fb_parent, "fb_parent");
|
|
// preserve the visible widget
|
|
stack.set_visible_child_name(&vis);
|
|
|
|
// aggresive memory cleanup
|
|
// probably not needed
|
|
old.destroy();
|
|
}
|
|
|
|
fn init_flowbox(db: &Database, stack: >k::Stack, flowbox: >k::FlowBox) {
|
|
// TODO: handle unwraps.
|
|
flowbox.connect_child_activated(clone!(db, stack => move |_, child| {
|
|
// This is such an ugly hack...
|
|
let id = child.get_name().unwrap().parse::<i32>().unwrap();
|
|
let parent = {
|
|
let tempdb = db.lock().unwrap();
|
|
dbqueries::get_podcast_from_id(&tempdb, id).unwrap()
|
|
};
|
|
on_flowbox_child_activate(&db, &stack, &parent);
|
|
}));
|
|
// Populate the flowbox with the Podcasts.
|
|
populate_flowbox(db, stack, flowbox);
|
|
}
|