Merge branch 'master' of git+ssh://dev.laptop.org/git/sugar

This commit is contained in:
Marco Pesenti Gritti 2007-04-30 13:43:05 +02:00
commit afe90d3000
4 changed files with 81 additions and 1 deletions

View File

@ -57,7 +57,7 @@ class Shell(gobject.GObject):
home_model.connect('active-activity-changed', home_model.connect('active-activity-changed',
self._active_activity_changed_cb) self._active_activity_changed_cb)
#self.start_activity('org.laptop.JournalActivity') self.start_activity('org.laptop.JournalActivity')
def _activity_added_cb(self, home_model, home_activity): def _activity_added_cb(self, home_model, home_activity):
activity_host = ActivityHost(home_activity) activity_host = ActivityHost(home_activity)

View File

@ -5,6 +5,7 @@ sugar_PYTHON = \
iconbutton.py \ iconbutton.py \
canvasicon.py \ canvasicon.py \
color.py \ color.py \
combobox.py \
font.py \ font.py \
frame.py \ frame.py \
menu.py \ menu.py \

View File

@ -0,0 +1,76 @@
# Copyright (C) 2007, One Laptop Per Child
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# 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
import sys
import gobject
import gtk
class ComboBox(gtk.ComboBox):
__gtype_name__ = 'SugarComboBox'
__gproperties__ = {
'value' : (int, None, None,
0, sys.maxint, 0,
gobject.PARAM_READABLE)
}
def __init__(self):
gtk.ComboBox.__init__(self)
self._model = gtk.ListStore(gobject.TYPE_INT,
gobject.TYPE_STRING,
gobject.TYPE_STRING,
gobject.TYPE_BOOLEAN)
self.set_model(self._model)
renderer = gtk.CellRendererPixbuf()
self.pack_start(renderer, False)
self.add_attribute(renderer, 'icon-name', 2)
renderer = gtk.CellRendererText()
self.pack_start(renderer, True)
self.add_attribute(renderer, 'text', 1)
self.set_row_separator_func(self._is_separator)
self.connect('realize', self._realize_cb)
def do_get_property(self, pspec):
if pspec.name == 'value':
action_id, text, icon_name, is_separator = self.get_active_item()
return action_id
else:
return gtk.ComboBox.do_get_property(self, pspec)
def _realize_cb(self, widget, data=None):
if self.get_active() == -1:
self.set_active(0)
def append_item(self, action_id, text, icon_name=None):
self._model.append([action_id, text, icon_name, False])
def append_separator(self):
self._model.append([0, None, None, True])
def get_active_item(self):
index = self.get_active()
if index == -1:
index = 0
row = self._model.iter_nth_child(None, index)
return self._model[row]
def _is_separator(self, model, row):
action_id, text, icon_name, is_separator = model[row]
return is_separator

View File

@ -33,3 +33,6 @@ class Toolbox(gtk.VBox):
def add_toolbar(self, name, toolbar): def add_toolbar(self, name, toolbar):
self._notebook.append_page(toolbar, gtk.Label(name)) self._notebook.append_page(toolbar, gtk.Label(name))
def remove_toolbar(self, index):
self._notebook.remove_page(index)