diff options
Diffstat (limited to 'addressbook/gui')
-rw-r--r-- | addressbook/gui/component/addressbook-component.c | 85 |
1 files changed, 73 insertions, 12 deletions
diff --git a/addressbook/gui/component/addressbook-component.c b/addressbook/gui/component/addressbook-component.c index 250d13dc36..b991db11d7 100644 --- a/addressbook/gui/component/addressbook-component.c +++ b/addressbook/gui/component/addressbook-component.c @@ -28,6 +28,7 @@ #include <bonobo/bonobo-generic-factory.h> #include "evolution-shell-component.h" +#include "evolution-shell-component-dnd.h" #include "evolution-storage.h" #include "addressbook-storage.h" @@ -101,14 +102,13 @@ create_folder (EvolutionShellComponent *shell_component, CORBA_exception_free(&ev); } -#if 0 static void remove_folder (EvolutionShellComponent *shell_component, const char *physical_uri, const GNOME_Evolution_ShellComponentListener listener, void *closure) { - printf ("should remove %s\n", physical_uri); + g_print ("should remove %s\n", physical_uri); } static void @@ -119,8 +119,41 @@ xfer_folder (EvolutionShellComponent *shell_component, const GNOME_Evolution_ShellComponentListener listener, void *closure) { - printf ("should transfer %s to %s, %s source\n", source_physical_uri, - destination_physical_uri, remove_source ? "removing" : "not removing"); + CORBA_Environment ev; + char *source_path; + char *destination_path; + + g_print ("should transfer %s to %s, %s source\n", source_physical_uri, + destination_physical_uri, remove_source ? "removing" : "not removing"); + + if (!strncmp (source_physical_uri, "ldap:", 5) + || !strncmp (destination_physical_uri, "ldap:", 5)) { + GNOME_Evolution_ShellComponentListener_notifyResult (listener, GNOME_Evolution_ShellComponentListener_UNSUPPORTED_OPERATION, &ev); + return; + } + if (strncmp (source_physical_uri, "file://", 7) + || strncmp (destination_physical_uri, "file://", 7)) { + GNOME_Evolution_ShellComponentListener_notifyResult (listener, GNOME_Evolution_ShellComponentListener_INVALID_URI, &ev); + return; + } + + /* strip the 'file://' from the beginning of each uri and add addressbook.db */ + source_path = g_concat_dir_and_file (source_physical_uri + 7, "addressbook.db"); + destination_path = g_concat_dir_and_file (destination_physical_uri + 7, "addressbook.db"); + + if (remove_source) { + g_print ("rename %s %s\n", source_path, destination_path); + } + else { + g_print ("copy %s %s\n", source_path, destination_path); + } + + CORBA_exception_init (&ev); + + /* XXX always fail for now, until the above stuff is written */ + GNOME_Evolution_ShellComponentListener_notifyResult (listener, GNOME_Evolution_ShellComponentListener_PERMISSION_DENIED, &ev); + + CORBA_exception_free (&ev); } static void @@ -130,7 +163,7 @@ populate_context_menu (EvolutionShellComponent *shell_component, const char *type, void *closure) { - printf ("should populate context menu for %s (%s)\n", physical_uri, type); + g_print ("should populate context menu for %s (%s)\n", physical_uri, type); } static char* @@ -142,10 +175,9 @@ get_dnd_selection (EvolutionShellComponent *shell_component, int *selection_length_return, void *closure) { - printf ("should get dnd selection for %s\n", physical_uri); + g_print ("should get dnd selection for %s\n", physical_uri); return NULL; } -#endif static int owner_count = 0; @@ -173,6 +205,29 @@ owner_unset_cb (EvolutionShellComponent *shell_component, gtk_main_quit(); } +static CORBA_boolean +destination_folder_handle_motion (EvolutionShellComponentDndDestinationFolder *folder, + const char *physical_uri, + const GNOME_Evolution_ShellComponentDnd_DestinationFolder_Context * destination_context, + GNOME_Evolution_ShellComponentDnd_Action * suggested_action_return, + gpointer user_data) +{ + g_print ("in destination_folder_handle_motion (%s)\n", physical_uri); + return TRUE; +} + +static CORBA_boolean +destination_folder_handle_drop (EvolutionShellComponentDndDestinationFolder *folder, + const char *physical_uri, + const GNOME_Evolution_ShellComponentDnd_DestinationFolder_Context * destination_context, + const GNOME_Evolution_ShellComponentDnd_Action action, + const GNOME_Evolution_ShellComponentDnd_Data * data, + gpointer user_data) +{ + g_print ("in destination_folder_handle_drop (%s)\n", physical_uri); + return TRUE; +} + /* The factory function. */ @@ -181,15 +236,21 @@ factory_fn (BonoboGenericFactory *factory, void *closure) { EvolutionShellComponent *shell_component; + EvolutionShellComponentDndDestinationFolder *destination_interface; shell_component = evolution_shell_component_new (folder_types, create_view, create_folder, - NULL, NULL, NULL, NULL, -#if 0 - remove_folder, xfer_folder, - populate_context_menu, get_dnd_selection, -#endif + remove_folder, xfer_folder, + populate_context_menu, + get_dnd_selection, NULL); + destination_interface = evolution_shell_component_dnd_destination_folder_new (destination_folder_handle_motion, + destination_folder_handle_drop, + shell_component); + + bonobo_object_add_interface (BONOBO_OBJECT (shell_component), + BONOBO_OBJECT (destination_interface)); + gtk_signal_connect (GTK_OBJECT (shell_component), "owner_set", GTK_SIGNAL_FUNC (owner_set_cb), NULL); |