X-Git-Url: http://git.maemo.org/git/?a=blobdiff_plain;f=src%2Fmaemo%2Fmodest-maemo-utils.c;h=28f73e17c951d6e4447ae6f14ae861fe9ce30a01;hb=a3fa613b8f9ff7a21d9dda408086f2145bf54c94;hp=1fca24ece43a66d26d3b0109d09956809a385b4f;hpb=5005b6ea5c9c552cc50414c548515737acf314b8;p=modest diff --git a/src/maemo/modest-maemo-utils.c b/src/maemo/modest-maemo-utils.c index 1fca24e..28f73e1 100644 --- a/src/maemo/modest-maemo-utils.c +++ b/src/maemo/modest-maemo-utils.c @@ -34,9 +34,23 @@ #include #include #include +#include +#include +#include /* for strlen */ #include +#include +#include +#include +#include +#include +#include +#include +#include "modest-hildon-includes.h" +#include #include "modest-maemo-utils.h" +#include "modest-text-utils.h" +#include "modest-platform.h" /* * For getting and tracking the Bluetooth name @@ -54,6 +68,24 @@ "',member='" BTNAME_SIG_CHANGED "'" +static osso_context_t *__osso_context = NULL; /* urgh global */ + +osso_context_t * +modest_maemo_utils_get_osso_context (void) +{ + if (!__osso_context) + g_warning ("%s: __osso_context == NULL", __FUNCTION__); + + return __osso_context; +} + +void +modest_maemo_utils_set_osso_context (osso_context_t *osso_context) +{ + g_return_if_fail (osso_context); + __osso_context = osso_context; +} + static void update_device_name_from_msg (DBusMessage *message) { @@ -63,22 +95,15 @@ update_device_name_from_msg (DBusMessage *message) dbus_error_init (&error); if (dbus_set_error_from_message (&error, message)) { - g_printerr ("modest: failed to get bt name: %s\n", error.message); + g_printerr ("modest: failed to get bluetooth name: %s\n", error.message); dbus_error_free (&error); - modest_conf_set_string (modest_runtime_get_conf(), - MODEST_CONF_DEVICE_NAME, - MODEST_LOCAL_FOLDERS_DEFAULT_DISPLAY_NAME, - NULL); - } else { const gchar *device_name; if (!dbus_message_iter_init (message, &iter)) { g_printerr ("modest: message did not have argument\n"); return; } - dbus_message_iter_get_basic (&iter, &device_name); - g_warning ("update device name: %s", device_name); modest_conf_set_string (modest_runtime_get_conf(), MODEST_CONF_DEVICE_NAME, device_name, NULL); @@ -166,5 +191,72 @@ modest_maemo_utils_get_device_name (void) get_device_name_from_dbus (); } +void +modest_maemo_utils_setup_images_filechooser (GtkFileChooser *chooser) +{ + gchar *images_folder; + GtkFileFilter *file_filter; + GList *image_mimetypes_list; + GList *node; + g_return_if_fail (GTK_IS_FILE_CHOOSER (chooser)); + /* Set the default folder to images folder */ + images_folder = g_build_filename (g_get_home_dir (), + MODEST_MAEMO_UTILS_MYDOCS_FOLDER, + MODEST_MAEMO_UTILS_DEFAULT_IMAGE_FOLDER, NULL); + gtk_file_chooser_set_current_folder (chooser, images_folder); + g_free (images_folder); + + /* Set the images mime filter */ + file_filter = gtk_file_filter_new (); +#ifdef MODEST_HAVE_HILDON0_WIDGETS + image_mimetypes_list = osso_mime_get_mime_types_for_category (OSSO_MIME_CATEGORY_IMAGES); +#else + image_mimetypes_list = hildon_mime_get_mime_types_for_category (HILDON_MIME_CATEGORY_IMAGES); +#endif + for (node = image_mimetypes_list; node != NULL; node = g_list_next (node)) { + gtk_file_filter_add_mime_type (file_filter, node->data); + } + gtk_file_chooser_set_filter (chooser, file_filter); +#ifdef MODEST_HAVE_HILDON0_WIDGETS + osso_mime_types_list_free (image_mimetypes_list); +#else + hildon_mime_types_list_free (image_mimetypes_list); +#endif + +} + +void +modest_maemo_set_thumbable_scrollbar (GtkScrolledWindow *win, + gboolean thumbable) +{ + g_return_if_fail (GTK_IS_SCROLLED_WINDOW(win)); +#ifdef MODEST_HAVE_HILDON1_WIDGETS + hildon_helper_set_thumb_scrollbar (win, thumbable); +#endif /* MODEST_HAVE_HILDON1_WIDGETS */ +} + +GtkWidget * +modest_maemo_utils_get_manager_menubar_as_menu (GtkUIManager *manager, + const gchar *item_name) +{ + GtkWidget *new_menu; + GtkWidget *menubar; + GList *children, *iter; + + menubar = gtk_ui_manager_get_widget (manager, item_name); + new_menu = gtk_menu_new (); + + children = gtk_container_get_children (GTK_CONTAINER (menubar)); + for (iter = children; iter != NULL; iter = g_list_next (iter)) { + GtkWidget *menu; + + menu = GTK_WIDGET (iter->data); + gtk_widget_reparent (menu, new_menu); + } + + g_list_free (children); + + return new_menu; +}