X-Git-Url: https://vcs.maemo.org/git/?a=blobdiff_plain;f=src%2Fmovie-list-menu.vala;h=daea9e481baa4a4f22d19293a92f688e8c622020;hb=db58340a7fc45ea299263835be40bffa7bb5303f;hp=ea5cc4b8b9f1332b1a11eea29a2cd6a626a74664;hpb=5134fee4e38ecedb89c0374d6de095d7c43f146e;p=cinaest diff --git a/src/movie-list-menu.vala b/src/movie-list-menu.vala index ea5cc4b..daea9e4 100644 --- a/src/movie-list-menu.vala +++ b/src/movie-list-menu.vala @@ -20,12 +20,13 @@ using Gtk; using Hildon; public class MovieListMenu : AppMenu { - public TreeSortable sortable; + public MovieListStore store; public MovieFilter filter; private weak MovieListWindow movie_list_window; private Hildon.Button filter_year; private Hildon.Button filter_rating; private Hildon.Button filter_genres; + private Gtk.Button poster_view; private Gtk.Button delete_movies; private Gtk.Button import_movies; @@ -52,15 +53,15 @@ public class MovieListMenu : AppMenu { // Connect signals sort_by_title.toggled.connect (button => { if (button.get_active ()) - sortable.set_sort_column_id (MovieListStore.Columns.TITLE, Gtk.SortType.ASCENDING); + store.set_sort_column_id (MovieListStore.Columns.TITLE, Gtk.SortType.ASCENDING); }); sort_by_year.toggled.connect (button => { if (button.get_active ()) - sortable.set_sort_column_id (MovieListStore.Columns.YEAR, Gtk.SortType.DESCENDING); + store.set_sort_column_id (MovieListStore.Columns.YEAR, Gtk.SortType.DESCENDING); }); sort_by_rating.toggled.connect (button => { if (button.get_active ()) - sortable.set_sort_column_id (MovieListStore.Columns.RATING, Gtk.SortType.DESCENDING); + store.set_sort_column_id (MovieListStore.Columns.RATING, Gtk.SortType.DESCENDING); }); add_filter (sort_by_title); @@ -71,6 +72,7 @@ public class MovieListMenu : AppMenu { filter_year = new Hildon.Button.with_text (SizeType.FINGER_HEIGHT, ButtonArrangement.VERTICAL, _("Filter by year"), _("Off")); filter_rating = new Hildon.Button.with_text (SizeType.FINGER_HEIGHT, ButtonArrangement.VERTICAL, _("Filter by rating"), _("Off")); filter_genres = new Hildon.Button.with_text (SizeType.FINGER_HEIGHT, ButtonArrangement.VERTICAL, _("Filter by genres"), _("Off")); + poster_view = new Gtk.Button.with_label (_("Poster view")); delete_movies = new Gtk.Button.with_label (_("Delete movies")); import_movies = new Gtk.Button.with_label (_("Import movies")); var settings = new Gtk.Button.with_label (_("Settings")); @@ -83,6 +85,7 @@ public class MovieListMenu : AppMenu { filter_year.clicked.connect (on_filter_year_clicked); filter_rating.clicked.connect (on_filter_rating_clicked); filter_genres.clicked.connect (on_filter_genres_clicked); + poster_view.clicked.connect (on_poster_view_clicked); delete_movies.clicked.connect (() => { movie_list_window.on_delete_movies_clicked (); }); import_movies.clicked.connect (on_import_movies_clicked); settings.clicked.connect (on_settings_clicked); @@ -90,16 +93,19 @@ public class MovieListMenu : AppMenu { append (filter_year); append (filter_rating); append (filter_genres); - append (delete_movies); + append (poster_view); append (import_movies); + append (delete_movies); append (settings); show_all (); } + private MovieSource source_; public MovieSource source { set { - if (SourceFlags.EDITABLE in value.get_flags ()) { + source_ = value; + if (source_ != null && SourceFlags.EDITABLE in source_.get_flags ()) { delete_movies.show (); import_movies.show (); } else { @@ -203,6 +209,12 @@ public class MovieListMenu : AppMenu { } } + public void on_poster_view_clicked (Gtk.Button button) { + var poster_mode = movie_list_window.get_movie_list_view ().poster_mode; + movie_list_window.get_movie_list_view ().poster_mode = !poster_mode; + poster_view.set_label (poster_mode ? _("Poster view") : _("List view")); + } + public void on_import_movies_clicked (Gtk.Button button) { var dialog = new Gtk.Dialog (); dialog.set_transient_for (movie_list_window);