X-Git-Url: http://git.maemo.org/git/?a=blobdiff_plain;f=src%2Fplugins%2Fimdb-plugin.vala;h=e5b79761785633c209987d4545e2aa88ba57e305;hb=6cec48bf094d167ec7cd82fd0cde885d7b06ff92;hp=fb0c32a13c1402e5af1c63653ceb1eed090066fc;hpb=34849fed4649020b270a00b75b3b0e236bd9ad32;p=cinaest diff --git a/src/plugins/imdb-plugin.vala b/src/plugins/imdb-plugin.vala index fb0c32a..e5b7976 100644 --- a/src/plugins/imdb-plugin.vala +++ b/src/plugins/imdb-plugin.vala @@ -36,7 +36,7 @@ class IMDbPlugin : Plugin { note.destroy (); if (response == ResponseType.OK) { - download_imdb (window); + download_imdb (window, false); } } @@ -51,7 +51,7 @@ class IMDbPlugin : Plugin { (void) Config.GETTEXT_PACKAGE; } - private void download_imdb (Gtk.Window window) { + private void download_imdb (Gtk.Window window, bool plots) { var picker = new PickerDialog (window); var selector = new TouchSelector.text (); string[] mirrors; @@ -80,7 +80,7 @@ class IMDbPlugin : Plugin { picker.destroy(); if (res == ResponseType.OK) { - var download = new IMDbDownloadDialog (window); + var download = new IMDbDownloadDialog (window, plots); download.run (server, mirror); download.destroy (); } @@ -118,6 +118,19 @@ class IMDbPlugin : Plugin { dialog.set_transient_for (window); dialog.set_title (_("IMDb plugin settings")); + bool download_plots; + try { + var sqlite = new IMDbSqlite (Path.build_filename (Environment.get_user_cache_dir (), + "cinaest", "imdb.db", null)); + download_plots = sqlite.has_plots (); + } catch (Error e) { + download_plots = false; + } + + var plots = new Hildon.CheckButton (SizeType.FINGER_HEIGHT); + plots.set_label (_("Download and store movie plots")); + plots.set_active (download_plots); + string updated; string filename = Path.build_filename (Environment.get_user_cache_dir(), "cinaest", "imdb.db", null); @@ -139,10 +152,40 @@ class IMDbPlugin : Plugin { var download = new Hildon.Button.with_text (SizeType.FINGER_HEIGHT, ButtonArrangement.VERTICAL, _("Download"), _("Last update: ") + updated); VBox content = (VBox) dialog.get_content_area (); + content.pack_start (plots, true, true, 0); content.pack_start (download, true, true, 0); + var sizegroup = new Gtk.SizeGroup (SizeGroupMode.HORIZONTAL); + + // User name + var hbox = new Gtk.HBox (false, MARGIN_DOUBLE); + var label = new Gtk.Label (_("User name")); + label.set_alignment (0, 0.5f); + sizegroup.add_widget (label); + var entry = new Hildon.Entry (SizeType.FINGER_HEIGHT); + hbox.pack_start (label, false, false, 0); + hbox.pack_start (entry, true, true, 0); + content.pack_start (hbox, true, true, 0); + + // Password + hbox = new Gtk.HBox (false, MARGIN_DOUBLE); + label = new Gtk.Label ("Password"); + label.set_alignment (0, 0.5f); + sizegroup.add_widget (label); + entry = new Hildon.Entry (SizeType.FINGER_HEIGHT); + hbox.pack_start (label, false, false, 0); + hbox.pack_start (entry, true, true, 0); + content.pack_start (hbox, true, true, 0); + + dialog.add_button (_("Save"), ResponseType.ACCEPT); + + // Connect signals + plots.toggled.connect (() => { + if (download_plots != plots.get_active ()) + Hildon.Banner.show_information (window, null, _("Redownload the IMDb for this change to take effect.")); + }); download.clicked.connect (() => { - download_imdb (window); + download_imdb (window, plots.get_active ()); }); dialog.show_all (); @@ -155,28 +198,58 @@ class IMDbPlugin : Plugin { } } +class IMDbMovie : Movie { + public override string get_plot () { + var sqlite = new IMDbSqlite (Path.build_filename (Environment.get_user_cache_dir (), + "cinaest", "imdb.db", null)); + print ("IMDb get_plot(\"%s (%d)\")\n", title, year); + return sqlite.get_plot ("%s (%d)".printf (title, year)); + } +} + class IMDBSource : MovieSource { + SList result; + int results_waiting; + + public override bool active { get; set construct; } + + public IMDBSource () { + GLib.Object (active: true); + } + MovieSource.ReceiveMovieFunction _get_callback; - public override async void get_movies (MovieFilter filter, MovieSource.ReceiveMovieFunction callback, int limit, Cancellable? cancellable) { - // IMDb has too many movies - if (filter.title == "" && filter.year_min == 0 && filter.year_max == 0 && filter.genres.field == 0 && filter.rating_min == 0) - return; + public override async int get_movies (MovieFilter filter, MovieSource.ReceiveMovieFunction callback, int limit, Cancellable? cancellable) { var sqlite = new IMDbSqlite (Path.build_filename (Environment.get_user_cache_dir (), "cinaest", "imdb.db", null)); _get_callback = callback; - yield sqlite.query (filter, receive_movie, cancellable); + result = new SList (); + results_waiting = 0; + int n = yield sqlite.query (filter, receive_movie, limit, cancellable); + if (results_waiting > 0) + _get_callback (result); + result = new SList (); + return n; } - private void receive_movie (string title, int year, int rating, int genres) { - Movie movie = new Movie (); + private void receive_movie (string title, string? aka, int year, int rating, int genres) { + var movie = new IMDbMovie (); movie.title = title; movie.year = year; movie.rating = rating; movie.genres.field = genres; // TODO - depending on settings, this could be something else, like director info or runtime - movie.secondary = movie.genres.to_string (); - _get_callback (movie); + if (aka != null) { + movie.secondary = "aka \"%s\" - %s".printf (aka, movie.genres.to_string ()); + } else { + movie.secondary = movie.genres.to_string (); + } + result.append (movie); + if (++results_waiting >= 10) { + _get_callback (result); + result = new SList (); + results_waiting = 0; + } } public override void add_movie (Movie movie) { @@ -190,16 +263,16 @@ class IMDBSource : MovieSource { } public override unowned string get_description () { - return "Movies on IMDb"; + return _("Movies on IMDb"); } - public override bool get_editable () { - return false; + public override SourceFlags get_flags () { + return 0; } } [ModuleInit] -public Type register_plugin () { +public Type register_plugin (TypeModule module) { // types are registered automatically return typeof (IMDbPlugin); }