From 51b8c501be7d952e0023a72b24c91254b98fc48c Mon Sep 17 00:00:00 2001
From: Michael Gratton <mike@vee.net>
Date: Sat, 10 Oct 2020 23:55:02 +1100
Subject: [PATCH 063/124] Util.Email: Use a single unambiguous date format for
 reply quote dates

Rather than using the UI pref for 12/24h clocks, use a single format
string that should be reasonably unambiguous and that includes the
time zone.

Fixes #888
---
 src/client/composer/composer-widget.vala |  9 +--
 src/client/util/util-email.vala          | 78 ++++++++++++++----------
 2 files changed, 49 insertions(+), 38 deletions(-)

diff --git a/src/client/composer/composer-widget.vala b/src/client/composer/composer-widget.vala
index 37e93fb4..503727a9 100644
--- a/src/client/composer/composer-widget.vala
+++ b/src/client/composer/composer-widget.vala
@@ -740,7 +740,7 @@ public class Composer.Widget : Gtk.EventBox, Geary.BaseInterface {
             );
             add_recipients_and_ids(type, full_context);
             complete_quote = Util.Email.quote_email_for_reply(
-                full_context, quote, this.config.clock_format, HTML
+                full_context, quote, HTML
             );
             if (!Geary.String.is_empty(quote)) {
                 this.top_posting = false;
@@ -1291,12 +1291,7 @@ public class Composer.Widget : Gtk.EventBox, Geary.BaseInterface {
         // Always use reply styling, since forward styling doesn't
         // work for inline quotes
         this.editor.body.insert_html(
-            Util.Email.quote_email_for_reply(
-                referred,
-                to_quote,
-                this.config.clock_format,
-                Geary.RFC822.TextFormat.HTML
-            )
+            Util.Email.quote_email_for_reply(referred, to_quote, HTML)
         );
     }
 
diff --git a/src/client/util/util-email.vala b/src/client/util/util-email.vala
index a18a45cf..4a1754a7 100644
--- a/src/client/util/util-email.vala
+++ b/src/client/util/util-email.vala
@@ -177,41 +177,57 @@ namespace Util.Email {
      */
     public string quote_email_for_reply(Geary.Email email,
                                         string? quote,
-                                        Util.Date.ClockFormat clock_format,
                                         Geary.RFC822.TextFormat format) {
-        if (email.body == null && quote == null)
-            return "";
-
         string quoted = "";
+        if (email.body != null || quote != null) {
+            /// GLib g_date_time_format format string for the date and
+            /// time that a message being replied to was
+            /// received. This should be roughly similar to an RFC
+            /// 822-style date header value with optional additional
+            /// punctuation for readability. Note that this date may
+            /// be sent to someone in a different locale than the
+            /// sender, so should be unambiguous (for example, do not
+            /// use mm/dd/yyyy since it could be confused with
+            /// dd/mm/yyyy) and must include the time zone.
+            string date_format = _("%a, %b %-e %Y at %X %Z");
 
-        string DATE_FORMAT = Util.Date.get_full_date(clock_format);
-
-        if (email.date != null && email.from != null) {
-            /// The quoted header for a message being replied to.
-            /// %1$s will be substituted for the date, and %2$s will be substituted for
-            /// the original sender.
-            string QUOTED_LABEL = _("On %1$s, %2$s wrote:");
-            quoted += QUOTED_LABEL.printf(email.date.value.format(DATE_FORMAT),
-                                          Geary.RFC822.Utils.email_addresses_for_reply(email.from, format));
-
-        } else if (email.from != null) {
-            /// The quoted header for a message being replied to (in case the date is not known).
-            /// %s will be replaced by the original sender.
-            string QUOTED_LABEL = _("%s wrote:");
-            quoted += QUOTED_LABEL.printf(Geary.RFC822.Utils.email_addresses_for_reply(email.from, format));
-
-        } else if (email.date != null) {
-            /// The quoted header for a message being replied to (in case the sender is not known).
-            /// %s will be replaced by the original date
-            string QUOTED_LABEL = _("On %s:");
-            quoted += QUOTED_LABEL.printf(email.date.value.format(DATE_FORMAT));
-        }
+            if (email.date != null && email.from != null) {
+                /// The quoted header for a message being replied to.
+                /// %1$s will be substituted for the date, and %2$s
+                /// will be substituted for the original sender.
+                string QUOTED_LABEL = _("On %1$s, %2$s wrote:");
+                quoted += QUOTED_LABEL.printf(
+                    email.date.value.format(date_format),
+                    Geary.RFC822.Utils.email_addresses_for_reply(
+                        email.from, format
+                    )
+                );
+            } else if (email.from != null) {
+                /// The quoted header for a message being replied to
+                /// (in case the date is not known).  %s will be
+                /// replaced by the original sender.
+                string QUOTED_LABEL = _("%s wrote:");
+                quoted += QUOTED_LABEL.printf(
+                    Geary.RFC822.Utils.email_addresses_for_reply(
+                        email.from, format
+                    )
+                );
+            } else if (email.date != null) {
+                /// The quoted header for a message being replied to
+                /// (in case the sender is not known).  %s will be
+                /// replaced by the original date
+                string QUOTED_LABEL = _("On %s:");
+                quoted += QUOTED_LABEL.printf(
+                    email.date.value.format(date_format)
+                );
+            }
 
-        quoted += "<br />";
-        try {
-            quoted += quote_body(email, quote, true, format);
-        } catch (Error err) {
-            debug("Failed to quote body for replying: %s".printf(err.message));
+            quoted += "<br />";
+            try {
+                quoted += quote_body(email, quote, true, format);
+            } catch (Error err) {
+                debug("Failed to quote body for replying: %s".printf(err.message));
+            }
         }
 
         return quoted;
-- 
2.29.2