aboutsummaryrefslogtreecommitdiffstats
path: root/addressbook/gui/widgets/e-addressbook-view.c
diff options
context:
space:
mode:
authorChristopher James Lahey <clahey@ximian.com>2002-02-14 03:35:38 +0800
committerChris Lahey <clahey@src.gnome.org>2002-02-14 03:35:38 +0800
commitc2bf443756e31fb5d360f81a265a4529ea64ebe4 (patch)
tree83253af071f5c73c4e3355df0e4e7f34df5a197e /addressbook/gui/widgets/e-addressbook-view.c
parent22c314f7226679706f06cbd9d2b7dcc0edaf7279 (diff)
downloadgsoc2013-evolution-c2bf443756e31fb5d360f81a265a4529ea64ebe4.tar
gsoc2013-evolution-c2bf443756e31fb5d360f81a265a4529ea64ebe4.tar.gz
gsoc2013-evolution-c2bf443756e31fb5d360f81a265a4529ea64ebe4.tar.bz2
gsoc2013-evolution-c2bf443756e31fb5d360f81a265a4529ea64ebe4.tar.lz
gsoc2013-evolution-c2bf443756e31fb5d360f81a265a4529ea64ebe4.tar.xz
gsoc2013-evolution-c2bf443756e31fb5d360f81a265a4529ea64ebe4.tar.zst
gsoc2013-evolution-c2bf443756e31fb5d360f81a265a4529ea64ebe4.zip
Finishing commit that failed in the middle:
2002-02-13 Christopher James Lahey <clahey@ximian.com> * backend/ebook/e-book-util.c, backend/ebook/e-book-util.h (e_book_expand_uri, e_book_load_address_book_by_uri, e_book_use_address_book_by_uri): New functions that take a file:// url ending in the directory name and automatically append the addressbook.db and do the appropriate thing. * backend/pas/pas-backend-card-sexp.c, backend/pas/pas-backend-card-sexp.h: Added copyright notice here. * gui/component/addressbook-component.c (destination_folder_handle_drop), gui/component/addressbook.c (set_prop): Use e_book_expand_uri instead of addressbook_expand_uri. * gui/component/addressbook-storage.c: Fixed the fcntl include here. * gui/component/addressbook.c (ContactsCopyToFolder, ContactsMoveToFolder): Added handlers for these two verbs. * gui/component/addressbook.h: Removed addressbook_expand_uri in favor of e_book_expand_uri. * gui/widgets/e-addressbook-reflow-adapter.c (transfer_cards): Added code to handle Move to and Copy to right click menu items. * gui/widgets/e-addressbook-util.c, gui/widgets/e-addressbook-util.h (e_addressbook_transfer_cards): New function to pop up a dialog and transfer a set of cards to the given folder. * gui/widgets/e-addressbook-view.c, gui/widgets/e-addressbook-view.h (display_view): Don't attach to the view if it doesn't exist yet. We have to make this then attach later. (e_addressbook_view_copy_to_folder, e_addressbook_view_move_to_folder): New functions utilizing e_addressbook_transfer_cards. (table_right_click): Add copy_to_folder and move_to_folder to the right click menu for tables here. (e_addressbook_view_discard_menus): Handle menu unmerging here. * gui/widgets/e-minicard-view-widget.h (struct _EMinicardViewWidget): Removed unused field. svn path=/trunk/; revision=15711
Diffstat (limited to 'addressbook/gui/widgets/e-addressbook-view.c')
-rw-r--r--addressbook/gui/widgets/e-addressbook-view.c77
1 files changed, 70 insertions, 7 deletions
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;
+}