Combo for shared/private in the activity menu.

This commit is contained in:
Marco Pesenti Gritti 2007-07-24 11:29:14 +02:00
parent 02149eba0a
commit 1b292a7514
3 changed files with 55 additions and 19 deletions

2
NEWS
View File

@ -1,3 +1,5 @@
* #2014 Use a combobox to represent activity network state. (marco)
Snapshot 4a924a8e5d Snapshot 4a924a8e5d
* #2399 Fix a bug which was preventing Write to start. (tomeu) * #2399 Fix a bug which was preventing Write to start. (tomeu)

View File

@ -36,12 +36,16 @@ from sugar.graphics import units
from sugar.graphics.window import Window from sugar.graphics.window import Window
from sugar.graphics.toolbox import Toolbox from sugar.graphics.toolbox import Toolbox
from sugar.graphics.toolbutton import ToolButton from sugar.graphics.toolbutton import ToolButton
from sugar.graphics.toolcombobox import ToolComboBox
from sugar.datastore import datastore from sugar.datastore import datastore
from sugar import wm from sugar import wm
from sugar import profile from sugar import profile
from sugar import _sugarext from sugar import _sugarext
class ActivityToolbar(gtk.Toolbar): class ActivityToolbar(gtk.Toolbar):
SHARE_PRIVATE = 0
SHARE_NEIGHBORHOOD = 1
def __init__(self, activity): def __init__(self, activity):
gtk.Toolbar.__init__(self) gtk.Toolbar.__init__(self)
@ -64,25 +68,21 @@ class ActivityToolbar(gtk.Toolbar):
self.insert(separator, -1) self.insert(separator, -1)
separator.show() separator.show()
self.share = ToolComboBox(label_text='Share with:')
self.share.combo.connect('changed', self._share_changed_cb)
self.share.combo.append_item(None, _('Private'))
self.share.combo.append_item(None, _('My Neighborhood'))
self._update_share()
self.insert(self.share, -1)
self.share.show()
self.keep = ToolButton('document-save') self.keep = ToolButton('document-save')
self.keep.set_tooltip(_('Keep')) self.keep.set_tooltip(_('Keep'))
self.keep.connect('clicked', self._keep_clicked_cb) self.keep.connect('clicked', self._keep_clicked_cb)
self.insert(self.keep, -1) self.insert(self.keep, -1)
self.keep.show() self.keep.show()
self.share = ToolButton('stock-share-mesh')
self.share.set_tooltip(_('Share'))
self.share.connect('clicked', self._share_clicked_cb)
self.insert(self.share, -1)
if activity.get_shared():
self.share.set_sensitive(False)
self.share.show()
separator = gtk.SeparatorToolItem()
separator.props.draw = False
self.insert(separator, -1)
separator.show()
self.stop = ToolButton('activity-stop') self.stop = ToolButton('activity-stop')
self.stop.set_tooltip(_('Stop')) self.stop.set_tooltip(_('Stop'))
self.stop.connect('clicked', self._stop_clicked_cb) self.stop.connect('clicked', self._stop_clicked_cb)
@ -91,8 +91,17 @@ class ActivityToolbar(gtk.Toolbar):
self._update_title_sid = None self._update_title_sid = None
def _share_clicked_cb(self, button): def _update_share(self):
self._activity.share() if self._activity.get_shared():
self.share.set_sensitive(False)
self.share.combo.set_active(self.SHARE_NEIGHBORHOOD)
else:
self.share.set_sensitive(True)
self.share.combo.set_active(self.SHARE_PRIVATE)
def _share_changed_cb(self, combo):
if self.share.combo.get_active() == self.SHARE_NEIGHBORHOOD:
self._activity.share()
def _keep_clicked_cb(self, button): def _keep_clicked_cb(self, button):
self._activity.save() self._activity.save()
@ -126,7 +135,7 @@ class ActivityToolbar(gtk.Toolbar):
tool_item.show() tool_item.show()
def _activity_shared_cb(self, activity): def _activity_shared_cb(self, activity):
self.share.set_sensitive(False) self._update_share()
class EditToolbar(gtk.Toolbar): class EditToolbar(gtk.Toolbar):
def __init__(self): def __init__(self):

View File

@ -16,20 +16,45 @@
# Boston, MA 02111-1307, USA. # Boston, MA 02111-1307, USA.
import gtk import gtk
import gobject
from sugar.graphics.combobox import ComboBox from sugar.graphics.combobox import ComboBox
from sugar.graphics import units from sugar.graphics import units
from sugar.graphics import style
class ToolComboBox(gtk.ToolItem): class ToolComboBox(gtk.ToolItem):
def __init__(self, combo=None): __gproperties__ = {
gtk.ToolItem.__init__(self) 'label-text' : (str, None, None, None,
gobject.PARAM_WRITABLE),
}
def __init__(self, combo=None, **kwargs):
self.label = None
self._label_text = ''
gobject.GObject.__init__(self, **kwargs)
self.set_border_width(units.microgrid_to_pixels(1)) self.set_border_width(units.microgrid_to_pixels(1))
hbox = gtk.HBox(False, style.DEFAULT_SPACING)
self.label = gtk.Label(self._label_text)
hbox.pack_start(self.label, False)
self.label.show()
if combo: if combo:
self.combo = combo self.combo = combo
else: else:
self.combo = ComboBox() self.combo = ComboBox()
self.add(self.combo)
hbox.pack_start(self.combo)
self.combo.show() self.combo.show()
self.add(hbox)
hbox.show()
def do_set_property(self, pspec, value):
if pspec.name == 'label-text':
self._label_text = value
if self.label:
self.label.set_text(self._label_text)