aboutsummaryrefslogtreecommitdiffstats
path: root/addressbook/gui/widgets
diff options
context:
space:
mode:
authorChris Toshok <toshok@ximian.com>2001-08-21 07:31:16 +0800
committerChris Toshok <toshok@src.gnome.org>2001-08-21 07:31:16 +0800
commit13c5202cd9f214fddaa95ac259544efc9cd70bd5 (patch)
tree1948849b192d02cbceafb3fd151bbaad7cdb2b9a /addressbook/gui/widgets
parent27ab1e72a98d218c20c658b35fea7af721d708ab (diff)
downloadgsoc2013-evolution-13c5202cd9f214fddaa95ac259544efc9cd70bd5.tar.gz
gsoc2013-evolution-13c5202cd9f214fddaa95ac259544efc9cd70bd5.tar.zst
gsoc2013-evolution-13c5202cd9f214fddaa95ac259544efc9cd70bd5.zip
fix arg info - we're only passing 1 GTK_TYPE_POINTER arg, not 2.
2001-08-20 Chris Toshok <toshok@ximian.com> * gui/widgets/e-addressbook-reflow-adapter.c (e_addressbook_reflow_adapter_class_init): fix arg info - we're only passing 1 GTK_TYPE_POINTER arg, not 2. * gui/widgets/e-minicard.c (e_minicard_event): lots of fixes for DnD. For GDK_BUTTON_PRESS, we grab immediately. For GDK_BUTTON_MOTION, we start the drag after a certain threshold, and connect to the "drag_end" signal on our canvas so we'll know when the drag is complete. For GDK_BUTTON_RELEASE, we release the grab if we were dragging and get the event. (e_minicard_drag_end): new function, just remove the pointer/gtk grabs and disconnect. * gui/widgets/e-minicard.h (struct _EMinicard): add "gint drag_button" svn path=/trunk/; revision=12331
Diffstat (limited to 'addressbook/gui/widgets')
-rw-r--r--addressbook/gui/widgets/e-addressbook-reflow-adapter.c2
-rw-r--r--addressbook/gui/widgets/e-minicard.c67
-rw-r--r--addressbook/gui/widgets/e-minicard.h1
3 files changed, 53 insertions, 17 deletions
diff --git a/addressbook/gui/widgets/e-addressbook-reflow-adapter.c b/addressbook/gui/widgets/e-addressbook-reflow-adapter.c
index b9f4917015..97ceb36a1f 100644
--- a/addressbook/gui/widgets/e-addressbook-reflow-adapter.c
+++ b/addressbook/gui/widgets/e-addressbook-reflow-adapter.c
@@ -548,7 +548,7 @@ e_addressbook_reflow_adapter_class_init (GtkObjectClass *object_class)
object_class->type,
GTK_SIGNAL_OFFSET (EAddressbookReflowAdapterClass, drag_begin),
gtk_marshal_INT__POINTER,
- GTK_TYPE_INT, 2, GTK_TYPE_POINTER, GTK_TYPE_POINTER);
+ GTK_TYPE_INT, 1, GTK_TYPE_POINTER);
gtk_object_class_add_signals (object_class, e_addressbook_reflow_adapter_signals, LAST_SIGNAL);
diff --git a/addressbook/gui/widgets/e-minicard.c b/addressbook/gui/widgets/e-minicard.c
index 6835017a5b..1638ee266c 100644
--- a/addressbook/gui/widgets/e-minicard.c
+++ b/addressbook/gui/widgets/e-minicard.c
@@ -55,6 +55,7 @@ static void e_minicard_resize_children( EMinicard *e_minicard );
static void remodel( EMinicard *e_minicard );
static gint e_minicard_drag_begin (EMinicard *minicard, GdkEvent *event);
+static void e_minicard_drag_end (GtkWidget *canvas, GdkDragContext *context, EMinicard *e_minicard);
static GnomeCanvasGroupClass *parent_class = NULL;
@@ -509,30 +510,49 @@ e_minicard_event (GnomeCanvasItem *item, GdkEvent *event)
}
}
break;
- case GDK_BUTTON_PRESS:
- if (event->button.button == 1) {
- int ret_val = e_minicard_selected(e_minicard, event);
- e_canvas_item_grab_focus(item, TRUE);
- e_minicard->button_x = event->button.x;
- e_minicard->button_y = event->button.y;
- e_minicard->drag_button_down = TRUE;
- return ret_val;
- } else if (event->button.button == 3) {
- return e_minicard_selected(e_minicard, event);
+ case GDK_BUTTON_PRESS: {
+ int ret_val = e_minicard_selected(e_minicard, event);
+ GdkEventMask mask = ((1 << (4 + event->button.button)) |
+ GDK_POINTER_MOTION_MASK |
+ GDK_BUTTON_RELEASE_MASK);
+
+ e_canvas_item_grab_focus(item, TRUE);
+
+ if (gnome_canvas_item_grab (GNOME_CANVAS_ITEM (e_minicard),
+ mask, NULL, event->button.time)) {
+ return FALSE;
}
- break;
+ gtk_grab_add (GTK_WIDGET (GNOME_CANVAS_ITEM (e_minicard)->canvas));
+ e_minicard->button_x = event->button.x;
+ e_minicard->button_y = event->button.y;
+ e_minicard->drag_button = event->button.button;
+ e_minicard->drag_button_down = TRUE;
+ return ret_val;
+ }
case GDK_BUTTON_RELEASE:
- e_minicard->drag_button_down = FALSE;
+ if (e_minicard->drag_button_down && e_minicard->drag_button == event->button.button) {
+ e_minicard->drag_button = 0;
+ e_minicard->drag_button_down = FALSE;
+ e_minicard->button_x = -1;
+ e_minicard->button_y = -1;
+
+ if (GTK_WIDGET_HAS_GRAB (GNOME_CANVAS_ITEM (e_minicard)->canvas)) {
+ gtk_grab_remove (GTK_WIDGET (GNOME_CANVAS_ITEM (e_minicard)->canvas));
+ gnome_canvas_item_ungrab (GNOME_CANVAS_ITEM (e_minicard), event->button.time);
+ }
+ }
break;
case GDK_MOTION_NOTIFY:
- /* shamelessly ripped from e-table.c, complete with
- broken stuck-grab behavior */
if (e_minicard->drag_button_down && event->motion.state & GDK_BUTTON1_MASK) {
if (MAX (abs (e_minicard->button_x - event->motion.x),
abs (e_minicard->button_y - event->motion.y)) > 3) {
- gint ret_val = e_minicard_drag_begin(e_minicard, event);
+ gint ret_val;
+
+ ret_val = e_minicard_drag_begin(e_minicard, event);
- printf ("signalled drag begin\n");
+ /* now we register with drag end on our canvas so we can know when to release our grab */
+ gtk_signal_connect (GTK_OBJECT (GNOME_CANVAS_ITEM (e_minicard)->canvas),
+ "drag_end", (GtkSignalFunc)e_minicard_drag_end, e_minicard);
e_minicard->drag_button_down = FALSE;
@@ -935,3 +955,18 @@ e_minicard_drag_begin (EMinicard *minicard, GdkEvent *event)
event, &ret_val);
return ret_val;
}
+
+static void
+e_minicard_drag_end (GtkWidget *canvas, GdkDragContext *context, EMinicard *e_minicard)
+{
+ e_minicard->drag_button = 0;
+ e_minicard->drag_button_down = FALSE;
+ e_minicard->button_x = -1;
+ e_minicard->button_y = -1;
+
+ gtk_grab_remove (GTK_WIDGET (GNOME_CANVAS_ITEM (e_minicard)->canvas));
+ gnome_canvas_item_ungrab (GNOME_CANVAS_ITEM (e_minicard), GDK_CURRENT_TIME);
+
+ gtk_signal_disconnect_by_func (GTK_OBJECT (GNOME_CANVAS_ITEM (e_minicard)->canvas),
+ (GtkSignalFunc)e_minicard_drag_end, e_minicard);
+}
diff --git a/addressbook/gui/widgets/e-minicard.h b/addressbook/gui/widgets/e-minicard.h
index 5a0f590c23..bd74a24c09 100644
--- a/addressbook/gui/widgets/e-minicard.h
+++ b/addressbook/gui/widgets/e-minicard.h
@@ -89,6 +89,7 @@ struct _EMinicard
guint editable : 1;
guint drag_button_down : 1;
+ gint drag_button;
gint button_x;
gint button_y;
ass='insertions'>+1 * This program checks memcached (or compatible) server by memcachedkuriyama2010-04-291-0/+1 * This "check_kumofs" is Nagios plugin for monitoring kumofs server nodekuriyama2010-04-291-0/+1 * - PHP 5.2 slave portdinoex2010-04-241-0/+1 * - Resurrect this portpgollucci2010-02-131-0/+1 * 2009-07-01 net-mgmt/net-snmp4: Use net-mgmt/net-snmp port insteadpgollucci2010-02-131-1/+0 * RackMonkey is a web-based tool for managing racks of equipmentpgollucci2010-02-131-0/+1 * ramond monitors IPv6 networks for router advertisements.miwi2010-01-271-0/+1 * - Fix sorting and minor cleanups in category Makefilesamdmi32010-01-201-6/+6 * - remove broken/expired ports@ portspgollucci2010-01-181-1/+0 * glpi-plugin-tracker-agent in a program writen in perl. It receivepgollucci2010-01-101-0/+1 * glpi-tracker-server in a plugin for glpi witch make inventory ofpgollucci2010-01-101-0/+1 * - Update zabbix to 1.8pav2009-12-141-1/+7 * qKismet is graphical Kismet client writtent in Qt. It aims to be a full-featuredmiwi2009-12-131-0/+1 * Read and process an SNMP trap from Net-SNMP's snmptrapdmiwi2009-12-121-0/+1 * bsnmp-jails is a module for bsnmpd which allows you to measure statisticsdinoex2009-12-121-0/+1 * - Remove expired p5-SNMP portpav2009-12-081-1/+0 * - Remove net-snmp-tkmib, it depends on expired ports net-snmp4 and p5-SNMPpav2009-12-081-1/+0 * Add wifimgr 1.0.1, wiFi Networks Manager.ehaupt2009-11-231-0/+1 * This program is a lightweight access- and prefix-list generatormiwi2009-11-211-0/+1 * NagiosGrapher is a full-featured RRD based charting software especiallymiwi2009-11-041-0/+1 * Add nagiosagent to buildmakc2009-09-151-0/+1 * DHCDROP - utility for tracing and neutralizing(blocking) fake DHCPamdmi32009-08-191-0/+1 * NOC Project is an Operation Support System (OSS) for the Telco,bsam2009-08-181-0/+1 * check_ice is a Nagios plugin-in that checks if a stream is up ormiwi2009-07-151-0/+1 * check_nick is a Nagios plugin-in written in python that willmiwi2009-07-151-0/+1 * check_smartmon is a Nagios plug-in written in python that usesmiwi2009-07-151-0/+1 * DEPRECATED= Use net-mgmt/net-snmp port insteadmezz2009-07-141-1/+0 * Add pyang, a freely available RFC 4741 YANG parser and validator.bms2009-07-061-0/+1 * YAF is Yet Another Flowmeter. It processes packet data from pcap(3)miwi2009-07-011-0/+1 * The general idea of these scripts is to check as many things as possible withmiwi2009-06-161-0/+1 * This check plugin is a Perl script which compares your local signature databasemiwi2009-06-141-0/+1 * Remove net-mgmt/nav as it has been marked BROKEN for over 5 months.erwin2009-06-141-1/+0 * Jnettop is a traffic visualiser, which captures traffic going throughwxs2009-06-081-0/+1 * check_puppet - is a very simple Nagios plugin to check Puppet daemonmiwi2009-05-301-0/+1 * NetAms Front - is an alternative to builtin web interface for NeTAMS software.miwi2009-05-111-0/+1 * 2009-04-28 audio/festival+OGI: unmaintained, does not work with current versi...miwi2009-05-051-1/+0 * 2009-04-22 audio/snowstar: tcl8.0 support is going to be droppedmiwi2009-05-021-1/+0 * 2009-03-22 emulators/dlx: unmaintained, does not work with current versions o...miwi2009-03-241-1/+0 * check_multi is kind of a wrapper plugin which takes benefit of thedinoex2009-03-181-0/+1 * This package provides a suite of modules for managing NetApp's NASrafan2009-03-101-0/+1 * 2009-02-09 audio/xmms-imms: does not configure or buildmiwi2009-02-141-1/+0 * 2009-01-19 games/emacs-chess: has been broken for more than 6 monthsmiwi2009-02-041-1/+0 * CoovaChilli is an access controlleramdmi32009-01-201-0/+1 * - rename hobbit-* -> xymon-*dinoex2009-01-121-2/+2 * - Remove net-mgmt/bsnmpd, is part of base since FreeBSD 6.0pav2009-01-111-1/+0 * SBLIM (pronounced "sublime"), the Standards Based Linuxkuriyama2009-01-051-0/+1 * Connect rrdbot to the build (added by koitsu 2 weeks ago)pav2008-11-281-0/+1 * - Add a port for flow-tools fork project which is aimed to bestas2008-11-171-0/+1 * Net::Abuse::Utils provides serveral functions useful for determiningmiwi2008-10-111-0/+1 * - repocopy net-mgmt/nagios -> net-mgmt/nagios2pgollucci2008-09-031-0/+1 * Lanmap sits quietly on a network and builds a picture of what it sees.jadawin2008-08-251-0/+1 * This is a small Nagios plugin. This plugin relies on portauditpgollucci2008-08-231-0/+1 * This is a small Nagios plugin written in PERL and designed to monitorpgollucci2008-08-23