[shotwell/wip/gtk4: 70/94] Re-activate import plugins




commit 64f54d47d4a6fd5dc5ecd6bf2a158d77776e71a4
Author: Jens Georg <mail jensge org>
Date:   Sat Apr 16 16:11:00 2022 +0200

    Re-activate import plugins

 src/.unitize/_DataImportsInternals.vala     |  4 +-
 src/data_imports/DataImportsPluginHost.vala |  3 +-
 src/data_imports/DataImportsUI.vala         | 95 ++++++++++++++++-------------
 src/dialogs/WelcomeDialog.vala              |  6 +-
 src/meson.build                             |  5 ++
 5 files changed, 62 insertions(+), 51 deletions(-)
---
diff --git a/src/.unitize/_DataImportsInternals.vala b/src/.unitize/_DataImportsInternals.vala
index 238969e0..002b6a7b 100644
--- a/src/.unitize/_DataImportsInternals.vala
+++ b/src/.unitize/_DataImportsInternals.vala
@@ -16,14 +16,14 @@ public void init_entry() throws Error {
 
     Unit.init_entry();
 
-    //DataImports.init();
+    DataImports.init();
 }
 
 public void terminate_entry() {
     if (_unit_init_count == 0 || --_unit_init_count != 0)
         return;
 
-    //DataImports.terminate();
+    DataImports.terminate();
 
     Unit.terminate_entry();
 }
diff --git a/src/data_imports/DataImportsPluginHost.vala b/src/data_imports/DataImportsPluginHost.vala
index 158b8f4b..9a5621d7 100644
--- a/src/data_imports/DataImportsPluginHost.vala
+++ b/src/data_imports/DataImportsPluginHost.vala
@@ -468,8 +468,7 @@ private void data_import_reporter(ImportManifest manifest, BatchImportRoll impor
         }
     } else {
         DataImportsUI.DataImportsDialog.terminate_instance();
-        ImportUI.report_manifest(meta_manifest, true);
-        meta_manifest = null;
+        ImportUI.report_manifest.begin(meta_manifest, true, null, () => { meta_manifest = null; });
     }
 }
 
diff --git a/src/data_imports/DataImportsUI.vala b/src/data_imports/DataImportsUI.vala
index 6fb7158c..987d4c1c 100644
--- a/src/data_imports/DataImportsUI.vala
+++ b/src/data_imports/DataImportsUI.vala
@@ -34,15 +34,15 @@ public class ConcreteDialogPane : Spit.DataImports.DialogPane, GLib.Object {
 public class StaticMessagePane : ConcreteDialogPane {
     public StaticMessagePane(string message_string) {
         Gtk.Label message_label = new Gtk.Label(message_string);
-        ((Gtk.Box) get_widget()).pack_start(message_label, true, true, 0);
+        ((Gtk.Box) get_widget()).prepend(message_label);
     }
     
     public StaticMessagePane.with_pango(string msg) {
         Gtk.Label label = new Gtk.Label(null);
         label.set_markup(msg);
-        label.set_line_wrap(true);
+        label.set_wrap(true);
         
-        ((Gtk.Box) get_widget()).pack_start(label, true, true, 0);
+        ((Gtk.Box) get_widget()).prepend(label);
     }
 }
 
@@ -51,7 +51,7 @@ public class LibrarySelectionPane : ConcreteDialogPane {
     private Spit.DataImports.ImportableLibrary? selected_library = null;
     private File? selected_file = null;
     private Gtk.Button import_button;
-    private Gtk.RadioButton? file_radio = null;
+    private Gtk.CheckButton? file_radio = null;
     
     public LibrarySelectionPane(
         Spit.DataImports.PluginHost host,
@@ -68,9 +68,9 @@ public class LibrarySelectionPane : ConcreteDialogPane {
         content_box.set_margin_end(30);
         Gtk.Label welcome_label = new Gtk.Label(null);
         welcome_label.set_markup(welcome_message);
-        welcome_label.set_line_wrap(true);
+        welcome_label.set_wrap(true);
         welcome_label.set_halign(Gtk.Align.START);
-        content_box.pack_start(welcome_label, true, true, 6);
+        content_box.prepend(welcome_label);
         
         // margins for buttons
         int radio_margin_left = 20;
@@ -78,7 +78,7 @@ public class LibrarySelectionPane : ConcreteDialogPane {
         int chooser_margin_left = radio_margin_left;
         int chooser_margin_right = radio_margin_right;
         
-        Gtk.RadioButton lib_radio = null;
+        Gtk.CheckButton lib_radio = null;
         if (discovered_libraries.length > 0) {
             chooser_margin_left = radio_margin_left + 20;
             foreach (Spit.DataImports.ImportableLibrary library in discovered_libraries) {
@@ -97,16 +97,25 @@ public class LibrarySelectionPane : ConcreteDialogPane {
             }
         }
         if (file_select_label != null) {
-            Gtk.FileChooserButton file_chooser = new Gtk.FileChooserButton(_("Database file:"), 
Gtk.FileChooserAction.OPEN);
-            file_chooser.selection_changed.connect(() => {
-                selected_file = file_chooser.get_file();
-                if (file_radio != null)
-                    file_radio.active = true;
-                set_import_button_sensitivity();
+            Gtk.Button file_chooser_button = new Gtk.Button.with_label(_("Database file"));
+            file_chooser_button.clicked.connect(() => {
+                var file_chooser = new Gtk.FileChooserNative(_("Database file"), null, 
Gtk.FileChooserAction.OPEN, null, null);
+                file_chooser.show();
+                file_chooser.response.connect((source, res) => {
+                    file_chooser.hide();
+                    if (res == Gtk.ResponseType.OK) {
+                        selected_file = file_chooser.get_file();
+                        if (file_radio != null)
+                            file_radio.active = true;
+                        set_import_button_sensitivity();        
+                    }
+                    file_chooser_button.set_label(selected_file.get_path());
+                    file_chooser.destroy();
+                });
             });
-            file_chooser.set_margin_start(chooser_margin_left);
-            file_chooser.set_margin_end(chooser_margin_right);
-            content_box.pack_start(file_chooser, false, false, 6);
+            file_chooser_button.set_margin_start(chooser_margin_left);
+            file_chooser_button.set_margin_end(chooser_margin_right);
+            content_box.append(file_chooser_button);
         }
         
         import_button = new Gtk.Button.with_mnemonic(_("_Import"));
@@ -118,24 +127,25 @@ public class LibrarySelectionPane : ConcreteDialogPane {
             else
                 debug("LibrarySelectionPane: Library or file should be selected.");
         });
-        Gtk.ButtonBox button_box = new Gtk.ButtonBox(Gtk.Orientation.HORIZONTAL);
-        button_box.layout_style = Gtk.ButtonBoxStyle.CENTER;
-        button_box.add(import_button);
-        content_box.pack_end(button_box, true, false, 6);
+        Gtk.Box button_box = new Gtk.Box(Gtk.Orientation.HORIZONTAL, 6);
+        button_box.append(import_button);
+        content_box.append(button_box);
         
-        ((Gtk.Box) get_widget()).pack_start(content_box, true, true, 0);
+        ((Gtk.Box) get_widget()).append(content_box);
         
         set_import_button_sensitivity();
     }
     
-    private Gtk.RadioButton create_radio_button(
-        Gtk.Box box, Gtk.RadioButton? group, Spit.DataImports.ImportableLibrary? library, string label,
+    private Gtk.CheckButton create_radio_button(
+        Gtk.Box box, Gtk.CheckButton? group, Spit.DataImports.ImportableLibrary? library, string label,
         int margin_left, int margin_right
     ) {
-        var button = new Gtk.RadioButton.with_label_from_widget (group, label);
+        var button = new Gtk.CheckButton.with_label (label);
         if (group == null) { // first radio button is active
             button.active = true;
             selected_library = library;
+        } else {
+            button.set_group(group);
         }
         button.toggled.connect (() => {
             if (button.active) {
@@ -146,7 +156,7 @@ public class LibrarySelectionPane : ConcreteDialogPane {
         });
         button.set_margin_start(margin_left);
         button.set_margin_end(margin_right);
-        box.pack_start(button, false, false, 6);
+        box.append(button);
         return button;
     }
     
@@ -171,13 +181,13 @@ public class ProgressPane : ConcreteDialogPane {
     public ProgressPane(string message) {
         Gtk.Box content_box = new Gtk.Box(Gtk.Orientation.VERTICAL, 8);
         message_label = new Gtk.Label(message);
-        content_box.pack_start(message_label, true, true, 6);
+        content_box.append(message_label);
         progress_bar = new Gtk.ProgressBar();
-        content_box.pack_start(progress_bar, false, true, 6);
+        content_box.append(progress_bar);
         progress_label = new Gtk.Label("");
-        content_box.pack_start(progress_label, false, true, 6);
+        content_box.append(progress_label);
         
-        ((Gtk.Container) get_widget()).add(content_box);
+        ((Gtk.Box) get_widget()).append(content_box);
     }
     
     public void update_progress(double progress, string? progress_message) {
@@ -211,10 +221,10 @@ public class DataImportsDialog : Gtk.Dialog {
         bool use_header = Resources.use_header_bar() == 1;
         Object(use_header_bar: Resources.use_header_bar());
         if (use_header)
-            ((Gtk.HeaderBar) get_header_bar()).set_show_close_button(false);
+            ((Gtk.HeaderBar) get_header_bar()).set_show_title_buttons(false);
 
         resizable = false;
-        delete_event.connect(on_window_close);
+        close_request.connect(on_window_close);
         
         string title = _("Import From Application");
         string label = _("Import media _from:");
@@ -266,33 +276,31 @@ public class DataImportsDialog : Gtk.Dialog {
                 service_selector_box.vexpand = false;
 
                 Gtk.Box service_selector_layouter = new Gtk.Box(Gtk.Orientation.HORIZONTAL, 8);
-                service_selector_layouter.set_border_width(12);
-                service_selector_layouter.add(service_selector_box_label);
-                service_selector_layouter.pack_start(service_selector_box, true, true, 0);
+                service_selector_layouter.append(service_selector_box_label);
+                service_selector_layouter.prepend(service_selector_box);
 
                 /* 'service area' is the selector assembly plus the horizontal rule dividing it from the
                    rest of the dialog */
                 Gtk.Box service_area_layouter = new Gtk.Box(Gtk.Orientation.VERTICAL, 0);
-                service_area_layouter.pack_start(service_selector_layouter, true, true, 0);
+                service_area_layouter.prepend(service_selector_layouter);
                 Gtk.Separator service_central_separator = new Gtk.Separator(Gtk.Orientation.HORIZONTAL);
-                service_area_layouter.add(service_central_separator);
+                service_area_layouter.append(service_central_separator);
                 service_area_layouter.halign = Gtk.Align.FILL;
                 service_area_layouter.valign = Gtk.Align.START;
                 service_area_layouter.hexpand = true;
                 service_area_layouter.vexpand = false;
 
-                ((Gtk.Box) get_content_area()).pack_start(service_area_layouter, false, false, 0);
+                ((Gtk.Box) get_content_area()).prepend(service_area_layouter);
             }
         }
         
         // Install the central area in all cases
         central_area_layouter = new Gtk.Box(Gtk.Orientation.VERTICAL, 0);
-        ((Gtk.Box) get_content_area()).pack_start(central_area_layouter, true, true, 0);
+        ((Gtk.Box) get_content_area()).prepend(central_area_layouter);
         
 
         if (use_header) {
             close_cancel_button = new Gtk.Button.with_mnemonic("_Cancel");
-            close_cancel_button.set_can_default(true);
             ((Gtk.HeaderBar) get_header_bar()).pack_start(close_cancel_button);
             if (service_selector_box != null) {
                 ((Gtk.HeaderBar) get_header_bar()).pack_end(service_selector_box);
@@ -315,7 +323,7 @@ public class DataImportsDialog : Gtk.Dialog {
             set_close_button_mode();
         }
         
-        show_all();
+        show();
     }
     
     public static DataImportsDialog get_or_create_instance() {
@@ -332,7 +340,7 @@ public class DataImportsDialog : Gtk.Dialog {
         instance = null;
     }
     
-    private bool on_window_close(Gdk.EventAny evt) {
+    private bool on_window_close() {
         debug("DataImportsDialog: on_window_close( ): invoked.");
         terminate();
         
@@ -413,7 +421,6 @@ public class DataImportsDialog : Gtk.Dialog {
 
     public void set_close_button_mode() {
         close_cancel_button.set_label(_("_Close"));
-        set_default(close_cancel_button);
     }
 
     public void set_cancel_button_mode() {
@@ -438,8 +445,8 @@ public class DataImportsDialog : Gtk.Dialog {
             central_area_layouter.remove(active_pane.get_widget());
         }
 
-        central_area_layouter.pack_start(pane.get_widget(), true, true, 0);
-        show_all();
+        central_area_layouter.prepend(pane.get_widget());
+        show();
 
         Spit.DataImports.DialogPane.GeometryOptions geometry_options =
             pane.get_preferred_geometry();
diff --git a/src/dialogs/WelcomeDialog.vala b/src/dialogs/WelcomeDialog.vala
index 6d9732c3..f7087b08 100644
--- a/src/dialogs/WelcomeDialog.vala
+++ b/src/dialogs/WelcomeDialog.vala
@@ -21,14 +21,14 @@ public class WelcomeDialog : Gtk.Dialog {
     Gtk.Box import_content;
     Gtk.Box import_action_checkbox_packer;
     Gtk.Box external_import_action_checkbox_packer;
-    //Spit.DataImports.WelcomeImportMetaHost import_meta_host;
+    Spit.DataImports.WelcomeImportMetaHost import_meta_host;
     bool import_content_already_installed = false;
     bool ok_clicked = false;
     GLib.MainLoop loop;
 
     public WelcomeDialog(Gtk.Window owner) {
         Object(use_header_bar : Resources.use_header_bar());
-        //import_meta_host = new Spit.DataImports.WelcomeImportMetaHost(this);
+        import_meta_host = new Spit.DataImports.WelcomeImportMetaHost(this);
         bool show_system_pictures_import = is_system_pictures_import_possible();
         Gtk.Widget ok_button = add_button(Resources.OK_LABEL, Gtk.ResponseType.CLOSE);
         set_default_response(Gtk.ResponseType.CLOSE);
@@ -111,7 +111,7 @@ public class WelcomeDialog : Gtk.Dialog {
 
         install_import_content();
 
-        //TODO import_meta_host.start();
+        import_meta_host.start();
     }
 
     private void install_import_content() {
diff --git a/src/meson.build b/src/meson.build
index 6f50a098..71d8ae00 100644
--- a/src/meson.build
+++ b/src/meson.build
@@ -158,6 +158,11 @@ executable(
         'config/Config.vala',
         'config/ConfigurationInterfaces.vala',
         'config/GSettingsEngine.vala',
+        'data_imports/DataImports.vala',
+        'data_imports/DataImportsPluginHost.vala',
+        'data_imports/DataImportsUI.vala',
+        'data_imports/DataImportJob.vala',
+        'data_imports/DataImportSource.vala',        
         'folders/Folders.vala',
         'folders/FoldersBranch.vala',
         'folders/FoldersPage.vala',


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]