IMDb SQLite: unescape quotation marks when retrieving plots from the database
[cinaest] / src / movie-list-window.vala
index f975746..5112b97 100644 (file)
@@ -30,10 +30,14 @@ public class MovieListWindow : StackableWindow {
        private MovieListStore store;
        private Label no_movies;
        private bool search_bar_visible;
+       private MovieWindow movie_window;
+
+       public MovieListWindow (MovieSource source) {
+               set_title (source.get_description ());
 
-       construct {
                // View menu
                menu = new MovieListMenu (this);
+               menu.source = source;
 
                set_main_menu (menu);
 
@@ -57,6 +61,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");
@@ -74,12 +79,14 @@ public class MovieListWindow : StackableWindow {
                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.search_finished.connect (on_search_finished);
 
                store.notify["update-running"].connect (on_update_running_changed);
 
@@ -90,22 +97,14 @@ public class MovieListWindow : StackableWindow {
                edit_toolbar.hide ();
                search_bar_visible = false;
                search_bar.hide ();
-               movie_list.hide ();
 
                filter = new MovieFilter ();
-       }
-
-       public MovieSource source {
-               get { return store.source; }
-               set {
-                       store.source = value;
-                       menu.source = value;
-                       set_title (value.get_description ());
-                       filter.title = search_field.get_text ();
-                       if (store.start_search (filter)) {
-                               movie_list.show ();
-                               no_movies.hide ();
-                       }
+               menu.filter = filter;
+               filter.title = "";
+               if (store.start_search (filter)) {
+                       no_movies.hide ();
+               } else {
+                       movie_list.hide ();
                }
        }
 
@@ -124,6 +123,7 @@ public class MovieListWindow : StackableWindow {
                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));
@@ -152,6 +152,13 @@ public class MovieListWindow : StackableWindow {
                        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 ();
@@ -200,10 +207,19 @@ public class MovieListWindow : StackableWindow {
                return false;
        }
 
+       private void on_search_finished (int movies) {
+               if (movies > 100) {
+                       Banner.show_information (this, null, _("More results available - refine search to reduce the dataset"));
+               }
+       }
+
        private void on_movie_activated (Movie movie) {
-               var window = new MovieWindow.with_movie (movie, store);
-               window.show_all ();
+               if (movie_window != null)
+                       return;
 
+               movie_window = new MovieWindow.with_movie (movie, store);
+               movie_window.destroy.connect (() => { movie_window = null; });
+               movie_window.show ();
        }
 
        private void on_update_running_changed (GLib.Object source, ParamSpec spec) {