Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/activities
diff options
context:
space:
mode:
authorMarco Pesenti Gritti <marco@localhost.localdomain>2006-08-08 23:08:19 (GMT)
committer Marco Pesenti Gritti <marco@localhost.localdomain>2006-08-08 23:08:19 (GMT)
commitc6d59fd7b44e65d33cb0a607c1321f1a62405aa2 (patch)
treecd4530dda13a53d66807e527a09c025a46db96b4 /activities
parentf1821704e708e85aeb8dc1132ff96ba6ea235395 (diff)
Improve the activity api
Diffstat (limited to 'activities')
-rw-r--r--activities/browser/BrowserActivity.py47
1 files changed, 18 insertions, 29 deletions
diff --git a/activities/browser/BrowserActivity.py b/activities/browser/BrowserActivity.py
index 255b782..2969112 100644
--- a/activities/browser/BrowserActivity.py
+++ b/activities/browser/BrowserActivity.py
@@ -9,18 +9,10 @@ from sugar.p2p.model.RemoteModel import RemoteModel
from NotificationBar import NotificationBar
from NavigationToolbar import NavigationToolbar
-_SERVICE_URI_TAG = "URI"
-_SERVICE_TITLE_TAG = "Title"
-
class BrowserActivity(Activity):
- SOLO = 1
- FOLLOWING = 2
- LEADING = 3
-
- def __init__(self, service):
- Activity.__init__(self, service)
+ def __init__(self):
+ Activity.__init__(self)
- self._mode = BrowserActivity.SOLO
self._share_service = None
self._model_service = None
self._notif_service = None
@@ -46,16 +38,19 @@ class BrowserActivity(Activity):
self.add(vbox)
vbox.show()
- if service:
- service.connect('service-appeared', self._service_appeared_cb)
+ def join(self, activity_ps):
+ Activity.join(self, activity_ps)
+
+ activity_ps.connect('service-appeared', self._service_appeared_cb)
- services = service.get_services_of_type('_web_olpc._udp')
- if len(services) > 0:
- self._notif_service = services[0]
+ default_type = self.get_default_type()
+ services = activity_ps.get_services_of_type(default_type)
+ if len(services) > 0:
+ self._notif_service = services[0]
- services = service.get_services_of_type(LocalModel.SERVICE_TYPE)
- if len(services) > 0:
- self._model_service = services[0]
+ services = activity_ps.get_services_of_type(LocalModel.SERVICE_TYPE)
+ if len(services) > 0:
+ self._model_service = services[0]
if self._notif_service and self._model_service:
self._listen_to_model()
@@ -64,8 +59,7 @@ class BrowserActivity(Activity):
if service.get_type() == self._default_type:
self._notif_service = service
elif service.get_type() == LocalModel.SERVICE_TYPE:
- if self._mode != BrowserActivity.LEADING:
- self._model_service = service
+ self._model_service = service
if not self._model and self._notif_service and self._model_service:
self._listen_to_model()
@@ -92,14 +86,6 @@ class BrowserActivity(Activity):
self.embed.load_address(address)
self._notif_bar.hide()
- def set_mode(self, mode):
- self._mode = mode
- if mode == BrowserActivity.LEADING:
- self._notif_bar.set_text('Share this page with the group.')
- self._notif_bar.set_action('set_shared_location', 'Share')
- self._notif_bar.set_icon('stock_shared-by-me')
- self._notif_bar.show()
-
def get_embed(self):
return self.embed
@@ -110,7 +96,10 @@ class BrowserActivity(Activity):
self._model.set_value('owner', self._pservice.get_owner().get_name())
self._update_shared_location()
- self.set_mode(BrowserActivity.LEADING)
+ self._notif_bar.set_text('Share this page with the group.')
+ self._notif_bar.set_action('set_shared_location', 'Share')
+ self._notif_bar.set_icon('stock_shared-by-me')
+ self._notif_bar.show()
def __title_cb(self, embed):
self.set_title(embed.get_title())