aboutsummaryrefslogtreecommitdiffstats
path: root/addressbook/gui/widgets
diff options
context:
space:
mode:
Diffstat (limited to 'addressbook/gui/widgets')
-rw-r--r--addressbook/gui/widgets/e-addressbook-reflow-adapter.c45
-rw-r--r--addressbook/gui/widgets/e-addressbook-util.c161
-rw-r--r--addressbook/gui/widgets/e-addressbook-util.h4
-rw-r--r--addressbook/gui/widgets/e-addressbook-view.c77
-rw-r--r--addressbook/gui/widgets/e-addressbook-view.h71
-rw-r--r--addressbook/gui/widgets/e-minicard-view-widget.h1
6 files changed, 316 insertions, 43 deletions
diff --git a/addressbook/gui/widgets/e-addressbook-reflow-adapter.c b/addressbook/gui/widgets/e-addressbook-reflow-adapter.c
index 51bf381802..ab99206eac 100644
--- a/addressbook/gui/widgets/e-addressbook-reflow-adapter.c
+++ b/addressbook/gui/widgets/e-addressbook-reflow-adapter.c
@@ -95,7 +95,8 @@ text_height (GnomeCanvas *canvas, const gchar *text)
typedef struct {
EAddressbookReflowAdapter *adapter;
- ESelectionModel *selection;
+ ESelectionModel *selection;
+ GtkWidget *widget;
} ModelAndSelection;
static void
@@ -104,6 +105,8 @@ model_and_selection_free (ModelAndSelection *mns)
gtk_object_unref(GTK_OBJECT(mns->adapter));
e_selection_model_right_click_up(mns->selection);
gtk_object_unref(GTK_OBJECT(mns->selection));
+ if (mns->widget)
+ gtk_object_unref(GTK_OBJECT(mns->widget));
g_free(mns);
}
@@ -269,6 +272,37 @@ open_card (GtkWidget *widget, ModelAndSelection *mns)
model_and_selection_free (mns);
}
+static void
+transfer_cards (ModelAndSelection *mns, gboolean delete_from_source)
+{
+ EBook *book;
+ GList *cards;
+ GtkWindow *parent_window;
+
+ book = e_addressbook_model_get_ebook(mns->adapter->priv->model);
+ cards = get_card_list (mns);
+ if (mns->widget)
+ parent_window = GTK_WINDOW (gtk_widget_get_toplevel (mns->widget));
+ else
+ parent_window = NULL;
+
+ e_addressbook_transfer_cards (book, cards, delete_from_source, parent_window);
+
+ model_and_selection_free (mns);
+}
+
+static void
+copy_to_folder (GtkWidget *widget, ModelAndSelection *mns)
+{
+ transfer_cards (mns, FALSE);
+}
+
+static void
+move_to_folder (GtkWidget *widget, ModelAndSelection *mns)
+{
+ transfer_cards (mns, TRUE);
+}
+
#define POPUP_READONLY_MASK 0x01
gint
e_addressbook_reflow_adapter_right_click (EAddressbookReflowAdapter *adapter, GdkEvent *event, ESelectionModel *selection)
@@ -283,6 +317,12 @@ e_addressbook_reflow_adapter_right_click (EAddressbookReflowAdapter *adapter, Gd
#if 0 /* Envelope printing is disabled for Evolution 1.0. */
{N_("Print Envelope"), NULL, GTK_SIGNAL_FUNC(print_envelope), NULL, 0},
#endif
+ E_POPUP_SEPARATOR,
+
+ {N_("Copy to folder..."), NULL, GTK_SIGNAL_FUNC(copy_to_folder), NULL, 0},
+ {N_("Move to folder..."), NULL, GTK_SIGNAL_FUNC(move_to_folder), NULL, POPUP_READONLY_MASK},
+ E_POPUP_SEPARATOR,
+
{N_("Cut"), NULL, GTK_SIGNAL_FUNC (cut), NULL, POPUP_READONLY_MASK},
{N_("Copy"), NULL, GTK_SIGNAL_FUNC (copy), NULL, 0},
{N_("Paste"), NULL, GTK_SIGNAL_FUNC (paste), NULL, POPUP_READONLY_MASK},
@@ -291,8 +331,11 @@ e_addressbook_reflow_adapter_right_click (EAddressbookReflowAdapter *adapter, Gd
mns->adapter = adapter;
mns->selection = selection;
+ mns->widget = gtk_get_event_widget (event);
gtk_object_ref(GTK_OBJECT(mns->adapter));
gtk_object_ref(GTK_OBJECT(mns->selection));
+ if (mns->widget)
+ gtk_object_ref(GTK_OBJECT(mns->widget));
e_popup_menu_run (menu, event, e_addressbook_model_editable(priv->model) ? 0 : POPUP_READONLY_MASK, 0, mns);
return TRUE;
}
diff --git a/addressbook/gui/widgets/e-addressbook-util.c b/addressbook/gui/widgets/e-addressbook-util.c
index c53e16a45c..ea01e4ec5b 100644
--- a/addressbook/gui/widgets/e-addressbook-util.c
+++ b/addressbook/gui/widgets/e-addressbook-util.c
@@ -20,11 +20,13 @@
*/
#include <config.h>
+#include "e-addressbook-util.h"
#include <gnome.h>
-#include "e-addressbook-util.h"
#include "e-card-merging.h"
+#include <shell/evolution-shell-client.h>
+#include <addressbook/backend/ebook/e-book-util.h>
void
e_addressbook_error_dialog (const gchar *msg, EBookStatus status)
@@ -222,3 +224,160 @@ e_addressbook_show_multiple_cards (EBook *book,
}
}
}
+
+
+
+typedef struct CardCopyProcess_ CardCopyProcess;
+
+typedef void (*CardCopyDone) (CardCopyProcess *process);
+
+struct CardCopyProcess_ {
+ int count;
+ GList *cards;
+ EBook *source;
+ EBook *destination;
+ CardCopyDone done_cb;
+};
+
+static void
+card_deleted_cb (EBook* book, EBookStatus status, gpointer user_data)
+{
+ if (status != E_BOOK_STATUS_SUCCESS) {
+ e_addressbook_error_dialog (_("Error removing card"), status);
+ }
+}
+
+static void
+do_delete (gpointer data, gpointer user_data)
+{
+ EBook *book = user_data;
+ ECard *card = data;
+
+ e_book_remove_card(book, card, card_deleted_cb, NULL);
+}
+
+static void
+delete_cards (CardCopyProcess *process)
+{
+ g_list_foreach (process->cards,
+ do_delete,
+ process->source);
+}
+
+static void
+process_unref (CardCopyProcess *process)
+{
+ process->count --;
+ if (process->count == 0) {
+ if (process->done_cb) {
+ process->done_cb (process);
+ }
+ e_free_object_list(process->cards);
+ gtk_object_unref (GTK_OBJECT (process->source));
+ gtk_object_unref (GTK_OBJECT (process->destination));
+ g_free (process);
+ }
+}
+
+static void
+card_added_cb (EBook* book, EBookStatus status, const char *id, gpointer user_data)
+{
+ CardCopyProcess *process = user_data;
+
+ if (status != E_BOOK_STATUS_SUCCESS) {
+ e_addressbook_error_dialog (_("Error adding card"), status);
+ } else {
+ process_unref (process);
+ }
+}
+
+static void
+do_copy (gpointer data, gpointer user_data)
+{
+ EBook *book;
+ ECard *card;
+ CardCopyProcess *process;
+
+ process = user_data;
+ card = data;
+
+ book = process->destination;
+
+ process->count ++;
+ e_book_add_card(book, card, card_added_cb, process);
+}
+
+static void
+got_book_cb (EBook *book, gpointer closure)
+{
+ CardCopyProcess *process;
+ process = closure;
+ if (book) {
+ process->destination = book;
+ gtk_object_ref (GTK_OBJECT (book));
+ g_list_foreach (process->cards,
+ do_copy,
+ process);
+ }
+ process_unref (process);
+}
+
+void
+e_addressbook_transfer_cards (EBook *source, GList *cards /* adopted */, gboolean delete_from_source, GtkWindow *parent_window)
+{
+ const char *allowed_types[] = { "contacts", NULL };
+ extern EvolutionShellClient *global_shell_client;
+ char *uri, *physical, *path, *desc;
+ static char *last = NULL;
+ CardCopyProcess *process;
+
+ if (cards == NULL)
+ return;
+
+ if (last == NULL)
+ last = g_strdup ("");
+
+ if (cards->next == NULL) {
+ if (delete_from_source)
+ desc = _("Move card to");
+ else
+ desc = _("Copy card to");
+ } else {
+ if (delete_from_source)
+ desc = _("Move cards to");
+ else
+ desc = _("Copy cards to");
+ }
+
+ uri = NULL;
+ physical = NULL;
+ evolution_shell_client_user_select_folder (global_shell_client,
+ parent_window,
+ desc, last,
+ allowed_types, &uri, &physical);
+ if (!uri)
+ return;
+
+ path = strchr (uri, '/');
+ if (path && strcmp (last, path) != 0) {
+ g_free (last);
+ last = g_strdup_printf ("evolution:%s", path);
+ }
+ g_free (uri);
+
+ process = g_new (CardCopyProcess, 1);
+ process->count = 1;
+ process->source = source;
+ gtk_object_ref (GTK_OBJECT (source));
+ process->cards = cards;
+ process->destination = NULL;
+
+ if (delete_from_source)
+ process->done_cb = delete_cards;
+ else
+ process->done_cb = NULL;
+
+ e_book_use_address_book_by_uri (physical, got_book_cb, process);
+
+ g_free(physical);
+}
diff --git a/addressbook/gui/widgets/e-addressbook-util.h b/addressbook/gui/widgets/e-addressbook-util.h
index 3fa28a542d..f0681cea4d 100644
--- a/addressbook/gui/widgets/e-addressbook-util.h
+++ b/addressbook/gui/widgets/e-addressbook-util.h
@@ -43,6 +43,10 @@ EContactListEditor *e_addressbook_show_contact_list_editor (EBook *book,
void e_addressbook_show_multiple_cards (EBook *book,
GList *list,
gboolean editable);
+void e_addressbook_transfer_cards (EBook *source,
+ GList *cards, /* adopted */
+ gboolean delete_from_source,
+ GtkWindow *parent_window);
#ifdef __cplusplus
}
diff --git a/addressbook/gui/widgets/e-addressbook-view.c b/addressbook/gui/widgets/e-addressbook-view.c
index 1ed12066cc..93da4c8c29 100644
--- a/addressbook/gui/widgets/e-addressbook-view.c
+++ b/addressbook/gui/widgets/e-addressbook-view.c
@@ -468,7 +468,8 @@ display_view(GalViewInstance *instance,
gal_view_etable_attach_table (GAL_VIEW_ETABLE(view), e_table_scrolled_get_table(E_TABLE_SCROLLED(address_view->widget)));
} else if (GAL_IS_VIEW_MINICARD(view)) {
change_view_type (address_view, E_ADDRESSBOOK_VIEW_MINICARD);
- gal_view_minicard_attach (GAL_VIEW_MINICARD(view), E_MINICARD_VIEW (E_MINICARD_VIEW_WIDGET (address_view->object)->emv));
+ if (address_view->object && E_MINICARD_VIEW_WIDGET (address_view->object)->emv)
+ gal_view_minicard_attach (GAL_VIEW_MINICARD(view), E_MINICARD_VIEW (E_MINICARD_VIEW_WIDGET (address_view->object)->emv));
}
address_view->current_view = view;
}
@@ -998,6 +999,20 @@ delete (GtkWidget *widget, CardAndBook *card_and_book)
card_and_book_free(card_and_book);
}
+static void
+copy_to_folder (GtkWidget *widget, CardAndBook *card_and_book)
+{
+ e_addressbook_view_copy_to_folder (card_and_book->view);
+ card_and_book_free (card_and_book);
+}
+
+static void
+move_to_folder (GtkWidget *widget, CardAndBook *card_and_book)
+{
+ e_addressbook_view_move_to_folder (card_and_book->view);
+ card_and_book_free (card_and_book);
+}
+
#define POPUP_READONLY_MASK 0x1
static gint
table_right_click(ETableScrolled *table, gint row, gint col, GdkEvent *event, EAddressbookView *view)
@@ -1014,11 +1029,17 @@ table_right_click(ETableScrolled *table, gint row, gint col, GdkEvent *event, EA
#if 0 /* Envelope printing is disabled for Evolution 1.0. */
{N_("Print Envelope"), NULL, GTK_SIGNAL_FUNC(print_envelope), NULL, 0},
#endif
+ E_POPUP_SEPARATOR,
+
+ {N_("Copy to folder..."), NULL, GTK_SIGNAL_FUNC(copy_to_folder), NULL, 0},
+ {N_("Move to folder..."), NULL, GTK_SIGNAL_FUNC(move_to_folder), NULL, POPUP_READONLY_MASK},
+ E_POPUP_SEPARATOR,
+
{N_("Cut"), NULL, GTK_SIGNAL_FUNC (cut), NULL, POPUP_READONLY_MASK},
{N_("Copy"), NULL, GTK_SIGNAL_FUNC (copy), NULL, 0},
{N_("Paste"), NULL, GTK_SIGNAL_FUNC (paste), NULL, POPUP_READONLY_MASK},
{N_("Delete"), NULL, GTK_SIGNAL_FUNC(delete), NULL, POPUP_READONLY_MASK},
- {NULL, NULL, NULL, NULL, 0}
+ E_POPUP_TERMINATOR
};
card_and_book = g_new(CardAndBook, 1);
@@ -1303,16 +1324,18 @@ e_addressbook_view_discard_menus (EAddressbookView *view)
g_return_if_fail (E_IS_ADDRESSBOOK_VIEW (view));
g_return_if_fail (view->view_instance);
- if (view->view_instance) {
- gtk_object_unref (GTK_OBJECT (view->view_instance));
- view->view_instance = NULL;
- }
-
if (view->view_menus) {
+ gal_view_menus_unmerge (view->view_menus, NULL);
+
gtk_object_unref (GTK_OBJECT (view->view_menus));
view->view_menus = NULL;
}
+ if (view->view_instance) {
+ gtk_object_unref (GTK_OBJECT (view->view_instance));
+ view->view_instance = NULL;
+ }
+
view->uic = NULL;
}
@@ -1699,6 +1722,35 @@ e_addressbook_view_stop(EAddressbookView *view)
e_addressbook_model_stop (view->model);
}
+static void
+view_transfer_cards (EAddressbookView *view, gboolean delete_from_source)
+{
+ EBook *book;
+ GList *cards;
+ GtkWindow *parent_window;
+
+ gtk_object_get(GTK_OBJECT(view->model),
+ "book", &book,
+ NULL);
+ cards = get_selected_cards (view);
+ parent_window = GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (view)));
+
+ e_addressbook_transfer_cards (book, cards, delete_from_source, parent_window);
+}
+
+void
+e_addressbook_view_copy_to_folder (EAddressbookView *view)
+{
+ view_transfer_cards (view, FALSE);
+}
+
+void
+e_addressbook_view_move_to_folder (EAddressbookView *view)
+{
+ view_transfer_cards (view, TRUE);
+}
+
+
static gboolean
e_addressbook_view_selection_nonempty (EAddressbookView *view)
{
@@ -1783,3 +1835,14 @@ e_addressbook_view_can_stop (EAddressbookView *view)
return view ? e_addressbook_model_can_stop (view->model) : FALSE;
}
+gboolean
+e_addressbook_view_can_copy_to_folder (EAddressbookView *view)
+{
+ return view ? e_addressbook_view_selection_nonempty (view) : FALSE;
+}
+
+gboolean
+e_addressbook_view_can_move_to_folder (EAddressbookView *view)
+{
+ return view ? e_addressbook_view_selection_nonempty (view) && e_addressbook_model_editable (view->model) : FALSE;
+}
diff --git a/addressbook/gui/widgets/e-addressbook-view.h b/addressbook/gui/widgets/e-addressbook-view.h
index 98258ab88c..58511845bd 100644
--- a/addressbook/gui/widgets/e-addressbook-view.h
+++ b/addressbook/gui/widgets/e-addressbook-view.h
@@ -99,39 +99,44 @@ struct _EAddressbookViewClass
void (*alphabet_state_change) (EAddressbookView *view, gunichar letter);
};
-GtkWidget *e_addressbook_view_new (void);
-GtkType e_addressbook_view_get_type (void);
-
-void e_addressbook_view_setup_menus (EAddressbookView *view,
- BonoboUIComponent *uic);
-void e_addressbook_view_discard_menus (EAddressbookView *view);
-
-void e_addressbook_view_save_as (EAddressbookView *view);
-void e_addressbook_view_view (EAddressbookView *view);
-void e_addressbook_view_send (EAddressbookView *view);
-void e_addressbook_view_send_to (EAddressbookView *view);
-void e_addressbook_view_print (EAddressbookView *view);
-void e_addressbook_view_print_preview (EAddressbookView *view);
-void e_addressbook_view_delete_selection (EAddressbookView *view);
-void e_addressbook_view_cut (EAddressbookView *view);
-void e_addressbook_view_copy (EAddressbookView *view);
-void e_addressbook_view_paste (EAddressbookView *view);
-void e_addressbook_view_select_all (EAddressbookView *view);
-void e_addressbook_view_show_all (EAddressbookView *view);
-void e_addressbook_view_stop (EAddressbookView *view);
-
-gboolean e_addressbook_view_can_create (EAddressbookView *view);
-gboolean e_addressbook_view_can_print (EAddressbookView *view);
-gboolean e_addressbook_view_can_save_as (EAddressbookView *view);
-gboolean e_addressbook_view_can_view (EAddressbookView *view);
-gboolean e_addressbook_view_can_send (EAddressbookView *view);
-gboolean e_addressbook_view_can_send_to (EAddressbookView *view);
-gboolean e_addressbook_view_can_delete (EAddressbookView *view);
-gboolean e_addressbook_view_can_cut (EAddressbookView *view);
-gboolean e_addressbook_view_can_copy (EAddressbookView *view);
-gboolean e_addressbook_view_can_paste (EAddressbookView *view);
-gboolean e_addressbook_view_can_select_all (EAddressbookView *view);
-gboolean e_addressbook_view_can_stop (EAddressbookView *view);
+GtkWidget *e_addressbook_view_new (void);
+GtkType e_addressbook_view_get_type (void);
+
+void e_addressbook_view_setup_menus (EAddressbookView *view,
+ BonoboUIComponent *uic);
+
+void e_addressbook_view_discard_menus (EAddressbookView *view);
+
+void e_addressbook_view_save_as (EAddressbookView *view);
+void e_addressbook_view_view (EAddressbookView *view);
+void e_addressbook_view_send (EAddressbookView *view);
+void e_addressbook_view_send_to (EAddressbookView *view);
+void e_addressbook_view_print (EAddressbookView *view);
+void e_addressbook_view_print_preview (EAddressbookView *view);
+void e_addressbook_view_delete_selection (EAddressbookView *view);
+void e_addressbook_view_cut (EAddressbookView *view);
+void e_addressbook_view_copy (EAddressbookView *view);
+void e_addressbook_view_paste (EAddressbookView *view);
+void e_addressbook_view_select_all (EAddressbookView *view);
+void e_addressbook_view_show_all (EAddressbookView *view);
+void e_addressbook_view_stop (EAddressbookView *view);
+void e_addressbook_view_copy_to_folder (EAddressbookView *view);
+void e_addressbook_view_move_to_folder (EAddressbookView *view);
+
+gboolean e_addressbook_view_can_create (EAddressbookView *view);
+gboolean e_addressbook_view_can_print (EAddressbookView *view);
+gboolean e_addressbook_view_can_save_as (EAddressbookView *view);
+gboolean e_addressbook_view_can_view (EAddressbookView *view);
+gboolean e_addressbook_view_can_send (EAddressbookView *view);
+gboolean e_addressbook_view_can_send_to (EAddressbookView *view);
+gboolean e_addressbook_view_can_delete (EAddressbookView *view);
+gboolean e_addressbook_view_can_cut (EAddressbookView *view);
+gboolean e_addressbook_view_can_copy (EAddressbookView *view);
+gboolean e_addressbook_view_can_paste (EAddressbookView *view);
+gboolean e_addressbook_view_can_select_all (EAddressbookView *view);
+gboolean e_addressbook_view_can_stop (EAddressbookView *view);
+gboolean e_addressbook_view_can_copy_to_folder (EAddressbookView *view);
+gboolean e_addressbook_view_can_move_to_folder (EAddressbookView *view);
#ifdef __cplusplus
}
diff --git a/addressbook/gui/widgets/e-minicard-view-widget.h b/addressbook/gui/widgets/e-minicard-view-widget.h
index 39fb929bea..4cf3a72d93 100644
--- a/addressbook/gui/widgets/e-minicard-view-widget.h
+++ b/addressbook/gui/widgets/e-minicard-view-widget.h
@@ -44,7 +44,6 @@ struct _EMinicardViewWidget
{
ECanvas parent;
- GnomeCanvasItem *rect;
GnomeCanvasItem *emv;
EAddressbookReflowAdapter *adapter;