[geary/mjog/mail-merge-plugin: 10/10] Plugin.MailMerge: Add info bar to merge folder with status and actions




commit 73ee3770894e29d42dfe9b2c07fd0fbe98f94b9d
Author: Michael Gratton <mike vee net>
Date:   Fri Aug 14 16:06:44 2020 +1000

    Plugin.MailMerge: Add info bar to merge folder with status and actions

 src/client/plugin/mail-merge/mail-merge.vala | 92 ++++++++++++++++++++++++++++
 1 file changed, 92 insertions(+)
---
diff --git a/src/client/plugin/mail-merge/mail-merge.vala b/src/client/plugin/mail-merge/mail-merge.vala
index 5d21a440f..7f7fd202c 100644
--- a/src/client/plugin/mail-merge/mail-merge.vala
+++ b/src/client/plugin/mail-merge/mail-merge.vala
@@ -38,6 +38,8 @@ public class Plugin.MailMerge :
     private const string ACTION_INSERT_FIELD = "insert-field";
     private const string ACTION_MERGE = "merge-template";
     private const string ACTION_LOAD = "load-merge-data";
+    private const string ACTION_START = "start-send";
+    private const string ACTION_PAUSE = "pause-send";
 
     private const int INFO_BAR_PRIORITY = 10;
 
@@ -62,9 +64,15 @@ public class Plugin.MailMerge :
     private EmailStore? email_store = null;
 
     private global::MailMerge.Folder? merge_folder = null;
+    private InfoBar merge_bar = null;
 
     private GLib.SimpleAction? edit_action = null;
     private GLib.SimpleAction? merge_action = null;
+    private GLib.SimpleAction? start_action = null;
+    private GLib.SimpleAction? pause_action = null;
+
+    private Actionable? start_ui = null;
+    private Actionable? pause_ui = null;
 
     private Gee.List<string> folder_names = new Gee.ArrayList<string>();
 
@@ -83,6 +91,7 @@ public class Plugin.MailMerge :
 
         this.folder_store = yield this.folders.get_folder_store();
         this.folder_store.folders_available.connect(on_folders_available);
+        this.folder_store.folder_selected.connect(on_folder_selected);
 
         this.email_store = yield this.email.get_email_store();
         this.email_store.email_displayed.connect(on_email_displayed);
@@ -99,6 +108,30 @@ public class Plugin.MailMerge :
         this.merge_action.activate.connect(on_merge_activated);
         this.plugin_application.register_action(this.merge_action);
 
+        this.start_action = new GLib.SimpleAction(ACTION_START, null);
+        this.start_action.activate.connect(on_start_activated);
+        this.plugin_application.register_action(this.start_action);
+
+        this.start_ui = new Actionable.with_icon(
+            // Translators: Info bar label for starting sending a mail
+            // merge
+            _("Start"),
+            "media-playback-start-symbolic",
+            this.start_action
+        );
+
+        this.pause_action = new GLib.SimpleAction(ACTION_PAUSE, null);
+        this.pause_action.activate.connect(on_pause_activated);
+        this.plugin_application.register_action(this.pause_action);
+
+        this.pause_ui = new Actionable.with_icon(
+            // Translators: Info bar label for pausing sending a mail
+            // merge
+            _("Pause"),
+            "media-playback-pause-symbolic",
+            this.pause_action
+        );
+
         this.plugin_application.composer_registered.connect(
             this.on_composer_registered
         );
@@ -174,6 +207,19 @@ public class Plugin.MailMerge :
                         csv
                     );
 
+                    this.merge_bar = new InfoBar(
+                        this.merge_folder.data_display_name, ""
+                    );
+                    update_merge_folder_info_bar();
+                    this.merge_bar.show_close_button = true;
+                    this.merge_bar.close_activated.connect(on_merge_closed);
+                    this.merge_folder.notify["email-sent"].connect(
+                        () => { update_merge_folder_info_bar(); }
+                    );
+                    this.merge_folder.notify["email-total"].connect(
+                        () => { update_merge_folder_info_bar(); }
+                    );
+
                     account_context.account.register_local_folder(
                         this.merge_folder
                     );
@@ -186,6 +232,19 @@ public class Plugin.MailMerge :
         }
     }
 
+    private void update_merge_folder_info_bar() {
+        // Translators: Info bar description for the mail merge
+        // folder. The first string substitution the number of email
+        // already sent, the second is the total number to send.
+        this.merge_bar.description = _("Sent %u of %u").printf(
+            this.merge_folder.email_sent,
+            this.merge_folder.email_total
+        );
+        this.merge_bar.primary_button = (
+            (this.merge_folder.is_sending) ? this.pause_ui : this.start_ui
+        );
+    }
+
     private async void update_email(Email target) {
         var containing = Gee.Collection.empty<Folder>();
         try {
@@ -385,10 +444,34 @@ public class Plugin.MailMerge :
         }
     }
 
+    private void on_start_activated(GLib.Action action, GLib.Variant? target) {
+        this.merge_folder.set_sending(true);
+        update_merge_folder_info_bar();
+    }
+
+    private void on_pause_activated(GLib.Action action, GLib.Variant? target) {
+        this.merge_folder.set_sending(false);
+        update_merge_folder_info_bar();
+    }
+
     private void on_composer_registered(Composer registered) {
         this.update_composer.begin(registered);
     }
 
+    private void on_merge_closed() {
+        if (this.merge_folder != null) {
+            try {
+                this.merge_folder.account.deregister_local_folder(
+                    this.merge_folder
+                );
+            } catch (GLib.Error err) {
+                warning("Error de-registering merge folder: %s", err.message);
+            }
+            this.merge_folder = null;
+            this.merge_bar = null;
+        }
+    }
+
     private void on_folders_available(Gee.Collection<Folder> available) {
         foreach (var folder in available) {
             var engine_folder = this.client_plugins.to_engine_folder(folder);
@@ -412,6 +495,15 @@ public class Plugin.MailMerge :
         }
     }
 
+    private void on_folder_selected(Folder selected) {
+        var engine_folder = this.client_plugins.to_engine_folder(selected);
+        if (this.merge_folder == engine_folder) {
+            this.folders.add_folder_info_bar(
+                selected, this.merge_bar, INFO_BAR_PRIORITY
+            );
+        }
+    }
+
     private void on_email_displayed(Email email) {
         this.update_email.begin(email);
     }


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