Make Activity update the presence service activity
name and listen to the name changes in the mesh view.
This commit is contained in:
parent
fbf995e71d
commit
560a914997
@ -26,24 +26,21 @@ from hardware import hardwaremanager
|
||||
from hardware import nmclient
|
||||
|
||||
class ActivityModel:
|
||||
def __init__(self, activity, activity_info):
|
||||
self._activity = activity
|
||||
self._activity_info = activity_info
|
||||
def __init__(self, activity, bundle):
|
||||
self.activity = activity
|
||||
self.bundle = bundle
|
||||
|
||||
def get_id(self):
|
||||
return self._activity.props.id
|
||||
return self.activity.props.id
|
||||
|
||||
def get_icon_name(self):
|
||||
return self._activity_info.icon
|
||||
return self.bundle.icon
|
||||
|
||||
def get_color(self):
|
||||
return XoColor(self._activity.props.color)
|
||||
return XoColor(self.activity.props.color)
|
||||
|
||||
def get_service_name(self):
|
||||
return self._activity_info.service_name
|
||||
|
||||
def get_title(self):
|
||||
return self._activity.props.name
|
||||
return self.bundle.service_name
|
||||
|
||||
class MeshModel(gobject.GObject):
|
||||
__gsignals__ = {
|
||||
@ -203,12 +200,12 @@ class MeshModel(gobject.GObject):
|
||||
|
||||
def _check_activity(self, presence_activity):
|
||||
registry = activity.get_registry()
|
||||
activity_info = registry.get_activity(presence_activity.props.type)
|
||||
if not activity_info:
|
||||
bundle = registry.get_activity(presence_activity.props.type)
|
||||
if not bundle:
|
||||
return
|
||||
if self.has_activity(presence_activity.props.id):
|
||||
return
|
||||
self.add_activity(activity_info, presence_activity)
|
||||
self.add_activity(bundle, presence_activity)
|
||||
|
||||
def has_activity(self, activity_id):
|
||||
return self._activities.has_key(activity_id)
|
||||
@ -219,8 +216,8 @@ class MeshModel(gobject.GObject):
|
||||
else:
|
||||
return None
|
||||
|
||||
def add_activity(self, activity_info, activity):
|
||||
model = ActivityModel(activity, activity_info)
|
||||
def add_activity(self, bundle, activity):
|
||||
model = ActivityModel(activity, bundle)
|
||||
self._activities[model.get_id()] = model
|
||||
self.emit('activity-added', model)
|
||||
|
||||
|
@ -183,11 +183,13 @@ class ActivityView(hippo.CanvasBox):
|
||||
self._icon = CanvasIcon(file_name=model.get_icon_name(),
|
||||
xo_color=model.get_color(), box_width=80)
|
||||
self._icon.connect('activated', self._clicked_cb)
|
||||
self._icon.set_tooltip(self._model.get_title())
|
||||
self._icon.set_tooltip(self._model.activity.props.name)
|
||||
self._layout.add_center(self._icon)
|
||||
|
||||
def _update_name(self):
|
||||
self.palette.set_primary_text(self._model.get_title())
|
||||
self._model.activity.connect('notify::name', self._name_changed_cb)
|
||||
|
||||
def _name_changed_cb(self, activity, pspec):
|
||||
self._icon.set_tooltip(activity.props.name)
|
||||
|
||||
def has_buddy_icon(self, key):
|
||||
return self._icons.has_key(key)
|
||||
|
@ -137,9 +137,16 @@ class ActivityToolbar(gtk.Toolbar):
|
||||
self._update_title_sid = gobject.timeout_add(1000, self._update_title_cb)
|
||||
|
||||
def _update_title_cb(self):
|
||||
self._activity.metadata['title'] = self.title.get_text()
|
||||
title = self.title.get_text()
|
||||
|
||||
self._activity.metadata['title'] = title
|
||||
self._activity.metadata['title_set_by_user'] = '1'
|
||||
self._activity.save()
|
||||
|
||||
shared_activity = self._activity._shared_activity
|
||||
if shared_activity:
|
||||
shared_activity.props.name = title
|
||||
|
||||
self._update_title_sid = None
|
||||
return False
|
||||
|
||||
@ -499,6 +506,9 @@ class Activity(Window, gtk.Container):
|
||||
logging.debug('Share of activity %s failed: %s.' % (self._activity_id, err))
|
||||
return
|
||||
logging.debug('Share of activity %s successful.' % self._activity_id)
|
||||
|
||||
activity.props.name = self._jobject.metadata['title']
|
||||
|
||||
self._shared_activity = activity
|
||||
self.emit('shared')
|
||||
if self._jobject:
|
||||
|
Loading…
Reference in New Issue
Block a user