mirror of
https://github.com/johrpan/musicus.git
synced 2025-10-26 19:57:25 +01:00
Add search to person selector
This commit is contained in:
parent
ea2dcbb4db
commit
9c8f32930f
1 changed files with 42 additions and 11 deletions
|
|
@ -17,6 +17,8 @@ where
|
||||||
window: gtk::Window,
|
window: gtk::Window,
|
||||||
callback: F,
|
callback: F,
|
||||||
persons: RefCell<Vec<Person>>,
|
persons: RefCell<Vec<Person>>,
|
||||||
|
list: gtk::ListBox,
|
||||||
|
search_entry: gtk::SearchEntry,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<F> PersonSelector<F>
|
impl<F> PersonSelector<F>
|
||||||
|
|
@ -29,7 +31,7 @@ where
|
||||||
|
|
||||||
get_widget!(builder, gtk::Window, window);
|
get_widget!(builder, gtk::Window, window);
|
||||||
get_widget!(builder, gtk::Button, add_button);
|
get_widget!(builder, gtk::Button, add_button);
|
||||||
get_widget!(builder, gtk::Entry, search_entry);
|
get_widget!(builder, gtk::SearchEntry, search_entry);
|
||||||
get_widget!(builder, gtk::ListBox, list);
|
get_widget!(builder, gtk::ListBox, list);
|
||||||
|
|
||||||
let persons = db.get_persons();
|
let persons = db.get_persons();
|
||||||
|
|
@ -47,20 +49,49 @@ where
|
||||||
window: window,
|
window: window,
|
||||||
callback: callback,
|
callback: callback,
|
||||||
persons: RefCell::new(persons),
|
persons: RefCell::new(persons),
|
||||||
|
search_entry: search_entry,
|
||||||
|
list: list,
|
||||||
});
|
});
|
||||||
|
|
||||||
list.connect_row_activated(clone!(@strong result => move |_, row| {
|
result
|
||||||
|
.list
|
||||||
|
.connect_row_activated(clone!(@strong result => move |_, row| {
|
||||||
result.window.close();
|
result.window.close();
|
||||||
let row = row.get_child().unwrap().downcast::<SelectorRow>().unwrap();
|
let row = row.get_child().unwrap().downcast::<SelectorRow>().unwrap();
|
||||||
let index: usize = row.get_index().try_into().unwrap();
|
let index: usize = row.get_index().try_into().unwrap();
|
||||||
(result.callback)(result.persons.borrow()[index].clone());
|
(result.callback)(result.persons.borrow()[index].clone());
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
result
|
||||||
|
.list
|
||||||
|
.set_filter_func(Some(Box::new(clone!(@strong result => move |row| {
|
||||||
|
let row = row.get_child().unwrap().downcast::<SelectorRow>().unwrap();
|
||||||
|
let index: usize = row.get_index().try_into().unwrap();
|
||||||
|
let search = result.search_entry.get_text().to_string();
|
||||||
|
|
||||||
|
search.is_empty() || result.persons.borrow()[index]
|
||||||
|
.name_lf()
|
||||||
|
.to_lowercase()
|
||||||
|
.contains(&result.search_entry.get_text().to_string().to_lowercase())
|
||||||
|
}))));
|
||||||
|
|
||||||
|
result
|
||||||
|
.search_entry
|
||||||
|
.connect_search_changed(clone!(@strong result => move |_| {
|
||||||
|
result.list.invalidate_filter();
|
||||||
|
}));
|
||||||
|
|
||||||
add_button.connect_clicked(clone!(@strong result => move |_| {
|
add_button.connect_clicked(clone!(@strong result => move |_| {
|
||||||
let editor = PersonEditor::new(result.db.clone(), &result.window, None, clone!(@strong result => move |person| {
|
let editor = PersonEditor::new(
|
||||||
|
result.db.clone(),
|
||||||
|
&result.window,
|
||||||
|
None,
|
||||||
|
clone!(@strong result => move |person| {
|
||||||
result.window.close();
|
result.window.close();
|
||||||
(result.callback)(person);
|
(result.callback)(person);
|
||||||
}));
|
}),
|
||||||
|
);
|
||||||
|
|
||||||
editor.show();
|
editor.show();
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue