* Set focus on next row after delete selected headers
[modest] / src / widgets / modest-attachment-view.c
index da3456a..12bb23c 100644 (file)
@@ -38,6 +38,7 @@
 #include <modest-platform.h>
 #include <modest-text-utils.h>
 #include <tny-msg.h>
+#include <tny-camel-mem-stream.h>
 
 static GObjectClass *parent_class = NULL;
 
@@ -56,6 +57,7 @@ struct _ModestAttachmentViewPriv
        guint64 size;
 
        PangoLayout *layout_full_filename;
+       gboolean is_purged;
 
 };
 
@@ -128,7 +130,7 @@ modest_attachment_view_set_part (TnyMimePartView *self, TnyMimePart *mime_part)
 
 static gboolean
 get_size_idle_func (gpointer data)
-{
+{      
        ModestAttachmentView *self = (ModestAttachmentView *) data;
        ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
        gssize readed_size;
@@ -136,7 +138,13 @@ get_size_idle_func (gpointer data)
        gchar *size_string;
 
        if (priv->get_size_stream == NULL) {
-               priv->get_size_stream = tny_mime_part_get_stream (priv->mime_part);
+               priv->get_size_stream = tny_camel_mem_stream_new ();
+               tny_mime_part_decode_to_stream (priv->mime_part, priv->get_size_stream);
+               tny_stream_reset (priv->get_size_stream);
+               if (tny_stream_is_eos (priv->get_size_stream)) {
+                       tny_stream_close (priv->get_size_stream);
+                       priv->get_size_stream = tny_mime_part_get_stream (priv->mime_part);
+               }
        }
 
        readed_size = tny_stream_read (priv->get_size_stream, read_buffer, GET_SIZE_BUFFER_SIZE);
@@ -145,6 +153,8 @@ get_size_idle_func (gpointer data)
        if (tny_stream_is_eos (priv->get_size_stream)) {
                gchar *display_size;
 
+               gdk_threads_enter ();
+
                display_size = modest_text_utils_get_display_size (priv->size);
                size_string = g_strdup_printf (" (%s)", display_size);
                g_free (display_size);
@@ -156,18 +166,19 @@ get_size_idle_func (gpointer data)
                gtk_widget_queue_resize (priv->size_view);
                priv->get_size_stream = NULL;
                priv->get_size_idle_id = 0;
-       }
 
+               gdk_threads_leave ();
+       }
        return (priv->get_size_stream != NULL);
-       
 }
 
 static void
 modest_attachment_view_set_part_default (TnyMimePartView *self, TnyMimePart *mime_part)
 {
        ModestAttachmentViewPriv *priv = NULL;
-       const gchar *filename = NULL;
+       gchar *filename = NULL;
        gchar *file_icon_name = NULL;
+       gboolean show_size = FALSE;
        
        g_return_if_fail (TNY_IS_MIME_PART_VIEW (self));
        g_return_if_fail (TNY_IS_MIME_PART (mime_part));
@@ -190,21 +201,28 @@ modest_attachment_view_set_part_default (TnyMimePartView *self, TnyMimePart *mim
        }
 
        priv->size = 0;
-
-       if (TNY_IS_MSG (mime_part)) {
+       priv->is_purged = tny_mime_part_is_purged (mime_part);
+       
+       if (priv->is_purged) {
+               filename = g_strdup( tny_mime_part_get_filename (mime_part));
+               if (filename == NULL)
+                       filename = g_strdup ("");
+               file_icon_name = modest_platform_get_file_icon_name (NULL, NULL, NULL);
+       } else if (TNY_IS_MSG (mime_part)) {
                TnyHeader *header = tny_msg_get_header (TNY_MSG (mime_part));
                if (TNY_IS_HEADER (header)) {
-                       filename = tny_header_get_subject (header);
+                       filename = g_strdup (tny_header_get_subject (header));
                        if (filename == NULL)
-                               filename = _("mail_va_no_subject");
+                               filename = g_strdup (_("mail_va_no_subject"));
                        file_icon_name = modest_platform_get_file_icon_name (NULL, tny_mime_part_get_content_type (mime_part), NULL);
                        g_object_unref (header);
                }
        } else {
-               filename = tny_mime_part_get_filename (mime_part);
+               filename = g_strdup (tny_mime_part_get_filename (mime_part));
                file_icon_name = modest_platform_get_file_icon_name (filename, 
                                                                     tny_mime_part_get_content_type (mime_part), 
                                                                     NULL);
+               show_size = TRUE;
        }
 
        if (file_icon_name) {
@@ -214,12 +232,22 @@ modest_attachment_view_set_part_default (TnyMimePartView *self, TnyMimePart *mim
                gtk_image_set_from_icon_name (GTK_IMAGE (priv->icon), UNKNOWN_FILE_ICON, GTK_ICON_SIZE_MENU);
        }
 
-       gtk_label_set_text (GTK_LABEL (priv->filename_view), filename);
+       if (priv->is_purged) {
+               gchar * label_str = g_markup_printf_escaped(
+                       "<span style='italic' foreground='grey'>%s</span>",
+                       filename);
+               gtk_label_set_markup (GTK_LABEL (priv->filename_view), label_str);
+               g_free (label_str);
+       } else {
+               gtk_label_set_text (GTK_LABEL (priv->filename_view), filename);
+       }
+       g_free (filename);
        update_filename_request (MODEST_ATTACHMENT_VIEW (self));
 
-       gtk_label_set_text (GTK_LABEL (priv->size_view), " ");
+       gtk_label_set_text (GTK_LABEL (priv->size_view), "");
 
-       priv->get_size_idle_id = g_idle_add ((GSourceFunc) get_size_idle_func, (gpointer) self);
+       if (show_size)
+               priv->get_size_idle_id = g_idle_add ((GSourceFunc) get_size_idle_func, (gpointer) self);
 
        gtk_widget_queue_draw (GTK_WIDGET (self));
 }