X-Git-Url: http://git.maemo.org/git/?a=blobdiff_plain;f=src%2Fplugins%2Fimdb-plugin.vala;h=e5b79761785633c209987d4545e2aa88ba57e305;hb=6cec48bf094d167ec7cd82fd0cde885d7b06ff92;hp=797def1264c0d278942516ac7d8808ba7e44f797;hpb=2778931afcf9f3535ead1af77c5d462211748e85;p=cinaest diff --git a/src/plugins/imdb-plugin.vala b/src/plugins/imdb-plugin.vala index 797def1..e5b7976 100644 --- a/src/plugins/imdb-plugin.vala +++ b/src/plugins/imdb-plugin.vala @@ -23,7 +23,6 @@ class IMDbPlugin : Plugin { private dynamic DBus.Object server; List sources; private weak Osso.Context osso_context; - private Gtk.Window _window; public override void hello (Gtk.Window window, Osso.Context context) { string filename = Path.build_filename (Environment.get_user_cache_dir(), @@ -37,7 +36,7 @@ class IMDbPlugin : Plugin { note.destroy (); if (response == ResponseType.OK) { - download_imdb (window); + download_imdb (window, false); } } @@ -47,13 +46,12 @@ class IMDbPlugin : Plugin { sources.append (source); osso_context = context; - _window = window; // FIXME - this forces the inclusion of config.h (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; @@ -82,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 (); } @@ -92,25 +90,25 @@ class IMDbPlugin : Plugin { return sources; } - public override List get_actions (Movie movie) { + public override List get_actions (Movie movie, Gtk.Window window) { List list = null; if (movie.year > 0) - list.append (new MovieAction (_("IMDb page"), on_visit_imdb, movie)); + list.append (new MovieAction (_("IMDb page"), on_visit_imdb, movie, window)); else - list.append (new MovieAction (_("Lookup on IMDb"), on_visit_imdb, movie)); + list.append (new MovieAction (_("Lookup on IMDb"), on_visit_imdb, movie, window)); return list; } - private void on_visit_imdb (Movie movie) { + private void on_visit_imdb (Movie movie, Gtk.Window window) { var url = "http://www.imdb.com/find?s=tt&q=" + movie.title.replace(" ", "+"); if (movie.year > 0) url += "+(%d)".printf (movie.year); var status = osso_context.rpc_run_with_defaults ("osso_browser", "open_new_window", null, 's', url, 'b', false); if (status != Osso.Status.OK) { - var banner = (Banner) Hildon.Banner.show_information_with_markup (_window, null, "Failed to open browser."); + var banner = (Banner) Hildon.Banner.show_information_with_markup (window, null, "Failed to open browser."); banner.set_timeout (1500); } } @@ -120,25 +118,74 @@ 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); var file = File.new_for_path (filename); - var info = file.query_info (FILE_ATTRIBUTE_TIME_MODIFIED, FileQueryInfoFlags.NONE, null); - TimeVal tv; - info.get_modification_time (out tv); - - var date = Date (); - date.set_time_val (tv); - char[] s = new char[64]; - date.strftime (s, "%x"); + try { + var info = file.query_info (FILE_ATTRIBUTE_TIME_MODIFIED, FileQueryInfoFlags.NONE, null); + TimeVal tv; + info.get_modification_time (out tv); + + var date = Date (); + date.set_time_val (tv); + char[] s = new char[64]; + date.strftime (s, "%x"); + updated = (string) s; + } catch (Error e) { + updated = _("unknown"); + } - var download = new Hildon.Button.with_text (SizeType.FINGER_HEIGHT, ButtonArrangement.VERTICAL, _("Download"), "Last update: " + (string) s); + 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 (); @@ -151,44 +198,81 @@ 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 == "") - 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) { } + public override void delete_movie (Movie movie) { + } + public override unowned string get_name () { return "IMDb"; } public override unowned string get_description () { - return "Movies on IMDb"; + return _("Movies on IMDb"); + } + + 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); }