Skip to content

Commit

Permalink
set action icon when entering text
Browse files Browse the repository at this point in the history
  • Loading branch information
blahgeek committed Jul 22, 2017
1 parent dde6016 commit 0e0e974
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 9 deletions.
14 changes: 7 additions & 7 deletions src/frontend_gtk/app.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
* @Author: BlahGeek
* @Date: 2017-04-23
* @Last Modified by: BlahGeek
* @Last Modified time: 2017-07-20
* @Last Modified time: 2017-07-22
*/

extern crate glib;
Expand Down Expand Up @@ -103,23 +103,23 @@ impl MinionsApp {
Status::Initial => {
self.ui.set_entry(None);
self.ui.set_filter_text("");
self.ui.set_action_name(None);
self.ui.set_action(None);
self.ui.set_reference(None);
self.ui.set_items(Vec::new(), -1, &self.ctx);
self.ui.set_spinning(false);
},
Status::Running(_) => {
self.ui.set_entry(None);
self.ui.set_filter_text("");
self.ui.set_action_name(None);
self.ui.set_action(None);
self.ui.set_reference(None);
self.ui.set_items(Vec::new(), -1, &self.ctx);
self.ui.set_spinning(true);
},
Status::Error(ref error) => {
self.ui.set_entry(None);
self.ui.set_filter_text("");
self.ui.set_action_name(None);
self.ui.set_action(None);
self.ui.set_reference(None);
self.ui.set_items(Vec::new(), -1, &self.ctx);
self.ui.set_spinning(false);
Expand All @@ -129,7 +129,7 @@ impl MinionsApp {
self.ui.set_spinning(false);
self.ui.set_entry(None);
self.ui.set_filter_text("");
self.ui.set_action_name(None);
self.ui.set_action(None);
self.ui.set_reference(self.ctx.reference.as_ref());
if self.ctx.list_items.len() == 0 {
warn!("No more listing items!");
Expand All @@ -155,7 +155,7 @@ impl MinionsApp {
}
self.ui.set_spinning(false);
self.ui.set_filter_text(&filter_text);
self.ui.set_action_name(None);
self.ui.set_action(None);
self.ui.set_reference(self.ctx.reference.as_ref());
self.ui.set_items(filter_indices.iter().map(|x| &self.ctx.list_items[x.clone()])
.collect::<Vec<&Item>>(), selected_idx, &self.ctx);
Expand All @@ -179,7 +179,7 @@ impl MinionsApp {

self.ui.set_filter_text("");
// self.ui.set_reference_item(Some(&self.ctx.list_items[idx]));
self.ui.set_action_name(Some(&self.ctx.list_items[idx].title));
self.ui.set_action(Some(&self.ctx.list_items[idx]));
self.ui.set_reference(None);
self.ui.set_items(Vec::new(), -1, &self.ctx);
}
Expand Down
15 changes: 13 additions & 2 deletions src/frontend_gtk/ui.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
* @Author: BlahGeek
* @Date: 2017-04-22
* @Last Modified by: BlahGeek
* @Last Modified time: 2017-07-15
* @Last Modified time: 2017-07-22
*/

extern crate gdk_pixbuf;
Expand Down Expand Up @@ -150,7 +150,7 @@ impl MinionsUI {
}
}

pub fn set_action_name(&self, name: Option<&str>) {
fn set_action_name(&self, name: Option<&str>) {
let action_box = self.window_builder.get_object::<gtk::Box>("action_box").unwrap();
let action_name = self.window_builder.get_object::<gtk::Label>("action_name").unwrap();
if let Some(name) = name {
Expand All @@ -161,6 +161,17 @@ impl MinionsUI {
}
}

pub fn set_action(&self, item: Option<&Item>) {
if let Some(item) = item {
if let Some(ref ico) = item.icon {
set_image_icon(&self.icon, &self.icon_text, ico);
}
self.set_action_name(Some(&item.title));
} else {
self.set_action_name(None)
}
}

fn build_item(item: &Item, ctx: &Context) -> gtk::Box {
let builder = gtk::Builder::new_from_string(include_str!("resource/item_template.glade"));
let item_ui = builder.get_object::<gtk::Box>("item_template")
Expand Down

0 comments on commit 0e0e974

Please sign in to comment.