Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/chat/box.py
diff options
context:
space:
mode:
Diffstat (limited to 'chat/box.py')
-rw-r--r--chat/box.py26
1 files changed, 15 insertions, 11 deletions
diff --git a/chat/box.py b/chat/box.py
index bfc8156..e82e19a 100644
--- a/chat/box.py
+++ b/chat/box.py
@@ -72,23 +72,20 @@ class TextBox(gtk.TextView):
self._mouse_detector.connect('motion-slow', self._mouse_slow_cb)
self.modify_base(gtk.STATE_NORMAL, bg_color.get_gdk_color())
self.connect("event-after", self.event_after)
+ self.connect('button-press-event', self.__button_press_cb)
self.motion_notify_id = self.connect("motion-notify-event", \
self.motion_notify_event)
self.connect("visibility-notify-event", self.visibility_notify_event)
+ def __button_press_cb(self, widget, event):
+ if event.type == gtk.gdk.BUTTON_PRESS and event.button == 3:
+ # To disable the standard textview popup
+ return True
+
# Links can be activated by clicking.
def event_after(self, widget, event):
if event.type != gtk.gdk.BUTTON_RELEASE:
return False
- if event.button == 2:
- # XXX `tag` is not defined
- #palette = tag.get_data('palette')
- #xw, yw = self.get_toplevel().get_pointer()
- #logging.debug('Popop palette by secondary button click')
- #palette.move(event.x, event.y)
- #palette.popup()
- #return False
- pass
x, y = self.window_to_buffer_coords(gtk.TEXT_WINDOW_WIDGET,
int(event.x), int(event.y))
@@ -97,7 +94,14 @@ class TextBox(gtk.TextView):
for tag in iter_tags.get_tags():
url = tag.get_data('url')
if url is not None:
- self._show_via_journal(url)
+ if event.button == 3:
+ palette = tag.get_data('palette')
+ xw, yw = self.get_toplevel().get_pointer()
+ palette.move(int(xw), int(yw))
+ palette.popup()
+ else:
+ self._show_via_journal(url)
+ break
return False
@@ -158,9 +162,9 @@ class TextBox(gtk.TextView):
if hovering_over_link:
if self.palette is not None:
xw, yw = self.get_toplevel().get_pointer()
- logging.debug('move palette to %d %d', xw, yw)
self.palette.move(xw, yw)
self.palette.popup()
+ self._mouse_detector.stop()
else:
if self.palette is not None:
self.palette.popdown()