X-Git-Url: http://vcs.maemo.org/git/?a=blobdiff_plain;f=src%2Fmovie-list-window.vala;h=1bcc7ecc11cbbb789caa66380ffdd733a5bf01ec;hb=3f4b39fa556e8274fd7231eb44baaadb3d904dec;hp=da0cfa2dc4512c7ca7561f9f1da7265263712e7a;hpb=7c7799dd2829b4711b0948a1bd9bb2f1ba2802a9;p=cinaest diff --git a/src/movie-list-window.vala b/src/movie-list-window.vala index da0cfa2..1bcc7ec 100644 --- a/src/movie-list-window.vala +++ b/src/movie-list-window.vala @@ -21,6 +21,7 @@ using Hildon; public class MovieListWindow : StackableWindow { private MovieListMenu menu; + private Hildon.EditToolbar edit_toolbar; private Hildon.Entry search_field; private Toolbar search_bar; private uint source_id; @@ -30,9 +31,12 @@ public class MovieListWindow : StackableWindow { private Label no_movies; private bool search_bar_visible; - construct { + public MovieListWindow (MovieSource source) { + set_title (source.get_description ()); + // View menu menu = new MovieListMenu (this); + menu.source = source; set_main_menu (menu); @@ -56,6 +60,7 @@ public class MovieListWindow : StackableWindow { movie_list = new MovieListView (); menu.sortable = movie_list.sorted_store; store = movie_list.store; + store.source = source; no_movies = new Label (_("No movies")); Hildon.helper_set_logical_font (no_movies, "LargeSystemFont"); @@ -69,7 +74,13 @@ public class MovieListWindow : StackableWindow { add (vbox); + edit_toolbar = new Hildon.EditToolbar.with_text (_("Select movies"), _("Delete")); + set_edit_toolbar (edit_toolbar); + // Connect signals + menu.filter_changed.connect (() => { start_search (); }); + edit_toolbar.button_clicked.connect (on_delete_button_clicked); + edit_toolbar.arrow_clicked.connect (leave_edit_mode); search_field.changed.connect (on_search_field_changed); close_button.clicked.connect (on_close_button_clicked); key_press_event.connect (on_key_press_event); @@ -81,25 +92,80 @@ public class MovieListWindow : StackableWindow { search_field.grab_default (); show_all (); + edit_toolbar.hide (); search_bar_visible = false; search_bar.hide (); - movie_list.hide (); filter = new MovieFilter (); + menu.filter = filter; + filter.title = ""; + if (store.start_search (filter)) { + no_movies.hide (); + } else { + movie_list.hide (); + } } - public MovieSource source { - get { return store.source; } - set { - store.source = value; - menu.source = value; - set_title ("Cinæst: " + value.get_description ()); - filter.title = search_field.get_text (); - if (store.start_search (filter)) { - movie_list.show (); - no_movies.hide (); + public void on_delete_movies_clicked () { + fullscreen (); + edit_toolbar.show (); + movie_list.set_hildon_ui_mode (UIMode.EDIT); + + var selection = movie_list.get_selection (); + selection.unselect_all (); + } + + private void on_delete_button_clicked () { + var selection = movie_list.get_selection (); + int count = selection.count_selected_rows (); + if (count == 0) { + Banner.show_information (this, null, _("No movies selected")); + leave_edit_mode (); + return; + } + + var dialog = new Note.confirmation (this, _("Delete %d movies?").printf (count)); + var res = dialog.run (); + + if (res == Gtk.ResponseType.OK) { + weak TreeModel model; + var rows = selection.get_selected_rows (out model); + + var movies = new List (); + + // get selected movies from the store + foreach (TreePath path in rows) { + TreeIter iter; + + if (model.get_iter (out iter, path)) { + Movie movie; + + model.get (iter, MovieListStore.Columns.MOVIE, out movie); + if (movie != null) { + movies.append (movie); + } + } + } + // and remove them + foreach (Movie movie in movies) { + store.remove (movie); + } + + // Switch to "No movies" label if the store is emptied + TreeIter iter; + if (!store.get_iter_first (out iter)) { + movie_list.hide (); + no_movies.show (); } } + dialog.destroy (); + leave_edit_mode (); + } + + private void leave_edit_mode () { + movie_list.set_hildon_ui_mode (UIMode.NORMAL); + edit_toolbar.hide (); + unfullscreen (); } private void on_close_button_clicked () { @@ -141,8 +207,8 @@ public class MovieListWindow : StackableWindow { private void on_movie_activated (Movie movie) { var window = new MovieWindow.with_movie (movie, store); - window.show_all (); + window.show (); } private void on_update_running_changed (GLib.Object source, ParamSpec spec) {