#include "modest-details-dialog.h"
#include <glib/gi18n.h>
+#include <gdk/gdkkeysyms.h>
#include <gtk/gtkscrolledwindow.h>
#include <gtk/gtktable.h>
#include <gtk/gtkstock.h>
#include <tny-msg.h>
#include <tny-header.h>
#include <tny-header-view.h>
-#include <tny-folder-stats.h>
+#include <tny-folder-store.h>
#include <modest-tny-folder.h>
+#include <modest-tny-account.h>
#include <modest-text-utils.h>
-
+#include <modest-datetime-formatter.h>
+#include <string.h> /* for strlen */
static void modest_details_dialog_set_header_default (ModestDetailsDialog *self,
TnyHeader *header);
static void
modest_details_dialog_init (ModestDetailsDialog *self)
{
- MODEST_DETAILS_DIALOG_GET_CLASS (self)->create_container_func (self);
}
GtkWidget*
"transient-for", parent,
NULL));
+ MODEST_DETAILS_DIALOG_GET_CLASS (dialog)->create_container_func (dialog);
MODEST_DETAILS_DIALOG_GET_CLASS (dialog)->set_header_func (dialog, header);
+ /* Add close button */
+ gtk_dialog_add_button (GTK_DIALOG (dialog), _("mcen_bd_close"), GTK_RESPONSE_CLOSE);
+
return GTK_WIDGET (dialog);
}
"transient-for", parent,
NULL));
+ MODEST_DETAILS_DIALOG_GET_CLASS (dialog)->create_container_func (dialog);
MODEST_DETAILS_DIALOG_GET_CLASS (dialog)->set_folder_func (dialog, folder);
+ /* Add close button */
+ gtk_dialog_add_button (GTK_DIALOG (dialog), _("mcen_bd_close"), GTK_RESPONSE_CLOSE);
+
return GTK_WIDGET (dialog);
}
/* Create value */
value_w = gtk_label_new (value);
gtk_label_set_line_wrap (GTK_LABEL (value_w), TRUE);
+ gtk_label_set_line_wrap_mode (GTK_LABEL (value_w), PANGO_WRAP_WORD_CHAR);
gtk_misc_set_alignment (GTK_MISC (value_w), 0.0, 0.0);
gtk_label_set_justify (GTK_LABEL (value_w), GTK_JUSTIFY_LEFT);
modest_details_dialog_set_header_default (ModestDetailsDialog *self,
TnyHeader *header)
{
- gchar *from, *subject, *to, *cc;
+ gchar *from = NULL, *subject = NULL, *to = NULL, *cc = NULL, *bcc = NULL;
time_t received, sent;
guint size;
gchar *size_s;
TnyFolder *folder;
TnyFolderType folder_type;
+ ModestDatetimeFormatter *datetime_formatter;
+ const gchar *date_time_str;
+
+ datetime_formatter = modest_datetime_formatter_new ();
- /* Set window title & Add close button */
+ /* Set window title */
gtk_window_set_title (GTK_WINDOW (self), _("mcen_ti_message_properties"));
- gtk_dialog_add_button (GTK_DIALOG (self), _("mcen_bd_close"), GTK_RESPONSE_CLOSE);
folder = tny_header_get_folder (header);
- folder_type = modest_tny_folder_guess_folder_type (folder);
- g_object_unref (folder);
+ if (folder) {
+ folder_type = modest_tny_folder_guess_folder_type (folder);
+ g_object_unref (folder);
+ } else {
+ folder_type = TNY_FOLDER_TYPE_NORMAL;
+ }
+
+ 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));
- subject = g_strdup (tny_header_get_subject (header));
- cc = g_strdup (tny_header_get_cc (header));
+ from = tny_header_dup_from (header);
+ to = tny_header_dup_to (header);
+ subject = tny_header_dup_subject (header);
+ cc = tny_header_dup_cc (header);
+ bcc = tny_header_dup_bcc (header);
received = tny_header_get_date_received (header);
sent = tny_header_get_date_sent (header);
size = tny_header_get_message_size (header);
- if (from == NULL)
- from = g_strdup ("");
- if (to == NULL)
- to = g_strdup ("");
- if (subject == NULL)
- subject = g_strdup ("");
- if (cc == NULL)
- cc = g_strdup ("");
+ if (!strcmp (subject, "")) {
+ g_free (subject);
+ subject = g_strdup (_("mail_va_no_subject "));
+ }
- /* 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) */
- if ((folder_type != TNY_FOLDER_TYPE_SENT) &&
+
+ /* 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)) {
- gchar *received_s;
+ date_time_str = modest_datetime_formatter_display_long_datetime (datetime_formatter,
+ received);
- received_s = modest_text_utils_get_display_date (received);
- if (received_s == NULL)
- received_s = g_strdup (received_s);
- modest_details_dialog_add_data (self, _("mcen_fi_message_properties_received"), received_s);
- g_free (received_s);
+ modest_details_dialog_add_data (self, _("mcen_fi_message_properties_received"),
+ date_time_str);
}
- /* Set date sent (optional) */
- if ((folder_type != TNY_FOLDER_TYPE_DRAFTS)&&
- (folder_type != TNY_FOLDER_TYPE_OUTBOX)) {
- gchar *sent_s;
+ /* for drafts (created) */
+ if (folder_type == TNY_FOLDER_TYPE_DRAFTS) {
+ date_time_str = modest_datetime_formatter_display_long_datetime (datetime_formatter,
+ received);
+ modest_details_dialog_add_data (self, _("mcen_fi_message_properties_created"),
+ date_time_str);
+ }
- sent_s = modest_text_utils_get_display_date (sent);
- if (sent_s == NULL)
- sent_s = g_strdup (sent_s);
- modest_details_dialog_add_data (self, _("mcen_fi_message_properties_sent"), sent_s);
- g_free (sent_s);
+ /* for everyting except outbox, drafts: Sent */
+ if (sent && (folder_type != TNY_FOLDER_TYPE_DRAFTS)&&
+ (folder_type != TNY_FOLDER_TYPE_OUTBOX)) {
+
+ date_time_str = modest_datetime_formatter_display_long_datetime (datetime_formatter,
+ sent);
+ modest_details_dialog_add_data (self, _("mcen_fi_message_properties_sent"),
+ date_time_str);
}
/* 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);
+
+ /* only show cc when it's there */
+ if (bcc && strlen(bcc) > 0)
+ modest_details_dialog_add_data (self, _("mcen_fi_message_properties_bcc"), bcc);
/* Set size */
- if (size <= 0)
- size_s = g_strdup (_("mcen_va_message_properties_size_noinfo"));
- else
- size_s = modest_text_utils_get_display_size (size);
+ size_s = modest_text_utils_get_display_size (size);
modest_details_dialog_add_data (self, _("mcen_fi_message_properties_size"), size_s);
g_free (size_s);
/* Frees */
+ g_object_unref (datetime_formatter);
g_free (to);
g_free (from);
g_free (subject);
g_free (cc);
+ g_free (bcc);
}
static void
modest_details_dialog_set_folder_default (ModestDetailsDialog *self,
TnyFolder *folder)
{
- TnyFolderStats *stats;
- gchar *count, *size_s;
- gint size;
-
+ gchar *count_s, *size_s, *name = NULL;
+ gchar *tmp = NULL;
+ guint size, count;
+
+ g_return_if_fail (folder && TNY_IS_FOLDER (folder));
+ g_return_if_fail (modest_tny_folder_guess_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_folder_properties_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);
- if (size <= 0)
- size_s = g_strdup (_("mcen_va_message_properties_size_noinfo"));
- else
- size_s = modest_text_utils_get_display_size (size);
-
- modest_details_dialog_add_data (self, _("mcen_fi_folder_properties_foldername"),
- tny_folder_get_name (folder));
- modest_details_dialog_add_data (self, _("mcen_fi_folder_properties_messages"), count);
- modest_details_dialog_add_data (self, _("mcen_fi_folder_properties_size"), size_s);
+
+ /* Get data. We use our function because it's recursive */
+ count = tny_folder_get_all_count (TNY_FOLDER (folder));
+ size = tny_folder_get_local_size (TNY_FOLDER (folder));
+
+ /* Format count and size */
+ count_s = g_strdup_printf ("%d", count);
+ size_s = modest_text_utils_get_display_size (size);
+
+ /* Different names for the local folders */
+ if (modest_tny_folder_is_local_folder (folder) ||
+ modest_tny_folder_is_memory_card_folder (folder)) {
+ gint type = modest_tny_folder_get_local_or_mmc_folder_type (folder);
+ if (type != TNY_FOLDER_TYPE_UNKNOWN)
+ name = g_strdup(modest_local_folder_info_get_type_display_name (type));
+ }
+
+ if (!name) {
+ if (tny_folder_get_folder_type (folder) == TNY_FOLDER_TYPE_INBOX)
+ name = g_strdup (_("mcen_me_folder_inbox"));
+ else
+ name = g_strdup (tny_folder_get_name (folder));
+ }
+
+ tmp = g_strconcat (_("mcen_fi_folder_properties_foldername"), ":", NULL);
+ modest_details_dialog_add_data (self, tmp, name);
+ g_free (tmp);
+
+ tmp = g_strconcat (_("mcen_fi_folder_properties_messages"), ":", NULL);
+ modest_details_dialog_add_data (self, tmp, count_s);
+ g_free (tmp);
+
+ tmp = g_strconcat (_("mcen_fi_folder_properties_size"), ":", NULL);
+ modest_details_dialog_add_data (self, tmp, size_s);
+ g_free (tmp);
/* Frees */
+ g_free (name);
g_free (size_s);
- g_free (count);
- g_object_unref (stats);
+ g_free (count_s);
+}
+
+static gboolean
+on_key_press_event (GtkWindow *window, GdkEventKey *event, gpointer userdata)
+{
+ GtkWidget *focused;
+
+ focused = gtk_window_get_focus (window);
+ if (GTK_IS_SCROLLED_WINDOW (focused)) {
+ GtkAdjustment *vadj;
+ gboolean return_value;
+
+ vadj = gtk_scrolled_window_get_vadjustment (GTK_SCROLLED_WINDOW (focused));
+ switch (event->keyval) {
+ case GDK_Up:
+ case GDK_KP_Up:
+ if (vadj->value > 0.0) {
+ g_signal_emit_by_name (G_OBJECT (focused), "scroll-child", GTK_SCROLL_STEP_UP, FALSE,
+ &return_value);
+ return TRUE;
+ }
+ break;
+ case GDK_Down:
+ case GDK_KP_Down:
+ if (vadj->value < vadj->upper - vadj->page_size) {
+ g_signal_emit_by_name (G_OBJECT (focused), "scroll-child", GTK_SCROLL_STEP_DOWN, FALSE,
+ &return_value);
+ return TRUE;
+ }
+ break;
+ }
+ }
+
+ return FALSE;
}
static void
gtk_table_set_row_spacings (GTK_TABLE (priv->props_table), 1);
gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (scrollbar), priv->props_table);
gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrollbar), GTK_POLICY_NEVER, GTK_POLICY_AUTOMATIC);
+ gtk_container_set_focus_vadjustment (GTK_CONTAINER (priv->props_table),
+ gtk_scrolled_window_get_vadjustment (GTK_SCROLLED_WINDOW (scrollbar)));
gtk_container_add (GTK_CONTAINER (GTK_DIALOG (self)->vbox), scrollbar);
gtk_dialog_set_has_separator (GTK_DIALOG (self), FALSE);
+
+ g_signal_connect (self, "key-press-event", G_CALLBACK (on_key_press_event), self);
}