aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mail/ChangeLog8
-rw-r--r--mail/mail-component.c58
2 files changed, 46 insertions, 20 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index ed32224c3e..caf0ad8e3a 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,3 +1,11 @@
+2004-04-21 Not Zed <NotZed@Ximian.com>
+
+ * mail-component.c (impl_createControls): fix for
+ e_user_creatable_items api changes.
+ (create_item): split out the code to create the item.
+ (create_local_item_cb): new callback for local item creation.
+ (impl_requestCreateItem): call create_item to do the work.
+
2004-04-19 Jeffrey Stedfast <fejj@ximian.com>
* em-folder-browser.c: Use E_ICON_SIZE_* enums for the menu icon
diff --git a/mail/mail-component.c b/mail/mail-component.c
index 815a547e4e..2a4d704d0f 100644
--- a/mail/mail-component.c
+++ b/mail/mail-component.c
@@ -81,6 +81,8 @@
#define d(x)
+static void create_local_item_cb(EUserCreatableItemsHandler *handler, const char *item_type_name, void *data);
+
#define MAIL_COMPONENT_DEFAULT(mc) if (mc == NULL) mc = mail_component_peek();
#define PARENT_TYPE bonobo_object_get_type ()
@@ -551,8 +553,9 @@ impl_createControls (PortableServer_Servant servant,
*corba_statusbar_control = CORBA_Object_duplicate (BONOBO_OBJREF (statusbar_control), ev);
g_object_set_data_full((GObject *)view_widget, "e-creatable-items-handler",
- e_user_creatable_items_handler_new("mail"), (GDestroyNotify)g_object_unref);
-
+ e_user_creatable_items_handler_new("mail", create_local_item_cb, tree_widget),
+ (GDestroyNotify)g_object_unref);
+
g_signal_connect (view_control, "activate", G_CALLBACK (view_control_activate_cb), view_widget);
g_signal_connect (tree_widget, "folder-selected", G_CALLBACK (folder_selected_cb), view_widget);
@@ -665,7 +668,7 @@ impl__get_userCreatableItems (PortableServer_Servant servant, CORBA_Environment
}
static void
-emc_new_folder_response(EMFolderSelector *emfs, int response, MailComponent *mc)
+emc_new_folder_response(EMFolderSelector *emfs, int response, void *dummy)
{
const char *uri, *path;
@@ -681,33 +684,48 @@ emc_new_folder_response(EMFolderSelector *emfs, int response, MailComponent *mc)
gtk_widget_destroy((GtkWidget *)emfs);
}
-static void
-impl_requestCreateItem (PortableServer_Servant servant,
- const CORBA_char *item_type_name,
- CORBA_Environment *ev)
+static int
+create_item(const char *type, EMFolderTreeModel *model, const char *uri)
{
- MailComponent *mc = MAIL_COMPONENT(bonobo_object_from_servant(servant));
-
- if (strcmp(item_type_name, "message") == 0) {
+ if (strcmp(type, "message") == 0) {
if (!em_utils_check_user_can_send_mail(NULL))
- return;
+ return 0;
- em_utils_compose_new_message ();
- } else if (strcmp(item_type_name, "folder") == 0) {
- /* This api is fucked up, too tightly integrated with the tree view */
+ em_utils_compose_new_message();
+ } else if (strcmp(type, "folder") == 0) {
EMFolderTree *folder_tree;
GtkWidget *dialog;
- folder_tree = (EMFolderTree *) em_folder_tree_new_with_model(mc->priv->model);
+ folder_tree = (EMFolderTree *)em_folder_tree_new_with_model(model);
dialog = em_folder_selector_create_new (folder_tree, 0, _("Create folder"), _("Specify where to create the folder:"));
- /* We need to get this from the currently activated component?
- em_folder_selector_set_selected ((EMFolderSelector *) dialog, emft->priv->selected_uri);*/
- g_signal_connect (dialog, "response", G_CALLBACK(emc_new_folder_response), mc);
+ if (uri)
+ em_folder_selector_set_selected ((EMFolderSelector *) dialog, uri);
+ g_signal_connect (dialog, "response", G_CALLBACK(emc_new_folder_response), NULL);
gtk_widget_show(dialog);
- } else {
+ } else
+ return -1;
+
+ return 0;
+}
+
+static void
+create_local_item_cb(EUserCreatableItemsHandler *handler, const char *item_type_name, void *data)
+{
+ EMFolderTree *tree = data;
+
+ create_item(item_type_name, em_folder_tree_get_model(tree), em_folder_tree_get_selected_uri(tree));
+}
+
+static void
+impl_requestCreateItem (PortableServer_Servant servant,
+ const CORBA_char *item_type_name,
+ CORBA_Environment *ev)
+{
+ MailComponent *mc = MAIL_COMPONENT(bonobo_object_from_servant(servant));
+
+ if (create_item(item_type_name, mc->priv->model, NULL) == -1) {
CORBA_exception_set (ev, CORBA_USER_EXCEPTION,
ex_GNOME_Evolution_Component_UnknownType, NULL);
- return;
}
}