Add support for grabbing focus after a label is edited and the rudimentary basics of the group popup menu

This commit is contained in:
Chris Jones 2009-09-03 00:52:36 +01:00
parent 846e0c0fff
commit 9bac025795
2 changed files with 74 additions and 4 deletions

View File

@ -16,6 +16,7 @@ from config import Config
from cwd import get_default_cwd from cwd import get_default_cwd
from titlebar import Titlebar from titlebar import Titlebar
from searchbar import Searchbar from searchbar import Searchbar
from translation import _
try: try:
import vte import vte
@ -77,6 +78,7 @@ class Terminal(gtk.VBox):
self.titlebar = Titlebar() self.titlebar = Titlebar()
self.titlebar.connect_icon(self.on_group_button_press) self.titlebar.connect_icon(self.on_group_button_press)
self.titlebar.connect('edit-done', self.on_edit_done)
self.connect('title-change', self.titlebar.set_terminal_title) self.connect('title-change', self.titlebar.set_terminal_title)
self.searchbar = Searchbar() self.searchbar = Searchbar()
@ -222,6 +224,56 @@ class Terminal(gtk.VBox):
self.vte.connect_after('realize', self.reconfigure) self.vte.connect_after('realize', self.reconfigure)
self.vte.connect_after('realize', self.spawn_child) self.vte.connect_after('realize', self.spawn_child)
def create_popup_group_menu(self, widget, event = None):
"""Pop up a menu for the group widget"""
if event:
button = event.button
time = event.time
else:
button = 0
time = 0
menu = self.populate_group_menu()
menu.show_all()
menu.popup(None, None, self.position_popup_group_menu, button, time,
widget)
return(True)
def populate_group_menu(self):
"""Fill out a group menu"""
menu = gtk.Menu()
groupitem = None
item = gtk.MenuItem(_('Assign to group...'))
item.connect('activate', self.create_group)
menu.append(item)
#FIXME: Add the rest of the menu
return(menu)
def position_popup_group_menu(self, menu, widget):
"""Calculate the position of the group popup menu"""
screen_w = gtk.gdk.screen_width()
screen_h = gtk.gdk.screen_height()
widget_win = widget.get_window()
widget_x, widget_y = widget_win.get_origin()
widget_w, widget_h = widget_win.get_size()
menu_w, menu_h = menu.size_request()
if widget_y + widget_h + menu_h > screen_h:
menu_y = max(widget_y - menu_h, 0)
else:
menu_y = widget_y + widget_h
return(widget_x, menu_y, 1)
def create_group(self, item):
"""Create a new group"""
pass
def reconfigure(self, widget=None): def reconfigure(self, widget=None):
"""Reconfigure our settings""" """Reconfigure our settings"""
pass pass
@ -230,9 +282,11 @@ class Terminal(gtk.VBox):
"""Return the window title""" """Return the window title"""
return(self.vte.get_window_title() or str(self.command)) return(self.vte.get_window_title() or str(self.command))
def on_group_button_press(self): def on_group_button_press(self, widget, event):
"""Handler for the group button""" """Handler for the group button"""
pass if event.button == 1:
self.create_popup_group_menu(widget, event)
return(False)
def on_keypress(self, vte, event): def on_keypress(self, vte, event):
"""Handler for keyboard events""" """Handler for keyboard events"""
@ -272,6 +326,10 @@ class Terminal(gtk.VBox):
def on_vte_focus_in(self, vte, event): def on_vte_focus_in(self, vte, event):
pass pass
def on_edit_done(self, widget):
"""A child widget is done editing a label, return focus to VTE"""
self.vte.grab_focus()
def on_resize_window(self): def on_resize_window(self):
pass pass

View File

@ -25,6 +25,11 @@ class Titlebar(gtk.EventBox):
groupicon = None groupicon = None
grouplabel = None grouplabel = None
__gsignals__ = {
'clicked': (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE, ()),
'edit-done': (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE, ()),
}
def __init__(self): def __init__(self):
"""Class initialiser""" """Class initialiser"""
gtk.EventBox.__init__(self) gtk.EventBox.__init__(self)
@ -33,6 +38,7 @@ class Titlebar(gtk.EventBox):
self.terminator = Terminator() self.terminator = Terminator()
self.label = EditableLabel() self.label = EditableLabel()
self.label.connect('edit-done', self.on_edit_done)
self.ebox = gtk.EventBox() self.ebox = gtk.EventBox()
self.grouphbox = gtk.HBox() self.grouphbox = gtk.HBox()
self.grouplabel = gtk.Label() self.grouplabel = gtk.Label()
@ -60,9 +66,11 @@ class Titlebar(gtk.EventBox):
self.add(self.hbox) self.add(self.hbox)
self.show_all() self.show_all()
self.connect('button-press-event', self.on_clicked)
def connect_icon(self, func): def connect_icon(self, func):
"""Connect the supplied function to clicking on the group icon""" """Connect the supplied function to clicking on the group icon"""
pass self.ebox.connect('button-release-event', func)
def update(self): def update(self):
"""Update our contents""" """Update our contents"""
@ -97,6 +105,10 @@ class Titlebar(gtk.EventBox):
def on_clicked(self, widget, event): def on_clicked(self, widget, event):
"""Handle a click on the label""" """Handle a click on the label"""
pass self.emit('clicked')
def on_edit_done(self, widget):
"""Re-emit an edit-done signal from an EditableLabel"""
self.emit('edit-done')
gobject.type_register(Titlebar) gobject.type_register(Titlebar)