X-Git-Url: http://git.maemo.org/git/?a=blobdiff_plain;f=src%2Fmaemo%2Fmodest-maemo-utils.c;h=28f73e17c951d6e4447ae6f14ae861fe9ce30a01;hb=a3fa613b8f9ff7a21d9dda408086f2145bf54c94;hp=98e1d68890778706cfb130b71fd1202b9e674ce5;hpb=3e7a3b4e5759d63285d8795435b2ceedaf63b216;p=modest diff --git a/src/maemo/modest-maemo-utils.c b/src/maemo/modest-maemo-utils.c index 98e1d68..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,37 +68,23 @@ "',member='" BTNAME_SIG_CHANGED "'" -GtkWidget* -modest_maemo_utils_menubar_to_menu (GtkUIManager *ui_manager) -{ - GtkWidget *main_menu; - GtkWidget *menubar; - GList *iter; +static osso_context_t *__osso_context = NULL; /* urgh global */ - g_return_val_if_fail (ui_manager, NULL); +osso_context_t * +modest_maemo_utils_get_osso_context (void) +{ + if (!__osso_context) + g_warning ("%s: __osso_context == NULL", __FUNCTION__); - /* Create new main menu */ - main_menu = gtk_menu_new(); - - /* Get the menubar from the UI manager */ - menubar = gtk_ui_manager_get_widget (ui_manager, "/MenuBar"); - - iter = gtk_container_get_children (GTK_CONTAINER (menubar)); - while (iter) { - GtkWidget *menu; - - menu = GTK_WIDGET (iter->data); - gtk_widget_reparent(menu, main_menu); - - iter = g_list_next (iter); - } - return main_menu; + 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) @@ -95,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); @@ -198,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; +}