X-Git-Url: http://git.maemo.org/git/?p=modest;a=blobdiff_plain;f=src%2Fwidgets%2Fmodest-details-dialog.c;h=3a8ec1c65a57d0f189ce13e0fc6ced14f65a4297;hp=68de19cb26a92f27052a1cda6890fa797598c22b;hb=16d7f8b9f45217e350735e33ee6d0255aa894074;hpb=dc84efe84c22be9c1b6247a8ee29cfd1d675d21d diff --git a/src/widgets/modest-details-dialog.c b/src/widgets/modest-details-dialog.c index 68de19c..3a8ec1c 100644 --- a/src/widgets/modest-details-dialog.c +++ b/src/widgets/modest-details-dialog.c @@ -37,10 +37,11 @@ #include #include #include -#include +#include #include +#include #include - +#include /* for strlen */ static void modest_details_dialog_set_header_default (ModestDetailsDialog *self, TnyHeader *header); @@ -201,6 +202,8 @@ modest_details_dialog_set_header_default (ModestDetailsDialog *self, folder_type = modest_tny_folder_guess_folder_type (folder); g_object_unref (folder); + g_return_if_fail (folder_type != TNY_FOLDER_TYPE_INVALID); + /* Get header data */ from = g_strdup (tny_header_get_from (header)); to = g_strdup (tny_header_get_to (header)); @@ -219,54 +222,51 @@ modest_details_dialog_set_header_default (ModestDetailsDialog *self, if (cc == NULL) cc = g_strdup (""); - /* Add from and subject */ + /* Add from and subject for all folders */ modest_details_dialog_add_data (self, _("mcen_fi_message_properties_from"), from); modest_details_dialog_add_data (self, _("mcen_fi_message_properties_subject"), subject); - /* Set received (optional) */ + + /* for inbox, user-created folders and archive: Received */ if (received && (folder_type != TNY_FOLDER_TYPE_SENT) && (folder_type != TNY_FOLDER_TYPE_DRAFTS) && (folder_type != TNY_FOLDER_TYPE_OUTBOX)) { - + modest_text_utils_strftime (date_time_buffer, DATE_TIME_BUFFER_SIZE, "%x %X", received); modest_details_dialog_add_data (self, _("mcen_fi_message_properties_received"), date_time_buffer); - modest_text_utils_strftime (date_time_buffer, DATE_TIME_BUFFER_SIZE, "%x %X", - sent); - modest_details_dialog_add_data (self, _("mcen_fi_message_properties_created"), - date_time_buffer); } - if (sent && (folder_type == TNY_FOLDER_TYPE_SENT)) { + /* for outbox, drafts: Modified: (_created) */ + if ((folder_type == TNY_FOLDER_TYPE_DRAFTS) || + (folder_type == TNY_FOLDER_TYPE_OUTBOX) || + (folder_type == TNY_FOLDER_TYPE_SENT)) { modest_text_utils_strftime (date_time_buffer, DATE_TIME_BUFFER_SIZE, "%x %X", received); modest_details_dialog_add_data (self, _("mcen_fi_message_properties_created"), date_time_buffer); } - /* Set date sent (optional) */ + + /* for everyting except outbox, drafts: Sent */ if (sent && (folder_type != TNY_FOLDER_TYPE_DRAFTS)&& (folder_type != TNY_FOLDER_TYPE_OUTBOX)) { - + modest_text_utils_strftime (date_time_buffer, DATE_TIME_BUFFER_SIZE, "%x %X", sent); modest_details_dialog_add_data (self, _("mcen_fi_message_properties_sent"), date_time_buffer); } - - if ((folder_type == TNY_FOLDER_TYPE_DRAFTS)|| (folder_type == TNY_FOLDER_TYPE_OUTBOX)) { - modest_text_utils_strftime (date_time_buffer, DATE_TIME_BUFFER_SIZE, "%x %X", - received); - modest_details_dialog_add_data (self, _("mcen_fi_message_properties_created"), - date_time_buffer); - } - + /* Set To and CC */ modest_details_dialog_add_data (self, _("mcen_fi_message_properties_to"), to); - modest_details_dialog_add_data (self, _("mcen_fi_message_properties_cc"), cc); + + /* only show cc when it's there */ + if (cc && strlen(cc) > 0) + modest_details_dialog_add_data (self, _("mcen_fi_message_properties_cc"), cc); /* Set size */ - if (size < 0) + if (size <= 0) size_s = g_strdup (_("mcen_va_message_properties_size_noinfo")); else size_s = modest_text_utils_get_display_size (size); @@ -284,19 +284,24 @@ static void modest_details_dialog_set_folder_default (ModestDetailsDialog *self, TnyFolder *folder) { - TnyFolderStats *stats; - gchar *count, *size_s, *name = NULL; - gint size; + gchar *count_s, *size_s, *name = NULL; + gint size, count; + + + g_return_if_fail (folder && TNY_IS_FOLDER (folder)); + g_return_if_fail (modest_tny_folder_get_local_or_mmc_folder_type (folder) + != TNY_FOLDER_TYPE_INVALID); /* Set window title */ gtk_window_set_title (GTK_WINDOW (self), _("mcen_ti_folder_properties")); gtk_dialog_add_button (GTK_DIALOG (self), _("mcen_bd_close"), GTK_RESPONSE_CLOSE); - /* Get stats */ - stats = tny_folder_get_stats (folder); - count = g_strdup_printf ("%d", tny_folder_stats_get_all_count (stats)); - /* Format the size */ - size = tny_folder_stats_get_local_size (stats); + /* Get data. We use our function because it's recursive */ + count = modest_tny_folder_store_get_message_count (TNY_FOLDER_STORE (folder)); + size = modest_tny_folder_store_get_local_size (TNY_FOLDER_STORE (folder)); + + /* Format count and size */ + count_s = g_strdup_printf ("%d", count); if (size <= 0) size_s = g_strdup (_("mcen_va_message_properties_size_noinfo")); else @@ -313,14 +318,13 @@ modest_details_dialog_set_folder_default (ModestDetailsDialog *self, name = g_strdup (tny_folder_get_name (folder)); modest_details_dialog_add_data (self, _("mcen_fi_folder_properties_foldername"), name); - modest_details_dialog_add_data (self, _("mcen_fi_folder_properties_messages"), count); + modest_details_dialog_add_data (self, _("mcen_fi_folder_properties_messages"), count_s); modest_details_dialog_add_data (self, _("mcen_fi_folder_properties_size"), size_s); /* Frees */ g_free (name); g_free (size_s); - g_free (count); - g_object_unref (stats); + g_free (count_s); } static void