Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/src/sugar/tutorius/editor.py
diff options
context:
space:
mode:
Diffstat (limited to 'src/sugar/tutorius/editor.py')
-rw-r--r--src/sugar/tutorius/editor.py176
1 files changed, 147 insertions, 29 deletions
diff --git a/src/sugar/tutorius/editor.py b/src/sugar/tutorius/editor.py
index 1a1eb61..bf70216 100644
--- a/src/sugar/tutorius/editor.py
+++ b/src/sugar/tutorius/editor.py
@@ -14,17 +14,22 @@
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+""" Tutorial Editor Module
+"""
import gtk
import gobject
-import hippo
-import gconf
+#import hippo
+#import gconf
from gettext import gettext as _
+from sugar.tutorius.gtkutils import register_signals_numbered, get_children
+
class WidgetIdentifier(gtk.Window):
"""
- Tool that allows identifying widgets
+ Tool that allows identifying widgets.
+
"""
__gtype_name__ = 'TutoriusWidgetIdentifier'
@@ -32,7 +37,19 @@ class WidgetIdentifier(gtk.Window):
gtk.Window.__init__(self)
self._activity = activity
- self._handlers = []
+ self._handlers = {}
+ # dict of signals to register on the widgets.
+ # key : signal name
+ # value : initial checkbox status
+ signals = {
+ "focus":True,
+ "button-press-event":True,
+ "enter-notify-event":False,
+ "leave-notify-event":False,
+ "key-press-event":True,
+ "text-selected":True,
+ "clicked":True,
+ }
self.set_decorated(False)
self.set_resizable(False)
@@ -47,63 +64,164 @@ class WidgetIdentifier(gtk.Window):
self._expander.show()
- vbox = gtk.VBox()
- self._expander.add(vbox)
- vbox.show()
-
+ nbk = gtk.Notebook()
+ self._expander.add(nbk)
+ nbk.show()
+ ###############################
+ # Event log viewer page
+ ###############################
self.logview = gtk.TextView()
self.logview.set_editable(False)
self.logview.set_cursor_visible(False)
self.logview.set_wrap_mode(gtk.WRAP_NONE)
self._textbuffer = self.logview.get_buffer()
- sw = gtk.ScrolledWindow()
- sw.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC)
- sw.add(self.logview)
+ swd = gtk.ScrolledWindow()
+ swd.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC)
+ swd.add(self.logview)
self.logview.show()
- vbox.pack_start(sw)
- sw.show()
-
- from sugar.tutorius.gtkutils import register_signals_numbered
- self._handlers = register_signals_numbered(self._activity, self._handle_events)
+ nbk.append_page(swd, gtk.Label(_("Log")))
+ swd.show()
+
+ ###############################
+ # Filters page
+ ###############################
+ filters = gtk.Table( (len(signals)+1)/2, 2)
+
+ xpos, ypos = 0, 0
+ for key, active in signals.items():
+ cbtn = gtk.CheckButton(label=key)
+ filters.attach(cbtn, xpos, xpos+1, ypos, ypos+1)
+ cbtn.show()
+ cbtn.set_active(active)
+ if active:
+ self._handlers[key] = register_signals_numbered( \
+ self._activity, self._handle_events, events=(key,))
+ else:
+ self._handlers[key] = []
+
+ cbtn.connect("toggled", self.__filter_toggle_cb, key)
+
+ #Follow lines then columns
+ xpos, ypos = (xpos+1)%2, ypos+(xpos%2)
+
+ nbk.append_page(filters, gtk.Label(_("Events")))
+ filters.show()
+
+ ###############################
+ # Explorer Page
+ ###############################
+ tree = gtk.TreeStore(gobject.TYPE_STRING, gobject.TYPE_STRING)
+ explorer = gtk.TreeView(tree)
+
+ pathrendr = gtk.CellRendererText()
+ pathrendr.set_properties(background="#ffffff", foreground="#000000")
+ pathcol = gtk.TreeViewColumn(_("Path"), pathrendr, text=0, background=0, foreground=0)
+ explorer.append_column(pathcol)
+
+ typerendr = gtk.CellRendererText()
+ typerendr.set_properties(background="#ffffff", foreground="#000000")
+ typecol = gtk.TreeViewColumn(_("Widget"), typerendr, text=1, background=1, foreground=1)
+ explorer.append_column(typecol)
+
+ self.__populate_treestore(
+ tree, #tree
+ tree.append(None, ["0",self._activity.get_name()]), #parent
+ self._activity, #widget
+ "0" #path
+ )
- def __expander_cb(self, *args):
+ explorer.set_expander_column(typecol)
+
+ swd2 = gtk.ScrolledWindow()
+ swd2.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC)
+ swd2.add(explorer)
+ explorer.show()
+ nbk.append_page(swd2, gtk.Label(_("Explorer")))
+ swd2.show()
+
+ def __populate_treestore(self, tree, parent, widget, path):
+ """Populates the treestore with the widget's children recursively
+ @param tree gtk.TreeStore to populate
+ @param parent gtk.TreeIter to append to
+ @param widget gtk.Widget to check for children
+ @param path treeish of the widget
+ """
+ #DEBUG: show parameters in log window gehehe
+ #self._handle_events((path,str(type(widget))))
+ children = get_children(widget)
+ for i in xrange(len(children)):
+ childpath = ".".join([path, str(i)])
+ child = children[i]
+ self.__populate_treestore(
+ tree, #tree
+ tree.append(parent, [childpath, child.get_name()]), #parent
+ child, #widget
+ childpath #path
+ )
+
+
+ def __filter_toggle_cb(self, btn, eventname):
+ """Callback for signal name checkbuttons' toggling"""
+ #Disconnect existing handlers on key
+ self.__disconnect_handlers(eventname)
+ if btn.get_active():
+ #if checked, reconnect
+ self._handlers[eventname] = register_signals_numbered( \
+ self._activity, self._handle_events, events=(eventname,))
+
+
+ def __expander_cb(self, *args):
+ """Callback for the window expander toggling"""
if self._expander.get_expanded():
self.__move_expanded()
else:
self.__move_collapsed()
def __move_expanded(self):
- width = 400
+ """Move the window to it's expanded position"""
+ width = 500
height = 300
- ww = gtk.gdk.screen_width()
- wh = gtk.gdk.screen_height()
+ swidth = gtk.gdk.screen_width()
+ sheight = gtk.gdk.screen_height()
self.set_size_request(width, height)
- self.move((ww-width)/2, wh-height)
+ self.move((swidth-width)/2, sheight-height)
def __move_collapsed(self):
+ """Move the window to it's collapsed position"""
width = 150
height = 40
- ww = gtk.gdk.screen_width()
- wh = gtk.gdk.screen_height()
+ swidth = gtk.gdk.screen_width()
+ sheight = gtk.gdk.screen_height()
self.set_size_request(width, height)
- self.move((ww-width)/2, wh-height)
+ self.move((swidth-width)/2, sheight-height)
def __realize_cb(self, widget):
+ """Callback for realize"""
self.window.set_type_hint(gtk.gdk.WINDOW_TYPE_HINT_DIALOG)
self.window.set_accept_focus(True)
self.__move_expanded()
def _disconnect_handlers(self):
- for widget, handlerid in self._handlers:
- widget.handler_disconnect(handlerid)
- self._handlers = []
-
- def _handle_events(self,*args):
+ """ Disconnect all event handlers """
+ for key in self._handlers:
+ self.__disconnect_handlers(key)
+
+ def __disconnect_handlers(self, key):
+ """ Disconnect event handlers associated to signal name "key" """
+ if self._handlers.has_key(key):
+ for widget, handlerid in self._handlers[key]:
+ widget.handler_disconnect(handlerid)
+ del self._handlers[key]
+
+ def _handle_events(self, *args):
+ """ Event handler for subscribed widget events.
+ Accepts variable length argument list. Last must be
+ a two-tuple containing (event name, widget name) """
sig, name = args[-1]
text = "\r\n".join(
(["%s event received from %s" % (sig, name)] +