Add configuration option to open the movie list window on startup
[cinaest] / src / movie-list-window.vala
index 3b74235..e545244 100644 (file)
@@ -20,17 +20,23 @@ using Gtk;
 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;
        private MovieListView movie_list;
-       public MovieListStore store;
+       private MovieFilter filter;
+       private MovieListStore store;
        private Label no_movies;
        private bool search_bar_visible;
 
-       construct {
+       public MovieListWindow (MovieSource source) {
+               set_title (source.get_description ());
+
                // View menu
-               var menu = new MovieListMenu ();
+               menu = new MovieListMenu (this);
+               menu.source = source;
 
                set_main_menu (menu);
 
@@ -54,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");
@@ -67,10 +74,17 @@ 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);
+               movie_list.movie_activated.connect (on_movie_activated);
 
                store.notify["update-running"].connect (on_update_running_changed);
 
@@ -78,9 +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 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<Movie> ();
+
+                       // 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 () {
@@ -102,13 +187,6 @@ public class MovieListWindow : StackableWindow {
        }
 
        private void on_search_field_changed () {
-               if (search_field.get_text () == "") {
-                       store.clear ();
-                       movie_list.hide ();
-                       no_movies.show ();
-                       return;
-               }
-
                // With every change we reset the timer to 500ms
                if (source_id != 0) {
                        Source.remove (source_id);
@@ -117,7 +195,8 @@ public class MovieListWindow : StackableWindow {
        }
 
        private bool start_search () {
-               if (store.start_search (search_field.get_text ())) {
+               filter.title = search_field.get_text ();
+               if (store.start_search (filter)) {
                        movie_list.show ();
                        no_movies.hide ();
                }
@@ -126,8 +205,21 @@ public class MovieListWindow : StackableWindow {
                return false;
        }
 
+       private void on_movie_activated (Movie movie) {
+               var window = new MovieWindow.with_movie (movie, store);
+               window.show_all ();
+
+       }
+
        private void on_update_running_changed (GLib.Object source, ParamSpec spec) {
+               TreeIter iter;
+
                Hildon.gtk_window_set_progress_indicator (this, (int) store.update_running);
+               // Update finished, but store still empty?
+               if (!store.update_running && !store.get_iter_first (out iter)) {
+                       movie_list.hide ();
+                       no_movies.show ();
+               }
        }
 }