Basic implementation of the shutdown graphics
This commit is contained in:
		
							parent
							
								
									dda16d83c0
								
							
						
					
					
						commit
						297381cad7
					
				| @ -16,6 +16,8 @@ | ||||
| 
 | ||||
| import os | ||||
| 
 | ||||
| import gobject | ||||
| 
 | ||||
| from sugar.presence import PresenceService | ||||
| from sugar.activity.bundleregistry import BundleRegistry | ||||
| from model.Friends import Friends | ||||
| @ -24,9 +26,22 @@ from model.homemodel import HomeModel | ||||
| from model.Owner import ShellOwner | ||||
| from sugar import env | ||||
| 
 | ||||
| class ShellModel: | ||||
| class ShellModel(gobject.GObject): | ||||
|     STATE_STARTUP = 0 | ||||
|     STATE_RUNNING = 1 | ||||
|     STATE_SHUTDOWN = 2 | ||||
| 
 | ||||
|     __gproperties__ = { | ||||
|         'state'     : (int, None, None, | ||||
|                       0, 2, STATE_RUNNING, | ||||
|                       gobject.PARAM_READWRITE) | ||||
|     } | ||||
| 
 | ||||
|     def __init__(self): | ||||
|         gobject.GObject.__init__(self) | ||||
| 
 | ||||
|         self._current_activity = None | ||||
|         self._state = self.STATE_RUNNING | ||||
| 
 | ||||
|         self._bundle_registry = BundleRegistry() | ||||
| 
 | ||||
| @ -47,6 +62,14 @@ class ShellModel: | ||||
|             bundles_path = os.path.join(path, 'activities') | ||||
|             self._bundle_registry.add_search_path(bundles_path) | ||||
| 
 | ||||
|     def do_set_property(self, pspec, value): | ||||
|         if pspec.name == 'state': | ||||
|             self._state = value | ||||
| 
 | ||||
|     def do_get_property(self, pspec): | ||||
|         if pspec.name == 'state': | ||||
|             return self._state | ||||
| 
 | ||||
|     def get_bundle_registry(self): | ||||
|         return self._bundle_registry | ||||
| 
 | ||||
|  | ||||
| @ -29,9 +29,11 @@ from view.ActivityHost import ActivityHost | ||||
| from sugar.activity import ActivityFactory | ||||
| from sugar.activity import Activity | ||||
| from view.frame.Frame import Frame | ||||
| from model.ShellModel import ShellModel | ||||
| from hardwaremanager import HardwareManager | ||||
| from _sugar import KeyGrabber | ||||
| from _sugar import AudioManager | ||||
| from sugar import env | ||||
| import sugar | ||||
| 
 | ||||
| class Shell(gobject.GObject): | ||||
| @ -107,6 +109,7 @@ class Shell(gobject.GObject): | ||||
|         # For non-OLPC machines | ||||
|         self._key_grabber.grab('<alt>f') | ||||
|         self._key_grabber.grab('<alt>o') | ||||
|         self._key_grabber.grab('<alt><shift>s') | ||||
| 
 | ||||
|     def _key_pressed_cb(self, grabber, key): | ||||
|         if key == 'F1': | ||||
| @ -149,7 +152,7 @@ class Shell(gobject.GObject): | ||||
|             self.toggle_chat_visibility() | ||||
|         elif key == '0x93': # Frame key | ||||
|             self._frame.notify_key_press() | ||||
|         elif key == '0x7C': # Power key | ||||
|         elif key == '0x7C' or key == '<alt><shift>s': # Power key | ||||
|             self._shutdown() | ||||
|         elif key == '0xEC': # Keyboard brightness | ||||
|             self._hw_manager.toggle_keyboard_brightness() | ||||
| @ -166,6 +169,11 @@ class Shell(gobject.GObject): | ||||
|         console.toggle_visibility() | ||||
| 
 | ||||
|     def _shutdown(self): | ||||
|         self._model.props.state = ShellModel.STATE_SHUTDOWN | ||||
|         if not env.is_emulator(): | ||||
|             self._shutdown_system() | ||||
| 
 | ||||
|     def _shutdown_system(self): | ||||
|         bus = dbus.SystemBus() | ||||
|         proxy = bus.get_object('org.freedesktop.Hal', | ||||
|                                '/org/freedesktop/Hal/devices/computer') | ||||
|  | ||||
| @ -18,8 +18,10 @@ import hippo | ||||
| 
 | ||||
| from view.home.activitiesdonut import ActivitiesDonut | ||||
| from view.home.MyIcon import MyIcon | ||||
| from model.ShellModel import ShellModel | ||||
| from sugar.graphics.grid import Grid | ||||
| from sugar.graphics import style | ||||
| from sugar.graphics.iconcolor import IconColor | ||||
| 
 | ||||
| class HomeBox(hippo.CanvasBox, hippo.CanvasItem): | ||||
|     __gtype_name__ = 'SugarHomeBox' | ||||
| @ -36,6 +38,17 @@ class HomeBox(hippo.CanvasBox, hippo.CanvasItem): | ||||
|         style.apply_stylesheet(self._my_icon, 'home.MyIcon') | ||||
|         self.append(self._my_icon, hippo.PACK_FIXED) | ||||
| 
 | ||||
|         shell.get_model().connect('notify::state', | ||||
|                                   self._shell_state_changed_cb) | ||||
| 
 | ||||
|     def _shell_state_changed_cb(self, model, pspec): | ||||
|         # FIXME handle all possible mode switches | ||||
|         if model.props.state == ShellModel.STATE_SHUTDOWN: | ||||
|             if self._donut: | ||||
|                 self.remove(self._donut) | ||||
|                 self._donut = None | ||||
|                 self._my_icon.props.color = IconColor('insensitive') | ||||
| 
 | ||||
|     def do_allocate(self, width, height): | ||||
|         hippo.CanvasBox.do_allocate(self, width, height) | ||||
| 
 | ||||
|  | ||||
| @ -19,6 +19,8 @@ | ||||
| import os | ||||
| import sys | ||||
| 
 | ||||
| os.environ['SUGAR_EMULATOR'] = 'yes' | ||||
| 
 | ||||
| sourcedir = os.path.abspath(os.path.dirname(__file__)) | ||||
| if os.path.isfile(os.path.join(sourcedir, 'sugar/__uninstalled__.py')): | ||||
| 	print 'Running sugar from ' + sourcedir + ' ...' | ||||
|  | ||||
| @ -30,6 +30,12 @@ def get_bundle_path(): | ||||
|     else: | ||||
|         return None | ||||
| 
 | ||||
| def is_emulator(): | ||||
|     if os.environ.has_key('SUGAR_EMULATOR'): | ||||
|         if os.environ['SUGAR_EMULATOR'] == 'yes': | ||||
|             return True | ||||
|     return False | ||||
| 
 | ||||
| def get_bundle_service_name(): | ||||
|     if os.environ.has_key('SUGAR_BUNDLE_SERVICE_NAME'): | ||||
|         return os.environ['SUGAR_BUNDLE_SERVICE_NAME'] | ||||
|  | ||||
| @ -22,6 +22,8 @@ from sugar.graphics.colors import colors | ||||
| def _parse_string(color_string): | ||||
|     if color_string == 'white': | ||||
|         return ['#ffffff', '#414141'] | ||||
|     elif color_string == 'insensitive': | ||||
|         return ['#ffffff', '#e2e2e2'] | ||||
| 
 | ||||
|     splitted = color_string.split(',') | ||||
|     if len(splitted) == 2: | ||||
|  | ||||
| @ -1,6 +1,6 @@ | ||||
| VERSION=0.63 | ||||
| DATE=`date +%Y%m%d` | ||||
| RELEASE=2.7 | ||||
| RELEASE=2.8 | ||||
| TARBALL=sugar-$VERSION-$RELEASE.${DATE}git.tar.bz2 | ||||
| 
 | ||||
| rm sugar-$VERSION.tar.bz2 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Marco Pesenti Gritti
						Marco Pesenti Gritti