minor headerbar improvments.

This commit is contained in:
Jordan Petridis 2017-10-18 18:57:29 +03:00
parent c0c6301e11
commit c3d7a11975
No known key found for this signature in database
GPG Key ID: CEABAD9F5683B9A6
2 changed files with 12 additions and 13 deletions

View File

@ -14,7 +14,11 @@ pub fn get_headerbar(
) -> gtk::HeaderBar {
let builder = include_str!("../gtk/headerbar.ui");
let builder = gtk::Builder::new_from_string(builder);
let header: gtk::HeaderBar = builder.get_object("headerbar1").unwrap();
let home_button: gtk::Button = builder.get_object("homebutton").unwrap();
let refresh_button: gtk::Button = builder.get_object("refbutton").unwrap();
let _search_button: gtk::Button = builder.get_object("searchbutton").unwrap();
let add_toggle_button: gtk::MenuButton = builder.get_object("add-toggle-button").unwrap();
let add_popover: gtk::Popover = builder.get_object("add-popover").unwrap();
@ -24,8 +28,10 @@ pub fn get_headerbar(
new_url.connect_changed(move |url| {
println!("{:?}", url.get_text());
});
let add_popover_clone = add_popover.clone();
let db_clone = db.clone();
add_button.connect_clicked(move |_| {
let tempdb = db_clone.lock().unwrap();
let url = new_url.get_text().unwrap();
@ -42,12 +48,15 @@ pub fn get_headerbar(
add_popover.hide();
add_toggle_button.set_popover(&add_popover);
let _search_button: gtk::Button = builder.get_object("searchbutton").unwrap();
// TODO: make it a back arrow button, that will hide when appropriate,
// and add a StackSwitcher when more views are added.
let home_button: gtk::Button = builder.get_object("homebutton").unwrap();
home_button.connect_clicked(move |_| stack.set_visible_child(&grid));
// FIXME: There appears to be a memmory leak here.
refresh_button.connect_clicked(move |_| {
// fsdaa, The things I do for the borrow checker.
utils::refresh_db(db.clone());
});
header
}

View File

@ -39,9 +39,7 @@ THE CODE IS TERIBLE, SPAGHETTI AND HAS UNWRAPS EVERYWHERE.
// Gonna clean it up when the GUI is a bit usuable.
fn build_ui() {
let glade_src = include_str!("../gtk/foo.ui");
let header_src = include_str!("../gtk/headerbar.ui");
let builder = gtk::Builder::new_from_string(glade_src);
let header_build = gtk::Builder::new_from_string(header_src);
// Get the main window
let window: gtk::Window = builder.get_object("window1").unwrap();
@ -69,14 +67,6 @@ fn build_ui() {
let header = headerbar::get_headerbar(db.clone(), stack.clone(), grid.clone());
window.set_titlebar(&header);
let refresh_button: gtk::Button = header_build.get_object("refbutton").unwrap();
// FIXME: There appears to be a memmory leak here.
let db_clone = db.clone();
refresh_button.connect_clicked(move |_| {
// fsdaa, The things I do for the borrow checker.
utils::refresh_db(db_clone.clone());
});
let tempdb = db.lock().unwrap();
let pd_model = podcast_liststore(&tempdb);
drop(tempdb);