Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTomeu Vizoso <tomeu@tomeuvizoso.net>2008-10-13 16:33:52 (GMT)
committer Tomeu Vizoso <tomeu@tomeuvizoso.net>2008-10-13 16:33:52 (GMT)
commit686f494eed61b35368c03bb86df1b6b74abf35b7 (patch)
tree97b9f2993cdf0c92554ec93342175067bdb4db5e
parent51f0350d078a4d3eac0abffc7160c74f35da55c7 (diff)
Add unmount option and space available to volume palette
-rw-r--r--extensions/deviceicon/volume.py43
-rw-r--r--src/jarabe/model/volume.py9
2 files changed, 46 insertions, 6 deletions
diff --git a/extensions/deviceicon/volume.py b/extensions/deviceicon/volume.py
index d70c937..7ee19f2 100644
--- a/extensions/deviceicon/volume.py
+++ b/extensions/deviceicon/volume.py
@@ -14,12 +14,16 @@
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+import os
+import statvfs
from gettext import gettext as _
import gtk
from sugar.graphics.tray import TrayIcon
from sugar.graphics.palette import Palette
+from sugar.graphics.menuitem import MenuItem
+from sugar.graphics.icon import Icon
from jarabe.model import volume
@@ -39,17 +43,48 @@ class DeviceView(TrayIcon):
class VolumePalette(Palette):
def __init__(self, model):
- Palette.__init__(self, label=model.name)
+ Palette.__init__(self, label=model.name,
+ secondary_text=model.mount_point)
self._model = model
- menu_item = gtk.MenuItem(_('Unmount'))
- menu_item.connect('activate', self._unmount_activated_cb)
+ vbox = gtk.VBox()
+ self.set_content(vbox)
+ vbox.show()
+
+ self._progress_bar = gtk.ProgressBar()
+ vbox.add(self._progress_bar)
+ self._progress_bar.show()
+
+ self._free_space_label = gtk.Label()
+ self._free_space_label.set_alignment(0.5, 0.5)
+ vbox.add(self._free_space_label)
+ self._free_space_label.show()
+
+ self.connect('popup', self.__popup_cb)
+
+ menu_item = MenuItem(_('Unmount'))
+
+ icon = Icon(icon_name='media-eject', icon_size=gtk.ICON_SIZE_MENU)
+ menu_item.set_image(icon)
+ icon.show()
+
+ menu_item.connect('activate', self.__unmount_activate_cb)
self.menu.append(menu_item)
menu_item.show()
- def _unmount_activated_cb(self, menu_item):
+ def __unmount_activate_cb(self, menu_item):
self._model.unmount()
+ def __popup_cb(self, palette):
+ stat = os.statvfs(self._model.mount_point)
+ free_space = stat[statvfs.F_BSIZE] * stat[statvfs.F_BAVAIL]
+ total_space = stat[statvfs.F_BSIZE] * stat[statvfs.F_BLOCKS]
+
+ fraction = (total_space - free_space) / float(total_space)
+ self._progress_bar.props.fraction = fraction
+ self._free_space_label.props.label = _('%(free_space)d MB Free') % \
+ {'free_space': free_space / (1024 * 1024)}
+
def setup(tray):
volumes_manager = volume.get_volumes_manager()
diff --git a/src/jarabe/model/volume.py b/src/jarabe/model/volume.py
index 7ed630f..6afa6a6 100644
--- a/src/jarabe/model/volume.py
+++ b/src/jarabe/model/volume.py
@@ -195,10 +195,14 @@ class VolumesManager(gobject.GObject):
volume_name = device.GetProperty('volume.label')
if not volume_name:
volume_name = device.GetProperty('volume.uuid')
+
+ mount_point = device.GetProperty('volume.mount_point')
+
volume = Volume(volume_name,
self._get_icon_for_volume(device),
profile.get_color(),
- udi)
+ udi,
+ mount_point)
self._volumes[udi] = volume
logging.debug('mounted volume %s' % udi)
@@ -227,11 +231,12 @@ class VolumesManager(gobject.GObject):
return 'media-flash-usb'
class Volume(object):
- def __init__(self, name, icon_name, icon_color, udi):
+ def __init__(self, name, icon_name, icon_color, udi, mount_point):
self.name = name
self.icon_name = icon_name
self.icon_color = icon_color
self.udi = udi
+ self.mount_point = mount_point
def unmount(self):
logging.debug('Volumes.unmount: %r', self.udi)