#include <dbus_api/modest-dbus-callbacks.h>
#include <maemo/modest-osso-autosave-callbacks.h>
#include <libosso.h>
-#include <mce/dbus-names.h>
#include <tny-maemo-conic-device.h>
#include <tny-simple-list.h>
#include <tny-folder.h>
#include <maemo/easysetup/modest-easysetup-wizard.h>
#include <hildon/hildon-sound.h>
+#ifdef MODEST_HAVE_MCE
+#include <mce/dbus-names.h>
+#endif /*MODEST_HAVE_MCE*/
+
#ifdef MODEST_HAVE_ABOOK
#include <libosso-abook/osso-abook.h>
#endif /*MODEST_HAVE_ABOOK*/
action_name += strlen ("mailto:");
gtk_clipboard_set_text (clipboard, action_name, strlen (action_name));
+ modest_platform_information_banner (NULL, NULL, _CS("ecoc_ib_edwin_copied"));
return; /* we're done */
}
return TRUE;
}
-void
-modest_platform_on_new_headers_received (TnyList *header_list,
- gboolean show_visual)
+void
+modest_platform_push_email_notification(void)
{
gboolean play_sound;
+ ModestWindow *main_window;
+ gboolean screen_on = TRUE, app_in_foreground;
/* Check whether or not we should play a sound */
play_sound = modest_conf_get_bool (modest_runtime_get_conf (),
MODEST_CONF_PLAY_SOUND_MSG_ARRIVE,
NULL);
- if (!show_visual) {
- gboolean screen_on, app_in_foreground;
- ModestWindow *main_window;
-
- /* Get the screen status */
- main_window = modest_window_mgr_get_main_window (modest_runtime_get_window_mgr (), FALSE);
+ /* Get the screen status */
+ main_window = modest_window_mgr_get_main_window (modest_runtime_get_window_mgr (), FALSE);
+ if (main_window)
screen_on = modest_main_window_screen_is_on (MODEST_MAIN_WINDOW (main_window));
- /* Get the window status */
- app_in_foreground = hildon_program_get_is_topmost (hildon_program_get_instance ());
+ /* Get the window status */
+ app_in_foreground = hildon_program_get_is_topmost (hildon_program_get_instance ());
- /* If the screen is on and the app is in the
- foreground we don't show anything */
- if (!(screen_on && app_in_foreground)) {
- /* Play a sound */
- if (play_sound)
- hildon_play_system_sound (MODEST_NEW_MAIL_SOUND_FILE);
-
- /* Activate LED. This must be deactivated by
- modest_platform_remove_new_mail_notifications */
- osso_rpc_run_system (modest_maemo_utils_get_osso_context (),
- MCE_SERVICE,
- MCE_REQUEST_PATH,
- MCE_REQUEST_IF,
- MCE_ACTIVATE_LED_PATTERN,
- NULL,
- DBUS_TYPE_STRING, MODEST_NEW_MAIL_LIGHTING_PATTERN,
- DBUS_TYPE_INVALID);
- }
+ /* If the screen is on and the app is in the
+ foreground we don't show anything */
+ if (!(screen_on && app_in_foreground)) {
+ /* Play a sound */
+ if (play_sound)
+ hildon_play_system_sound (MODEST_NEW_MAIL_SOUND_FILE);
+
+ /* Activate LED. This must be deactivated by
+ modest_platform_remove_new_mail_notifications */
+#ifdef MODEST_HAVE_MCE
+ osso_rpc_run_system (modest_maemo_utils_get_osso_context (),
+ MCE_SERVICE,
+ MCE_REQUEST_PATH,
+ MCE_REQUEST_IF,
+ MCE_ACTIVATE_LED_PATTERN,
+ NULL,
+ DBUS_TYPE_STRING, MODEST_NEW_MAIL_LIGHTING_PATTERN,
+ DBUS_TYPE_INVALID);
+#endif
+ }
+}
+
+void
+modest_platform_on_new_headers_received (TnyList *header_list,
+ gboolean show_visual)
+{
+ g_return_if_fail (TNY_IS_LIST(header_list));
+
+ if (tny_list_get_length(header_list) == 0) {
+ g_warning ("%s: header list is empty", __FUNCTION__);
+ return;
+ }
+
+ if (!show_visual) {
+ modest_platform_push_email_notification ();
/* We do a return here to avoid indentation with an else */
return;
}
#ifdef MODEST_HAVE_HILDON_NOTIFY
+ gboolean play_sound;
+
+ /* Check whether or not we should play a sound */
+ play_sound = modest_conf_get_bool (modest_runtime_get_conf (),
+ MODEST_CONF_PLAY_SOUND_MSG_ARRIVE,
+ NULL);
+
HildonNotification *notification;
TnyIterator *iter;
GSList *notifications_list = NULL;
modest_platform_remove_new_mail_notifications (gboolean only_visuals)
{
if (only_visuals) {
+#ifdef MODEST_HAVE_MCE
osso_rpc_run_system (modest_maemo_utils_get_osso_context (),
MCE_SERVICE,
MCE_REQUEST_PATH,
NULL,
DBUS_TYPE_STRING, MODEST_NEW_MAIL_LIGHTING_PATTERN,
DBUS_TYPE_INVALID);
+#endif
return;
}
modest_folder_view_set_style (MODEST_FOLDER_VIEW (widget),
MODEST_FOLDER_VIEW_STYLE_SHOW_ONE);
-
/* Restore settings */
modest_widget_memory_restore (modest_runtime_get_conf(),
G_OBJECT (widget),
return widget;
}
+void
+banner_finish (gpointer data, GObject *object)
+{
+ ModestWindowMgr *mgr = (ModestWindowMgr *) data;
+ modest_window_mgr_unregister_banner (mgr);
+ g_object_unref (mgr);
+}
+
void
modest_platform_information_banner (GtkWidget *parent,
const gchar *icon_name,
const gchar *text)
{
- hildon_banner_show_information (parent, icon_name, text);
+ GtkWidget *banner;
+ ModestWindowMgr *mgr;
+
+ mgr = modest_runtime_get_window_mgr ();
+ banner = hildon_banner_show_information (parent, icon_name, text);
+
+ modest_window_mgr_register_banner (mgr);
+ g_object_ref (mgr);
+ g_object_weak_ref ((GObject *) banner, banner_finish, mgr);
}
void
void
modest_platform_connect_and_perform (GtkWindow *parent_window,
+ gboolean force,
TnyAccount *account,
ModestConnectedPerformer callback,
gpointer user_data)
TnyDevice *device;
TnyConnectionStatus conn_status;
OnWentOnlineInfo *info;
- gboolean user_requested;
device = modest_runtime_get_device();
device_online = tny_device_is_online (device);
- /* Whether the connection is user requested or automatically
- requested, for example via D-Bus */
- user_requested = (parent_window) ? TRUE : FALSE;
-
/* If there is no account check only the device status */
if (!account) {
info->callback = callback;
tny_maemo_conic_device_connect_async (TNY_MAEMO_CONIC_DEVICE (device), NULL,
- user_requested, on_conic_device_went_online,
+ force, on_conic_device_went_online,
info);
/* We'll cleanup in on_conic_device_went_online */
* and the account */
tny_maemo_conic_device_connect_async (TNY_MAEMO_CONIC_DEVICE (device), NULL,
- user_requested, on_conic_device_went_online,
+ force, on_conic_device_went_online,
info);
} else {
void
modest_platform_connect_if_remote_and_perform (GtkWindow *parent_window,
+ gboolean force,
TnyFolderStore *folder_store,
ModestConnectedPerformer callback,
gpointer user_data)
}
}
- modest_platform_connect_and_perform (parent_window, account, callback, user_data);
+ modest_platform_connect_and_perform (parent_window, force, account, callback, user_data);
return;
}
+static void
+src_account_connect_performer (gboolean canceled,
+ GError *err,
+ GtkWindow *parent_window,
+ TnyAccount *src_account,
+ gpointer user_data)
+{
+ DoubleConnectionInfo *info = (DoubleConnectionInfo *) user_data;
+
+ if (canceled || err) {
+ /* If there was any error call the user callback */
+ info->callback (canceled, err, parent_window, src_account, info->data);
+ } else {
+ /* Connect the destination account */
+ modest_platform_connect_if_remote_and_perform (parent_window, TRUE,
+ TNY_FOLDER_STORE (info->dst_account),
+ info->callback, info->data);
+ }
+
+ /* Free the info object */
+ g_object_unref (info->dst_account);
+ g_slice_free (DoubleConnectionInfo, info);
+}
+
+
+void
+modest_platform_double_connect_and_perform (GtkWindow *parent_window,
+ gboolean force,
+ TnyFolderStore *folder_store,
+ DoubleConnectionInfo *connect_info)
+{
+ modest_platform_connect_if_remote_and_perform(parent_window,
+ force,
+ folder_store,
+ src_account_connect_performer,
+ connect_info);
+}
+
GtkWidget *
modest_platform_get_account_settings_dialog (ModestAccountSettings *settings)
{