Combo for shared/private in the activity menu.
This commit is contained in:
parent
02149eba0a
commit
1b292a7514
2
NEWS
2
NEWS
@ -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)
|
||||||
|
@ -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):
|
||||||
|
@ -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)
|
||||||
|
Loading…
Reference in New Issue
Block a user