Refactor Headerbar into a Wrapped struct type.
This commit is contained in:
parent
13e47e9b4e
commit
1fbcfa47ac
@ -3,7 +3,6 @@
|
|||||||
<interface>
|
<interface>
|
||||||
<requires lib="gtk+" version="3.20"/>
|
<requires lib="gtk+" version="3.20"/>
|
||||||
<object class="GtkPopover" id="add-popover">
|
<object class="GtkPopover" id="add-popover">
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="can_focus">False</property>
|
<property name="can_focus">False</property>
|
||||||
<property name="tooltip_text" translatable="yes">Add a new feed</property>
|
<property name="tooltip_text" translatable="yes">Add a new feed</property>
|
||||||
<property name="valign">center</property>
|
<property name="valign">center</property>
|
||||||
|
|||||||
@ -7,6 +7,68 @@ use hammond_data::utils::url_cleaner;
|
|||||||
use podcasts_view::update_podcasts_view;
|
use podcasts_view::update_podcasts_view;
|
||||||
use utils;
|
use utils;
|
||||||
|
|
||||||
|
#[derive(Debug)]
|
||||||
|
pub struct Header {
|
||||||
|
container: gtk::HeaderBar,
|
||||||
|
home: gtk::Button,
|
||||||
|
refresh: gtk::Button,
|
||||||
|
add_toggle: gtk::MenuButton,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Header {
|
||||||
|
fn new() -> Header {
|
||||||
|
let builder = gtk::Builder::new_from_resource("/org/gnome/hammond/gtk/headerbar.ui");
|
||||||
|
|
||||||
|
let header: gtk::HeaderBar = builder.get_object("headerbar1").unwrap();
|
||||||
|
let home: gtk::Button = builder.get_object("homebutton").unwrap();
|
||||||
|
let refresh: gtk::Button = builder.get_object("refbutton").unwrap();
|
||||||
|
let add_toggle: gtk::MenuButton = builder.get_object("add-toggle-button").unwrap();
|
||||||
|
|
||||||
|
Header {
|
||||||
|
container: header,
|
||||||
|
home,
|
||||||
|
refresh,
|
||||||
|
add_toggle,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn init(&self, stack: >k::Stack) {
|
||||||
|
let builder = gtk::Builder::new_from_resource("/org/gnome/hammond/gtk/headerbar.ui");
|
||||||
|
|
||||||
|
let add_popover: gtk::Popover = builder.get_object("add-popover").unwrap();
|
||||||
|
let new_url: gtk::Entry = builder.get_object("new-url").unwrap();
|
||||||
|
let add_button: gtk::Button = builder.get_object("add-button").unwrap();
|
||||||
|
|
||||||
|
new_url.connect_changed(move |url| {
|
||||||
|
println!("{:?}", url.get_text());
|
||||||
|
});
|
||||||
|
|
||||||
|
add_button.connect_clicked(clone!(stack, add_popover, new_url => move |_| {
|
||||||
|
on_add_bttn_clicked(&stack, &new_url);
|
||||||
|
|
||||||
|
// TODO: lock the button instead of hiding and add notification of feed added.
|
||||||
|
// TODO: map the spinner
|
||||||
|
add_popover.hide();
|
||||||
|
}));
|
||||||
|
self.add_toggle.set_popover(&add_popover);
|
||||||
|
|
||||||
|
// TODO: make it a back arrow button, that will hide when appropriate,
|
||||||
|
// and add a StackSwitcher when more views are added.
|
||||||
|
self.home.connect_clicked(clone!(stack => move |_| {
|
||||||
|
let vis = stack.get_visible_child_name().unwrap();
|
||||||
|
stack.set_visible_child_name("fb_parent");
|
||||||
|
if vis != "pdw" {
|
||||||
|
update_podcasts_view(&stack);
|
||||||
|
}
|
||||||
|
}));
|
||||||
|
|
||||||
|
// FIXME: There appears to be a memmory leak here.
|
||||||
|
self.refresh.connect_clicked(clone!(stack => move |_| {
|
||||||
|
utils::refresh_feed(&stack, None, None);
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn get_headerbar(stack: >k::Stack) -> gtk::HeaderBar {
|
pub fn get_headerbar(stack: >k::Stack) -> gtk::HeaderBar {
|
||||||
let builder = gtk::Builder::new_from_resource("/org/gnome/hammond/gtk/headerbar.ui");
|
let builder = gtk::Builder::new_from_resource("/org/gnome/hammond/gtk/headerbar.ui");
|
||||||
|
|
||||||
@ -23,16 +85,13 @@ pub fn get_headerbar(stack: >k::Stack) -> gtk::HeaderBar {
|
|||||||
println!("{:?}", url.get_text());
|
println!("{:?}", url.get_text());
|
||||||
});
|
});
|
||||||
|
|
||||||
add_button.connect_clicked(clone!(stack, add_popover => move |_| {
|
add_button.connect_clicked(clone!(stack, add_popover, new_url => move |_| {
|
||||||
let url = new_url.get_text().unwrap_or_default();
|
on_add_bttn_clicked(&stack, &new_url);
|
||||||
let url = url_cleaner(&url);
|
|
||||||
on_add_bttn_clicked(&stack, &url);
|
|
||||||
|
|
||||||
// TODO: lock the button instead of hiding and add notification of feed added.
|
// TODO: lock the button instead of hiding and add notification of feed added.
|
||||||
// TODO: map the spinner
|
// TODO: map the spinner
|
||||||
add_popover.hide();
|
add_popover.hide();
|
||||||
}));
|
}));
|
||||||
add_popover.hide();
|
|
||||||
add_toggle_button.set_popover(&add_popover);
|
add_toggle_button.set_popover(&add_popover);
|
||||||
|
|
||||||
// TODO: make it a back arrow button, that will hide when appropriate,
|
// TODO: make it a back arrow button, that will hide when appropriate,
|
||||||
@ -53,8 +112,10 @@ pub fn get_headerbar(stack: >k::Stack) -> gtk::HeaderBar {
|
|||||||
header
|
header
|
||||||
}
|
}
|
||||||
|
|
||||||
fn on_add_bttn_clicked(stack: >k::Stack, url: &str) {
|
fn on_add_bttn_clicked(stack: >k::Stack, entry: >k::Entry) {
|
||||||
let source = Source::from_url(url);
|
let url = entry.get_text().unwrap_or_default();
|
||||||
|
let url = url_cleaner(&url);
|
||||||
|
let source = Source::from_url(&url);
|
||||||
|
|
||||||
if let Ok(s) = source {
|
if let Ok(s) = source {
|
||||||
info!("{:?} feed added", url);
|
info!("{:?} feed added", url);
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user