From 4c548cd33f0614e666d9049e41b4f129629cf182 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=B6rg=20Frings-F=C3=BCrst?= Date: Tue, 5 Apr 2022 17:14:18 +0200 Subject: New upstream version 0.30.15 --- src/DesktopIntegration.vala | 71 ++++++++++++++++++++++++++++----------------- 1 file changed, 44 insertions(+), 27 deletions(-) (limited to 'src/DesktopIntegration.vala') diff --git a/src/DesktopIntegration.vala b/src/DesktopIntegration.vala index 80e8b2e..024bc8b 100644 --- a/src/DesktopIntegration.vala +++ b/src/DesktopIntegration.vala @@ -6,7 +6,6 @@ namespace DesktopIntegration { -private const string SENDTO_EXEC = "nautilus-sendto"; private const string DESKTOP_SLIDESHOW_XML_FILENAME = "wallpaper.xml"; private int init_count = 0; @@ -22,8 +21,12 @@ private bool set_screensaver = false; public void init() { if (init_count++ != 0) return; - - send_to_installed = Environment.find_program_in_path(SENDTO_EXEC) != null; + try{ + Portal.get_instance(); + send_to_installed = true; + } catch (Error error) { + send_to_installed = false; + } } public void terminate() { @@ -90,36 +93,50 @@ public string? get_app_open_command(AppInfo app_info) { } public bool is_send_to_installed() { + // FIXME: Check if portal is available return send_to_installed; } -public void files_send_to(File[] files) { +public async void files_send_to(File[] files) { if (files.length == 0) return; - string[] argv = new string[files.length + 1]; - argv[0] = SENDTO_EXEC; - - for (int ctr = 0; ctr < files.length; ctr++) - argv[ctr + 1] = files[ctr].get_path(); - - try { - AppWindow.get_instance().set_busy_cursor(); - - Pid child_pid; - Process.spawn_async( - "/", - argv, - null, // environment - SpawnFlags.SEARCH_PATH, - null, // child setup - out child_pid); - - AppWindow.get_instance().set_normal_cursor(); - } catch (Error err) { - AppWindow.get_instance().set_normal_cursor(); - AppWindow.error_message(_("Unable to launch Nautilus Send-To: %s").printf(err.message)); + var file_names = new StringBuilder(); + var files_builder = new VariantBuilder (new VariantType ("ah")); + var file_descriptors = new UnixFDList (); + for (int i=0; i (str_hash, str_equal); + options.insert ("subject", _("Send files per Mail: ") + file_names.str); + options.insert ("attachment_fds", files_builder.end()); + options.insert ("addresses", new Variant ("as", null)); + AppWindow.get_instance().set_busy_cursor(); + try{ + var response = yield Portal.get_instance().compose_email (options, file_descriptors); + if (response == null){ + throw new DBusError.FAILED("Did not get response"); + } + } catch (Error e){ + AppWindow.error_message(_("Unable to send file %s, %s").printf( + file_names.str, e.message)); } + AppWindow.get_instance().set_normal_cursor(); } public void send_to(Gee.Collection media) { @@ -150,7 +167,7 @@ public void send_to(Gee.Collection media) { private void on_send_to_export_completed(Exporter exporter, bool is_cancelled) { if (!is_cancelled) - files_send_to(exporter.get_exported_files()); + files_send_to.begin(exporter.get_exported_files()); send_to_exporter = null; } -- cgit v1.2.3