* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
+#ifdef HAVE_CONFIG_H
#include <config.h>
+#endif /*HAVE_CONFIG_H*/
-//#include <glib/gi18n-lib.h>
+#include <glib/gi18n.h>
#include <string.h>
#include <modest-attachment-view.h>
#include <modest-platform.h>
#include <modest-text-utils.h>
+#include <modest-tny-mime-part.h>
+#include <tny-msg.h>
+#include <modest-mail-operation.h>
+#include <modest-mail-operation-queue.h>
+#include <modest-runtime.h>
+#include <modest-count-stream.h>
-static GObjectClass *parent_class = NULL;
+#define GET_SIZE_BUFFER_SIZE 128
-/* signals */
-enum {
- ACTIVATE_SIGNAL,
- LAST_SIGNAL
-};
+static GObjectClass *parent_class = NULL;
-typedef struct _ModestAttachmentViewPriv ModestAttachmentViewPriv;
+typedef struct _ModestAttachmentViewPrivate ModestAttachmentViewPrivate;
-struct _ModestAttachmentViewPriv
+struct _ModestAttachmentViewPrivate
{
TnyMimePart *mime_part;
GtkWidget *filename_view;
GtkWidget *size_view;
- guint get_size_idle_id;
+ gboolean detect_size;
TnyStream *get_size_stream;
- guint size;
+ guint64 size;
PangoLayout *layout_full_filename;
+ gboolean is_purged;
- gboolean button_pressed;
- gdouble pressed_x, pressed_y;
};
+#ifdef MODEST_TOOLKIT_HILDON2
+#define UNKNOWN_FILE_ICON "filemanager_unknown_file"
+#else
#define UNKNOWN_FILE_ICON "qgn_list_gene_unknown_file"
-#define GET_SIZE_BUFFER_SIZE 128
+#endif
#define MODEST_ATTACHMENT_VIEW_GET_PRIVATE(o) \
- (G_TYPE_INSTANCE_GET_PRIVATE ((o), MODEST_TYPE_ATTACHMENT_VIEW, ModestAttachmentViewPriv))
-
-static guint signals[LAST_SIGNAL] = {0};
+ (G_TYPE_INSTANCE_GET_PRIVATE ((o), MODEST_TYPE_ATTACHMENT_VIEW, ModestAttachmentViewPrivate))
/* TnyMimePartView functions */
static TnyMimePart *modest_attachment_view_get_part (TnyMimePartView *self);
static void modest_attachment_view_clear_default (TnyMimePartView *self);
/* Gtk events */
-static gint button_press_event (GtkWidget *widget, GdkEventButton *event, gpointer user_data);
-static gint button_release_event (GtkWidget *widget, GdkEventButton *event, gpointer user_data);
static void size_allocate (GtkWidget *widget, GtkAllocation *allocation);
/* GObject and GInterface management */
-static gboolean get_size_idle_func (gpointer data);
static void update_filename_request (ModestAttachmentView *self);
+static void update_size_label (ModestAttachmentView *self)
+{
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
+ gchar *size_str;
+ gchar *label_text;
+
+ size_str = modest_text_utils_get_display_size (priv->size);
+ label_text = g_strdup_printf (" (%s)", size_str);
+ g_free (size_str);
+ gtk_label_set_text (GTK_LABEL (priv->size_view), label_text);
+ g_free (label_text);
+}
+
+static gboolean
+idle_get_mime_part_size_cb (gpointer userdata)
+{
+ ModestAttachmentView *view = (ModestAttachmentView *) userdata;
+ gdk_threads_enter ();
+
+ if (GTK_WIDGET_VISIBLE (view)) {
+ update_size_label (view);
+ }
+
+ gdk_threads_leave ();
+
+ g_object_unref (view);
+
+ return FALSE;
+}
+
+static gpointer
+get_mime_part_size_thread (gpointer thr_user_data)
+{
+ ModestAttachmentView *view = (ModestAttachmentView *) thr_user_data;
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (view);
+ gsize total = 0;
+ gssize result = 0;
+
+ result = tny_mime_part_decode_to_stream (priv->mime_part, priv->get_size_stream, NULL);
+ total = modest_count_stream_get_count(MODEST_COUNT_STREAM (priv->get_size_stream));
+ if (total == 0) {
+ modest_count_stream_reset_count(MODEST_COUNT_STREAM (priv->get_size_stream));
+ result = tny_mime_part_write_to_stream (priv->mime_part, priv->get_size_stream, NULL);
+ total = modest_count_stream_get_count(MODEST_COUNT_STREAM (priv->get_size_stream));
+ }
+
+ /* if there was an error, don't set the size (this is pretty uncommon) */
+ if (result < 0) {
+ g_warning ("%s: error while writing mime part to stream\n", __FUNCTION__);
+ } else {
+ priv->size = (guint64)total;
+ g_idle_add (idle_get_mime_part_size_cb, g_object_ref (view));
+ }
+ g_object_unref (view);
+
+ return NULL;
+}
+
+void
+modest_attachment_view_set_detect_size (ModestAttachmentView *self, gboolean detect_size)
+{
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
+ priv->detect_size = detect_size;
+
+}
+
+void
+modest_attachment_view_set_size (ModestAttachmentView *self, guint64 size)
+{
+ ModestAttachmentViewPrivate *priv;
+
+ g_return_if_fail (MODEST_IS_ATTACHMENT_VIEW (self));
+ priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
+
+ if (!priv->detect_size) {
+ priv->size = size;
+ update_size_label (self);
+ } else {
+ g_assert ("Shouldn't set the size of the attachment view if detect size is enabled");
+ }
+}
+
+guint64
+modest_attachment_view_get_size (ModestAttachmentView *self)
+{
+ ModestAttachmentViewPrivate *priv;
+
+ g_return_val_if_fail (MODEST_IS_ATTACHMENT_VIEW (self), 0);
+ priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
+
+ return priv->size;
+}
static TnyMimePart *
modest_attachment_view_get_part (TnyMimePartView *self)
static TnyMimePart *
modest_attachment_view_get_part_default (TnyMimePartView *self)
{
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
if (priv->mime_part)
return TNY_MIME_PART (g_object_ref (priv->mime_part));
static void
update_filename_request (ModestAttachmentView *self)
{
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
/* gint width, height; */
pango_layout_set_text (PANGO_LAYOUT (priv->layout_full_filename),
}
-static gboolean
-get_size_idle_func (gpointer data)
-{
- ModestAttachmentView *self = (ModestAttachmentView *) data;
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
- gssize readed_size;
- gchar read_buffer[GET_SIZE_BUFFER_SIZE];
- gchar *size_string;
-
- if (priv->get_size_stream == NULL) {
- 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);
- priv->size += readed_size;
-
- if (tny_stream_is_eos (priv->get_size_stream)) {
- gchar *display_size;
-
- display_size = modest_text_utils_get_display_size (priv->size);
- size_string = g_strdup_printf (" (%s)", display_size);
- g_free (display_size);
- gtk_label_set_text (GTK_LABEL (priv->size_view), size_string);
- g_free (size_string);
-
- g_object_unref (priv->get_size_stream);
-
- gtk_widget_queue_resize (priv->size_view);
- priv->get_size_stream = NULL;
- priv->get_size_idle_id = 0;
- }
-
- 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;
- gchar *file_icon_name;
+ ModestAttachmentViewPrivate *priv = 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));
g_object_unref (priv->mime_part);
}
- priv->mime_part = mime_part;
-
- if (priv->get_size_idle_id != 0) {
- g_source_remove (priv->get_size_idle_id);
- priv->get_size_idle_id = 0;
- }
-
- if (priv->get_size_stream != NULL) {
- g_object_unref (priv->get_size_stream);
- priv->get_size_stream = NULL;
- }
+ priv->mime_part = g_object_ref (mime_part);
priv->size = 0;
-
- filename = 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);
+ priv->is_purged = tny_mime_part_is_purged (mime_part);
+
+ if (TNY_IS_MSG (mime_part)) {
+ TnyHeader *header = tny_msg_get_header (TNY_MSG (mime_part));
+ if (TNY_IS_HEADER (header)) {
+ filename = g_strdup (tny_mime_part_get_filename (mime_part));
+ if (!filename)
+ filename = tny_header_dup_subject (header);
+ if (filename == NULL || filename[0] == '\0')
+ filename = g_strdup (_("mail_va_no_subject"));
+ if (priv->is_purged) {
+ file_icon_name = modest_platform_get_file_icon_name (NULL, NULL, NULL);
+ } else {
+ gchar *header_content_type;
+ header_content_type = modest_tny_mime_part_get_content_type (mime_part);
+ if ((g_str_has_prefix (header_content_type, "message/rfc822") ||
+ g_str_has_prefix (header_content_type, "multipart/") ||
+ g_str_has_prefix (header_content_type, "text/"))) {
+ file_icon_name =
+ modest_platform_get_file_icon_name (
+ NULL, tny_mime_part_get_content_type (mime_part), NULL);
+ } else {
+ file_icon_name =
+ modest_platform_get_file_icon_name (
+ NULL, header_content_type, NULL);
+ }
+ g_free (header_content_type);
+ }
+ g_object_unref (header);
+ }
+ } else {
+ filename = g_strdup (tny_mime_part_get_filename (mime_part));
+ if (priv->is_purged) {
+ file_icon_name = modest_platform_get_file_icon_name (NULL, NULL, NULL);
+ } else {
+ file_icon_name = modest_platform_get_file_icon_name (
+ filename, modest_tny_mime_part_get_content_type (mime_part), NULL);
+ show_size = TRUE;
+ }
+ }
if (file_icon_name) {
gtk_image_set_from_icon_name (GTK_IMAGE (priv->icon), file_icon_name, GTK_ICON_SIZE_MENU);
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->detect_size) {
+ g_object_ref (self);
+ if (!priv->get_size_stream)
+ priv->get_size_stream = modest_count_stream_new ();
+ g_thread_create (get_mime_part_size_thread, self, FALSE, NULL);
+ }
gtk_widget_queue_draw (GTK_WIDGET (self));
}
static void
modest_attachment_view_clear_default (TnyMimePartView *self)
{
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
if (priv->mime_part != NULL) {
g_object_unref (priv->mime_part);
priv->mime_part = NULL;
}
- if (priv->get_size_idle_id != 0) {
- g_source_remove (priv->get_size_idle_id);
- priv->get_size_idle_id = 0;
- }
-
- if (priv->get_size_stream != NULL) {
- g_object_unref (priv->get_size_stream);
- priv->get_size_stream = NULL;
- }
+ if (priv->get_size_stream)
+ modest_count_stream_reset_count(MODEST_COUNT_STREAM (priv->get_size_stream));
priv->size = 0;
gtk_widget_queue_draw (GTK_WIDGET (self));
}
-static gint
-button_press_event (GtkWidget *widget,
- GdkEventButton *event,
- gpointer user_data)
-{
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (MODEST_ATTACHMENT_VIEW (user_data));
-
- if (event->type == GDK_BUTTON_PRESS && event->button == 1) {
- priv->button_pressed = TRUE;
- priv->pressed_x = event->x;
- priv->pressed_y = event->y;
- }
- return TRUE;
-}
-
-static gint
-button_release_event (GtkWidget *widget,
- GdkEventButton *event,
- gpointer user_data)
-{
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (MODEST_ATTACHMENT_VIEW (user_data));
-
- if (event->type != GDK_BUTTON_RELEASE)
- return TRUE;
-
- if ((priv->button_pressed) &&
- (event->type == GDK_BUTTON_RELEASE) &&
- (priv->pressed_x == event->x) &&
- (priv->pressed_y == event->y)) {
- priv->button_pressed = FALSE;
- if (event->button == 1) {
- g_signal_emit (G_OBJECT (user_data), signals[ACTIVATE_SIGNAL], 0);
- return TRUE;
- }
- }
- priv->button_pressed = FALSE;
- return TRUE;
-}
-
-
/**
* modest_attachment_view_new:
* Return value: a new #ModestAttachmentView instance implemented for Gtk+
**/
GtkWidget*
-modest_attachment_view_new (TnyMimePart *mime_part)
+modest_attachment_view_new (TnyMimePart *mime_part, gboolean detect_size)
{
ModestAttachmentView *self = g_object_new (MODEST_TYPE_ATTACHMENT_VIEW,
- "homogeneous", FALSE,
- "spacing", 0,
NULL);
+ modest_attachment_view_set_detect_size (self, detect_size);
+
modest_attachment_view_set_part (TNY_MIME_PART_VIEW (self), mime_part);
return GTK_WIDGET (self);
static void
modest_attachment_view_instance_init (GTypeInstance *instance, gpointer g_class)
{
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (instance);
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (instance);
PangoContext *context;
- GtkWidget *icon_eventbox;
+ GtkWidget *box = NULL;
+
+#ifdef MODEST_TOOLKIT_HILDON2
+ PangoAttrList *attr_list;
+ attr_list = pango_attr_list_new ();
+ pango_attr_list_insert (attr_list, pango_attr_underline_new (PANGO_UNDERLINE_SINGLE));
+#endif
priv->mime_part = NULL;
priv->icon = gtk_image_new ();
gtk_label_set_line_wrap (GTK_LABEL (priv->filename_view), FALSE);
gtk_label_set_ellipsize (GTK_LABEL (priv->filename_view), PANGO_ELLIPSIZE_END);
gtk_label_set_single_line_mode (GTK_LABEL (priv->filename_view), TRUE);
- gtk_label_set_selectable (GTK_LABEL (priv->filename_view), TRUE);
+ gtk_label_set_selectable (GTK_LABEL (priv->filename_view), FALSE);
priv->size_view = gtk_label_new (" ");
gtk_label_set_line_wrap (GTK_LABEL (priv->size_view), FALSE);
- gtk_label_set_selectable (GTK_LABEL (priv->size_view), TRUE);
+ gtk_label_set_selectable (GTK_LABEL (priv->size_view), FALSE);
gtk_misc_set_alignment (GTK_MISC (priv->size_view), 0.0, 0.5);
gtk_misc_set_alignment (GTK_MISC (priv->filename_view), 0.0, 0.5);
- priv->get_size_idle_id = 0;
+#ifdef MODEST_TOOLKIT_HILDON2
+ gtk_label_set_attributes (GTK_LABEL (priv->filename_view), attr_list);
+ gtk_label_set_attributes (GTK_LABEL (priv->size_view), attr_list);
+#endif
+
priv->get_size_stream = NULL;
priv->size = 0;
+ priv->detect_size = TRUE;
- icon_eventbox = gtk_event_box_new ();
+ box = gtk_hbox_new (FALSE, 0);
+ gtk_box_pack_start (GTK_BOX (box), priv->icon, FALSE, FALSE, 0);
+ gtk_box_pack_start (GTK_BOX (box), priv->filename_view, TRUE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (box), priv->size_view, FALSE, FALSE, 0);
+ gtk_container_add (GTK_CONTAINER (instance), box);
- gtk_container_add (GTK_CONTAINER (icon_eventbox), priv->icon);
- gtk_box_pack_start (GTK_BOX (instance), icon_eventbox, FALSE, FALSE, 0);
- gtk_box_pack_start (GTK_BOX (instance), priv->filename_view, TRUE, TRUE, 0);
- gtk_box_pack_start (GTK_BOX (instance), priv->size_view, FALSE, FALSE, 0);
+/* gtk_widget_get_style */
+/* gtk_widget_modify_bg (instance, GTK_STATE_SELECTED, selection_color); */
context = gtk_widget_get_pango_context (priv->filename_view);
priv->layout_full_filename = pango_layout_new (context);
pango_layout_set_ellipsize (priv->layout_full_filename, PANGO_ELLIPSIZE_NONE);
- g_signal_connect (G_OBJECT (priv->filename_view), "button-press-event", G_CALLBACK (button_press_event), instance);
- g_signal_connect (G_OBJECT (priv->filename_view), "button-release-event", G_CALLBACK (button_release_event), instance);
- g_signal_connect (G_OBJECT (priv->size_view), "button-press-event", G_CALLBACK (button_press_event), instance);
- g_signal_connect (G_OBJECT (priv->size_view), "button-release-event", G_CALLBACK (button_release_event), instance);
- g_signal_connect (G_OBJECT (icon_eventbox), "button-press-event", G_CALLBACK (button_press_event), instance);
- g_signal_connect (G_OBJECT (icon_eventbox), "button-release-event", G_CALLBACK (button_release_event), instance);
+ gtk_event_box_set_above_child (GTK_EVENT_BOX (instance), FALSE);
+ gtk_event_box_set_visible_window (GTK_EVENT_BOX (instance), TRUE);
+ gtk_widget_set_events (GTK_WIDGET (instance), 0);
+
+#ifdef MODEST_TOOLKIT_HILDON2
+ pango_attr_list_unref (attr_list);
+#endif
+
+ GTK_WIDGET_UNSET_FLAGS (GTK_WIDGET (instance), GTK_CAN_FOCUS);
return;
}
static void
modest_attachment_view_finalize (GObject *object)
{
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (object);
-
- if (priv->get_size_idle_id) {
- g_source_remove (priv->get_size_idle_id);
- priv->get_size_idle_id = 0;
- }
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (object);
if (priv->get_size_stream != NULL) {
g_object_unref (priv->get_size_stream);
static void
size_allocate (GtkWidget *widget, GtkAllocation *allocation)
{
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (widget);
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (widget);
gint width, width_diff;
GTK_WIDGET_CLASS (parent_class)->size_allocate (widget, allocation);
klass->get_part_func = modest_attachment_view_get_part_default;
klass->set_part_func = modest_attachment_view_set_part_default;
klass->clear_func = modest_attachment_view_clear_default;
- klass->activate = NULL;
widget_class->size_allocate = size_allocate;
- g_type_class_add_private (object_class, sizeof (ModestAttachmentViewPriv));
+ g_type_class_add_private (object_class, sizeof (ModestAttachmentViewPrivate));
- signals[ACTIVATE_SIGNAL] =
- g_signal_new ("activate",
- G_TYPE_FROM_CLASS (object_class),
- G_SIGNAL_RUN_FIRST | G_SIGNAL_ACTION,
- G_STRUCT_OFFSET(ModestAttachmentViewClass, activate),
- NULL, NULL,
- g_cclosure_marshal_VOID__VOID,
- G_TYPE_NONE, 0);
-
return;
}
{
TnyMimePartViewIface *klass = (TnyMimePartViewIface *)g;
- klass->get_part_func = modest_attachment_view_get_part;
- klass->set_part_func = modest_attachment_view_set_part;
- klass->clear_func = modest_attachment_view_clear;
+ klass->get_part = modest_attachment_view_get_part;
+ klass->set_part = modest_attachment_view_set_part;
+ klass->clear = modest_attachment_view_clear;
return;
}
NULL /* interface_data */
};
- type = g_type_register_static (GTK_TYPE_HBOX,
+ type = g_type_register_static (GTK_TYPE_EVENT_BOX,
"ModestAttachmentView",
&info, 0);