diff options
Diffstat (limited to 'addressbook/gui/widgets')
-rw-r--r-- | addressbook/gui/widgets/e-minicard-view-model.c | 26 | ||||
-rw-r--r-- | addressbook/gui/widgets/e-minicard-view-model.h | 2 | ||||
-rw-r--r-- | addressbook/gui/widgets/e-minicard-view.c | 74 | ||||
-rw-r--r-- | addressbook/gui/widgets/e-minicard-view.h | 2 |
4 files changed, 86 insertions, 18 deletions
diff --git a/addressbook/gui/widgets/e-minicard-view-model.c b/addressbook/gui/widgets/e-minicard-view-model.c index ab0999518b..c58452a3ac 100644 --- a/addressbook/gui/widgets/e-minicard-view-model.c +++ b/addressbook/gui/widgets/e-minicard-view-model.c @@ -12,8 +12,8 @@ #include "e-minicard-view-model.h" #include <gal/util/e-i18n.h> +#include <gal/util/e-util.h> -#include "e-minicard.h" #include <gal/widgets/e-unicode.h> #include <gal/widgets/e-font.h> #include <gal/widgets/e-popup-menu.h> @@ -43,6 +43,7 @@ enum { enum { STATUS_MESSAGE, + DRAG_BEGIN, LAST_SIGNAL }; @@ -366,6 +367,18 @@ addressbook_compare (EReflowModel *erm, int n1, int n2) return 0; } +static int +minicard_drag_begin (EMinicard *card, GdkEvent *event, EMinicardViewModel *model) +{ + gint ret_val = 0; + + gtk_signal_emit (GTK_OBJECT(model), + e_minicard_view_model_signals[DRAG_BEGIN], + event, &ret_val); + + return ret_val; +} + static GnomeCanvasItem * addressbook_incarnate (EReflowModel *erm, int i, GnomeCanvasGroup *parent) { @@ -382,6 +395,8 @@ addressbook_incarnate (EReflowModel *erm, int i, GnomeCanvasGroup *parent) gtk_signal_connect (GTK_OBJECT (item), "selected", GTK_SIGNAL_FUNC(card_selected), emvm); #endif + gtk_signal_connect (GTK_OBJECT (item), "drag_begin", + GTK_SIGNAL_FUNC(minicard_drag_begin), emvm); return item; } @@ -493,6 +508,15 @@ e_minicard_view_model_class_init (GtkObjectClass *object_class) gtk_marshal_NONE__POINTER, GTK_TYPE_NONE, 1, GTK_TYPE_POINTER); + e_minicard_view_model_signals [DRAG_BEGIN] = + gtk_signal_new ("drag_begin", + GTK_RUN_LAST, + object_class->type, + GTK_SIGNAL_OFFSET (EMinicardViewModelClass, drag_begin), + gtk_marshal_INT__POINTER, + GTK_TYPE_INT, 2, GTK_TYPE_POINTER, GTK_TYPE_POINTER); + + gtk_object_class_add_signals (object_class, e_minicard_view_model_signals, LAST_SIGNAL); model_class->set_width = addressbook_set_width; diff --git a/addressbook/gui/widgets/e-minicard-view-model.h b/addressbook/gui/widgets/e-minicard-view-model.h index c0e1029522..c958a81690 100644 --- a/addressbook/gui/widgets/e-minicard-view-model.h +++ b/addressbook/gui/widgets/e-minicard-view-model.h @@ -4,6 +4,7 @@ #include <gal/widgets/e-reflow-model.h> #include <gal/widgets/e-selection-model.h> +#include "e-minicard.h" #include "addressbook/backend/ebook/e-book.h" #include "addressbook/backend/ebook/e-book-view.h" #include "addressbook/backend/ebook/e-card.h" @@ -52,6 +53,7 @@ struct _EMinicardViewModelClass { * Signals */ void (*status_message) (EMinicardViewModel *model, const gchar *message); + gint (* drag_begin) (EMinicardViewModel *model, GdkEvent *event); }; diff --git a/addressbook/gui/widgets/e-minicard-view.c b/addressbook/gui/widgets/e-minicard-view.c index 85a456cde1..3a89978756 100644 --- a/addressbook/gui/widgets/e-minicard-view.c +++ b/addressbook/gui/widgets/e-minicard-view.c @@ -32,7 +32,6 @@ #include <gal/widgets/e-unicode.h> #include <libgnome/gnome-i18n.h> -#if 0 static void canvas_destroy (GtkObject *object, EMinicardView *view); static void e_minicard_view_drag_data_get(GtkWidget *widget, GdkDragContext *context, @@ -40,7 +39,6 @@ static void e_minicard_view_drag_data_get(GtkWidget *widget, guint info, guint time, EMinicardView *view); -#endif static EReflowClass *parent_class = NULL; #define PARENT_TYPE (E_REFLOW_TYPE) @@ -58,20 +56,17 @@ enum { LAST_SIGNAL }; -#if 0 enum DndTargetType { - DND_TARGET_TYPE_VCARD, + DND_TARGET_TYPE_VCARD_LIST, }; -#define VCARD_TYPE "text/x-vcard" +#define VCARD_LIST_TYPE "text/x-vcard" static GtkTargetEntry drag_types[] = { - { VCARD_TYPE, 0, DND_TARGET_TYPE_VCARD } + { VCARD_LIST_TYPE, 0, DND_TARGET_TYPE_VCARD_LIST } }; static gint num_drag_types = sizeof(drag_types) / sizeof(drag_types[0]); -#endif static guint e_minicard_view_signals [LAST_SIGNAL] = {0, }; -#if 0 static void e_minicard_view_drag_data_get(GtkWidget *widget, GdkDragContext *context, @@ -80,16 +75,14 @@ e_minicard_view_drag_data_get(GtkWidget *widget, guint time, EMinicardView *view) { - printf ("e_minicard_view_drag_data_get (e_minicard = %p)\n", view->drag_card); - if (!E_IS_MINICARD_VIEW(view)) return; switch (info) { - case DND_TARGET_TYPE_VCARD: { + case DND_TARGET_TYPE_VCARD_LIST: { char *value; - - value = e_card_simple_get_vcard(view->drag_card->simple); + + value = e_card_list_get_vcard(view->drag_list); gtk_selection_data_set (selection_data, selection_data->target, @@ -98,27 +91,64 @@ e_minicard_view_drag_data_get(GtkWidget *widget, break; } } + + g_list_foreach (view->drag_list, (GFunc)gtk_object_unref, NULL); + g_list_free (view->drag_list); + view->drag_list = NULL; +} + +typedef struct { + GList *list; + EMinicardViewModel *model; +} ModelAndList; + +static void +add_to_list (int index, gpointer closure) +{ + ModelAndList *mal = closure; + mal->list = g_list_prepend (mal->list, e_minicard_view_model_get_card (mal->model, index)); +} + +static GList * +get_card_list (EMinicardViewModel *model, ESelectionModel *selection) +{ + ModelAndList mal; + + mal.model = model; + mal.list = NULL; + + e_selection_model_foreach (selection, add_to_list, &mal); + + mal.list = g_list_reverse (mal.list); + return mal.list; } static int -e_minicard_view_drag_begin (EMinicard *card, GdkEvent *event, EMinicardView *view) +e_minicard_view_drag_begin (EMinicardViewModel *model, GdkEvent *event, EMinicardView *view) { GdkDragContext *context; GtkTargetList *target_list; GdkDragAction actions = GDK_ACTION_MOVE; - view->drag_card = card; + view->drag_list = get_card_list (model, E_REFLOW (view)->selection); + + g_print ("dragging %d card(s)\n", g_list_length (view->drag_list)); target_list = gtk_target_list_new (drag_types, num_drag_types); context = gtk_drag_begin (GTK_WIDGET (GNOME_CANVAS_ITEM (view)->canvas), target_list, actions, 1/*XXX*/, event); + if (!view->canvas_drag_data_get_id) + view->canvas_drag_data_get_id = gtk_signal_connect (GTK_OBJECT (GNOME_CANVAS_ITEM (view)->canvas), + "drag_data_get", + GTK_SIGNAL_FUNC (e_minicard_view_drag_data_get), + view); + gtk_drag_set_icon_default (context); return TRUE; } -#endif #if 0 static void @@ -327,7 +357,12 @@ disconnect_signals(EMinicardView *view) gtk_signal_disconnect(GTK_OBJECT (view->model), view->status_message_id); + if (view->canvas_drag_data_get_id) + gtk_signal_disconnect(GTK_OBJECT (GNOME_CANVAS_ITEM (view)->canvas), + view->status_message_id); + view->status_message_id = 0; + view->canvas_drag_data_get_id = 0; } #if 0 @@ -466,12 +501,19 @@ e_minicard_view_init (EMinicardView *view) view->model = E_MINICARD_VIEW_MODEL(e_minicard_view_model_new()); + view->canvas_drag_data_get_id = 0; + view->status_message_id = 0; + empty_message = e_utf8_from_locale_string(_("\n\nThere are no items to show in this view\n\n" "Double-click here to create a new Contact.")); gtk_object_set (GTK_OBJECT(view), "empty_message", empty_message, "model", view->model, NULL); + + gtk_signal_connect (GTK_OBJECT (view->model), "drag_begin", + GTK_SIGNAL_FUNC (e_minicard_view_drag_begin), view); + g_free (empty_message); } diff --git a/addressbook/gui/widgets/e-minicard-view.h b/addressbook/gui/widgets/e-minicard-view.h index 253eedd3ac..318989958b 100644 --- a/addressbook/gui/widgets/e-minicard-view.h +++ b/addressbook/gui/widgets/e-minicard-view.h @@ -72,7 +72,7 @@ struct _EMinicardView ESelectionModelSimple *selection; - EMinicard *drag_card; + GList *drag_list; int canvas_destroy_id; int canvas_drag_data_get_id; |