2007-05-03 Murray Cumming <murrayc@murrayc.com>
[modest] / src / maemo / modest-platform.c
index 6798bcb..8a0f938 100644 (file)
 #include <glib/gi18n.h>
 #include <modest-platform.h>
 #include <modest-runtime.h>
-#include <dbus_api/modest-dbus-callbacks.h>
-#include <libosso.h>
+#include <modest-main-window.h>
+#include <modest-header-view.h>
 
-#ifdef MODEST_HILDON_VERSION_0
-#include <osso-mime.h>
-#include <osso-uri.h>
-#else
-#include <hildon-mime.h>
-#include <hildon-uri.h>
-#endif /*MODEST_HILDON_VERSION_0*/
+#include <modest-hildon-includes.h>
 
+#include <dbus_api/modest-dbus-callbacks.h>
+#include <libosso.h>
+#include <alarmd/alarm_event.h> /* For alarm_event_add(), etc. */
 #include <tny-maemo-conic-device.h>
 #include <tny-folder.h>
 #include <gtk/gtkicontheme.h>
-#include <hildon-widgets/hildon-banner.h>
-#include <hildon-widgets/hildon-note.h>
 #include <gtk/gtkmenuitem.h>
 #include <gtk/gtkmain.h>
 #include <string.h>
-
+       
 gboolean
 modest_platform_init (void)
 {      
@@ -84,6 +79,15 @@ modest_platform_init (void)
        }
        */
 
+       /* Register hardware event dbus callback: */
+    osso_hw_set_event_cb(osso_context, NULL, modest_osso_cb_hw_state_handler, NULL);
+
+       /* TODO: Get the actual update interval from gconf, 
+        * when that preferences dialog has been implemented.
+        * And make sure that this is called again whenever that is changed. */
+       const guint update_interval_minutes = 15;
+       modest_platform_set_update_interval (update_interval_minutes);
+       
        return TRUE;
 }
 
@@ -397,6 +401,106 @@ entry_changed (GtkEditable *editable,
        g_free (chars);
 }
 
+static void
+launch_sort_headers_dialog (GtkWindow *parent_window,
+                           HildonSortDialog *dialog)
+{
+       ModestHeaderView *header_view = NULL;
+       GList *cols = NULL;
+       GList *tmp = NULL;
+       GtkSortType sort_type;
+       gint sort_key;
+       gint result;
+       
+       /* Get header window */
+       if (MODEST_IS_MAIN_WINDOW (parent_window)) {
+               header_view = MODEST_HEADER_VIEW(modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(parent_window),
+                                                                                     MODEST_WIDGET_TYPE_HEADER_VIEW));
+       }
+       if (!header_view) return;
+
+       /* Add sorting keys */
+       cols = modest_header_view_get_columns (header_view);    
+       if (cols == NULL) return;
+       int num_cols = g_list_length(cols);
+       int sort_ids[num_cols];
+       int sort_model_ids[num_cols];
+       GtkTreeViewColumn *sort_cols[num_cols];
+       for (tmp=cols; tmp; tmp=tmp->next) {
+               gint col_id = GPOINTER_TO_INT (g_object_get_data(G_OBJECT(tmp->data), MODEST_HEADER_VIEW_COLUMN));
+               switch (col_id) {
+               case MODEST_HEADER_VIEW_COLUMN_COMPACT_FLAG:
+                       sort_key = hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_attachment"));
+                       sort_ids[sort_key] = col_id;
+                       sort_model_ids[sort_key] = TNY_HEADER_FLAG_ATTACHMENTS;
+                       sort_cols[sort_key] = tmp->data;
+
+                       sort_key = hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_priority"));
+                       sort_ids[sort_key] = col_id;
+                       sort_model_ids[sort_key] = TNY_HEADER_FLAG_PRIORITY;
+                       sort_cols[sort_key] = tmp->data;
+                       break;
+               case MODEST_HEADER_VIEW_COLUMN_COMPACT_HEADER_OUT:
+                       sort_key = hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_sender_recipient"));
+                       sort_ids[sort_key] = col_id;
+                       sort_model_ids[sort_key] = TNY_GTK_HEADER_LIST_MODEL_TO_COLUMN;
+                       sort_cols[sort_key] = tmp->data;
+
+                       sort_key = hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_subject"));
+                       sort_ids[sort_key] = col_id;
+                       sort_model_ids[sort_key] = TNY_GTK_HEADER_LIST_MODEL_SUBJECT_COLUMN;
+                       sort_cols[sort_key] = tmp->data;
+                       break;
+               case MODEST_HEADER_VIEW_COLUMN_COMPACT_HEADER_IN:
+                       sort_key = hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_sender_recipient"));
+                       sort_ids[sort_key] = col_id;
+                       sort_model_ids[sort_key] = TNY_GTK_HEADER_LIST_MODEL_FROM_COLUMN;
+                       sort_cols[sort_key] = tmp->data;
+
+                       sort_key = hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_subject"));
+                       sort_ids[sort_key] = col_id;
+                       sort_model_ids[sort_key] = TNY_GTK_HEADER_LIST_MODEL_SUBJECT_COLUMN;
+                       sort_cols[sort_key] = tmp->data;
+                       break;
+               case MODEST_HEADER_VIEW_COLUMN_COMPACT_RECEIVED_DATE:
+                       sort_key = hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_date"));
+                       sort_ids[sort_key] = col_id;
+                       sort_model_ids[sort_key] = TNY_GTK_HEADER_LIST_MODEL_DATE_RECEIVED_TIME_T_COLUMN,
+                       sort_cols[sort_key] = tmp->data;
+                       break;
+               case MODEST_HEADER_VIEW_COLUMN_COMPACT_SENT_DATE:
+                       sort_key = hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_date"));
+                       sort_ids[sort_key] = col_id;
+                       sort_model_ids[sort_key] = TNY_GTK_HEADER_LIST_MODEL_DATE_SENT_TIME_T_COLUMN,
+                       sort_cols[sort_key] = tmp->data;
+                       break;
+               default:
+                       return;
+               }
+       }
+       
+       /* Launch dialogs */
+       result = gtk_dialog_run (GTK_DIALOG (dialog));
+       if (result == GTK_RESPONSE_OK) {
+               sort_key = hildon_sort_dialog_get_sort_key (dialog);
+               sort_type = hildon_sort_dialog_get_sort_order (dialog);
+               if (sort_ids[sort_key] == MODEST_HEADER_VIEW_COLUMN_COMPACT_FLAG)
+                       g_object_set_data(G_OBJECT(sort_cols[sort_key]), 
+                                         MODEST_HEADER_VIEW_FLAG_SORT, 
+                                         GINT_TO_POINTER(sort_model_ids[sort_key]));
+               
+               else
+                       gtk_tree_view_column_set_sort_column_id (sort_cols[sort_key], sort_model_ids[sort_key]);
+               
+               modest_header_view_sort_by_column_id (header_view, sort_ids[sort_key], sort_type);
+       }
+       
+       /* free */
+       g_list_free(cols);      
+}
+
+
+
 gint
 modest_platform_run_new_folder_dialog (GtkWindow *parent_window,
                                       TnyFolderStore *parent_folder,
@@ -512,3 +616,105 @@ gboolean modest_platform_connect_and_wait (GtkWindow *parent_window)
        return TRUE;
 }
 
+void
+modest_platform_run_sort_dialog (GtkWindow *parent_window,
+                                ModestSortDialogType type)
+{
+       GtkWidget *dialog = NULL;
+
+       /* Build dialog */
+       dialog = hildon_sort_dialog_new (parent_window);
+       gtk_window_set_modal (GTK_WINDOW(dialog), TRUE);
+       
+       /* Fill sort keys */
+       switch (type) {
+       case MODEST_SORT_HEADERS:
+               launch_sort_headers_dialog (parent_window, 
+                                           HILDON_SORT_DIALOG(dialog));
+               break;
+       }
+       
+       /* Free */
+       gtk_widget_destroy (GTK_WIDGET (dialog));
+}
+
+
+gboolean modest_platform_set_update_interval (guint minutes)
+{
+       ModestConf *conf = modest_runtime_get_conf ();
+       if (!conf)
+               return FALSE;
+               
+       cookie_t alarm_cookie = modest_conf_get_int (conf, MODEST_CONF_ALARM_ID, NULL);
+
+       /* Delete any existing alarm,
+        * because we will replace it: */
+       if (alarm_cookie) {
+               /* TODO: What does the alarm_event_del() return value mean? */
+               alarm_event_del(alarm_cookie);
+               alarm_cookie = 0;
+               modest_conf_set_int (conf, MODEST_CONF_ALARM_ID, 0, NULL);
+       }
+       
+       /* 0 means no updates: */
+       if (minutes == 0)
+               return TRUE;
+               
+     
+       /* Register alarm: */
+       
+       /* Get current time: */
+       time_t time_now;
+       time (&time_now);
+       struct tm *st_time = localtime (&time_now);
+       
+       /* Add minutes to tm_min field: */
+       st_time->tm_min += minutes;
+       
+       /* Set the time in alarm_event_t structure: */
+       alarm_event_t event;
+       memset (&event, 0, sizeof (alarm_event_t));
+       event.alarm_time = mktime (st_time);
+
+       /* Specify what should happen when the alarm happens:
+        * It should call this D-Bus method: */
+        
+       /* Note: I am surpised that alarmd can't just use the modest.service file
+        * for this. murrayc. */
+       event.dbus_path = g_strdup(PREFIX "/bin/modest");
+       
+       event.dbus_interface = g_strdup (MODEST_DBUS_IFACE);
+       event.dbus_service = g_strdup (MODEST_DBUS_SERVICE);
+       event.dbus_name = g_strdup (MODEST_DBUS_METHOD_SEND_RECEIVE);
+       
+       alarm_cookie = alarm_event_add (&event);
+       
+       /* Store the alarm ID in GConf, so we can remove it later:
+        * This is apparently valid between application instances. */
+       modest_conf_set_int (conf, MODEST_CONF_ALARM_ID, alarm_cookie, NULL);
+       
+       if (!alarm_cookie) {
+           /* Error */
+           const alarm_error_t alarm_error = alarmd_get_error ();
+           printf ("Error setting alarm event. Error code: '%d'\n", alarm_error);
+           
+           /* Give people some clue: */
+           /* The alarm API should have a function for this: */
+           if (alarm_error == ALARMD_ERROR_DBUS) {
+               printf ("  ALARMD_ERROR_DBUS: An error with D-Bus occurred, probably coudn't get a D-Bus connection.\n");
+           } else if (alarm_error == ALARMD_ERROR_CONNECTION) {
+               printf ("  ALARMD_ERROR_CONNECTION: Could not contact alarmd via D-Bus.\n");
+           } else if (alarm_error == ALARMD_ERROR_INTERNAL) {
+               printf ("  ALARMD_ERROR_INTERNAL: Some alarmd or libalarm internal error, possibly a version mismatch.\n");
+           } else if (alarm_error == ALARMD_ERROR_MEMORY) {
+               printf ("  ALARMD_ERROR_MEMORY: A memory allocation failed.\n");
+           } else if (alarm_error == ALARMD_ERROR_ARGUMENT) {
+               printf ("  ALARMD_ERROR_ARGUMENT: An argument given by caller was invalid.\n");
+           }
+           
+           return FALSE;
+       }
+       
+       return TRUE;
+}
+