Forgot to add the model
This commit is contained in:
parent
645aa93e50
commit
14383f4fc7
86
shell/ShellModel.py
Normal file
86
shell/ShellModel.py
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
import gobject
|
||||||
|
|
||||||
|
from Owner import ShellOwner
|
||||||
|
from sugar.presence import PresenceService
|
||||||
|
from sugar.activity import ActivityFactory
|
||||||
|
from sugar.activity import Activity
|
||||||
|
from Friends import Friends
|
||||||
|
from Invites import Invites
|
||||||
|
|
||||||
|
class ShellModel(gobject.GObject):
|
||||||
|
__gsignals__ = {
|
||||||
|
'activity-opened': (gobject.SIGNAL_RUN_FIRST,
|
||||||
|
gobject.TYPE_NONE, ([gobject.TYPE_PYOBJECT])),
|
||||||
|
'activity-changed': (gobject.SIGNAL_RUN_FIRST,
|
||||||
|
gobject.TYPE_NONE, ([gobject.TYPE_PYOBJECT])),
|
||||||
|
'activity-closed': (gobject.SIGNAL_RUN_FIRST,
|
||||||
|
gobject.TYPE_NONE, ([gobject.TYPE_PYOBJECT]))
|
||||||
|
}
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
gobject.GObject.__init__(self)
|
||||||
|
|
||||||
|
self._hosts = {}
|
||||||
|
self._current_activity = None
|
||||||
|
|
||||||
|
PresenceService.start()
|
||||||
|
self._pservice = PresenceService.get_instance()
|
||||||
|
|
||||||
|
self._owner = ShellOwner()
|
||||||
|
self._owner.announce()
|
||||||
|
self._friends = Friends()
|
||||||
|
self._invites = Invites()
|
||||||
|
|
||||||
|
def get_friends(self):
|
||||||
|
return self._friends
|
||||||
|
|
||||||
|
def get_invites(self):
|
||||||
|
return self._invites
|
||||||
|
|
||||||
|
def get_owner(self):
|
||||||
|
return self._owner
|
||||||
|
|
||||||
|
def add_activity(self, activity_host):
|
||||||
|
self._hosts[activity_host.get_xid()] = activity_host
|
||||||
|
self.emit('activity-opened', activity_host)
|
||||||
|
|
||||||
|
def set_current_activity(self, activity_xid):
|
||||||
|
activity_host = self._hosts[activity_xid]
|
||||||
|
if self._current_activity == activity_host:
|
||||||
|
return
|
||||||
|
|
||||||
|
self._current_activity = activity_host
|
||||||
|
self.emit('activity-changed', activity_host)
|
||||||
|
|
||||||
|
def remove_activity(self, activity_xid):
|
||||||
|
if self._hosts.has_key(activity_xid):
|
||||||
|
host = self._hosts[activity_xid]
|
||||||
|
self.emit('activity-closed', host)
|
||||||
|
del self._hosts[activity_xid]
|
||||||
|
|
||||||
|
def get_activity(self, activity_id):
|
||||||
|
for host in self._hosts.values():
|
||||||
|
if host.get_id() == activity_id:
|
||||||
|
return host
|
||||||
|
return None
|
||||||
|
|
||||||
|
def get_current_activity(self):
|
||||||
|
return self._current_activity
|
||||||
|
|
||||||
|
def join_activity(self, bundle_id, activity_id):
|
||||||
|
activity = self.get_activity(activity_id)
|
||||||
|
if activity:
|
||||||
|
activity.present()
|
||||||
|
else:
|
||||||
|
activity_ps = self._pservice.get_activity(activity_id)
|
||||||
|
|
||||||
|
if activity_ps:
|
||||||
|
activity = ActivityFactory.create(bundle_id)
|
||||||
|
activity.join(activity_ps.object_path())
|
||||||
|
else:
|
||||||
|
logging.error('Cannot start activity.')
|
||||||
|
|
||||||
|
def start_activity(self, activity_type):
|
||||||
|
activity = ActivityFactory.create(activity_type)
|
||||||
|
activity.execute('test', [])
|
||||||
|
return activity
|
Loading…
Reference in New Issue
Block a user