increase granularity of mesh device control
This commit is contained in:
@@ -15,18 +15,28 @@
|
||||
# along with this program; if not, write to the Free Software
|
||||
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
|
||||
from gettext import gettext as _
|
||||
|
||||
import gtk
|
||||
|
||||
from sugar import profile
|
||||
from sugar.graphics.icon import CanvasIcon
|
||||
from sugar.graphics import style
|
||||
from model.devices import device
|
||||
|
||||
from sugar.graphics.palette import Palette
|
||||
from model.devices.network import wireless
|
||||
|
||||
class DeviceView(CanvasIcon):
|
||||
def __init__(self, model):
|
||||
CanvasIcon.__init__(self, size=style.MEDIUM_ICON_SIZE,
|
||||
icon_name='network-mesh')
|
||||
self._model = model
|
||||
self._palette = MeshPalette(_("Mesh Network"), model)
|
||||
self.set_palette(self._palette)
|
||||
|
||||
model.connect('notify::state', self._state_changed_cb)
|
||||
model.connect('notify::activation-stage', self._state_changed_cb)
|
||||
self._update_state()
|
||||
|
||||
def _state_changed_cb(self, model, pspec):
|
||||
@@ -35,6 +45,8 @@ class DeviceView(CanvasIcon):
|
||||
def _update_state(self):
|
||||
# FIXME Change icon colors once we have real icons
|
||||
state = self._model.props.state
|
||||
self._palette.update_state(state)
|
||||
|
||||
if state == device.STATE_ACTIVATING:
|
||||
self.props.fill_color = style.COLOR_INACTIVE_FILL.get_svg()
|
||||
self.props.stroke_color = style.COLOR_INACTIVE_STROKE.get_svg()
|
||||
@@ -43,3 +55,69 @@ class DeviceView(CanvasIcon):
|
||||
elif state == device.STATE_INACTIVE:
|
||||
self.props.fill_color = style.COLOR_INACTIVE_FILL.get_svg()
|
||||
self.props.stroke_color = style.COLOR_INACTIVE_STROKE.get_svg()
|
||||
|
||||
if state == device.STATE_INACTIVE:
|
||||
self._palette.set_primary_text(_("Mesh Network"))
|
||||
else:
|
||||
chan = wireless.freq_to_channel(self._model.props.frequency)
|
||||
if chan > 0:
|
||||
self._palette.set_primary_text(_("Mesh Network") + " %d" % chan)
|
||||
self._palette.set_mesh_step(self._model.props.mesh_step, state)
|
||||
|
||||
class MeshPalette(Palette):
|
||||
def __init__(self, primary_text, model):
|
||||
Palette.__init__(self, primary_text, menu_after_content=True)
|
||||
self._model = model
|
||||
|
||||
self._step_label = gtk.Label()
|
||||
self._step_label.show()
|
||||
|
||||
vbox = gtk.VBox()
|
||||
vbox.pack_start(self._step_label)
|
||||
vbox.show()
|
||||
|
||||
self.set_content(vbox)
|
||||
|
||||
self._disconnect_item = gtk.MenuItem(_('Disconnect...'))
|
||||
self._disconnect_item.connect('activate', self._disconnect_activate_cb)
|
||||
self.menu.append(self._disconnect_item)
|
||||
|
||||
def update_state(self, state):
|
||||
if state == device.STATE_ACTIVATED:
|
||||
self._disconnect_item.show()
|
||||
else:
|
||||
self._disconnect_item.hide()
|
||||
|
||||
def _disconnect_activate_cb(self, menuitem):
|
||||
# Disconnection for an mesh means activating the default mesh device
|
||||
# again without a channel
|
||||
network_manager = hardwaremanager.get_network_manager()
|
||||
nm_device = self._model.get_nm_device()
|
||||
if network_manager and nm_device:
|
||||
network_manager.set_active_device(nm_device)
|
||||
|
||||
def set_mesh_step(self, step, state):
|
||||
label = ""
|
||||
if step == 1:
|
||||
if state == device.STATE_ACTIVATED:
|
||||
label = _("Connected to a School Mesh Portal")
|
||||
elif state == device.STATE_ACTIVATING:
|
||||
label = _("Looking for a School Mesh Portal...")
|
||||
elif step == 3:
|
||||
if state == device.STATE_ACTIVATED:
|
||||
label = _("Connected to an XO Mesh Portal")
|
||||
elif state == device.STATE_ACTIVATING:
|
||||
label = _("Looking for an XO Mesh Portal...")
|
||||
elif step == 4:
|
||||
if state == device.STATE_ACTIVATED:
|
||||
label = _("Connected to a Simple Mesh")
|
||||
elif state == device.STATE_ACTIVATING:
|
||||
label = _("Starting a Simple Mesh")
|
||||
|
||||
if len(label):
|
||||
self._step_label.set_text(label)
|
||||
else:
|
||||
import logging
|
||||
logging.debug("Unhandled mesh step %d" % step)
|
||||
self._step_label.set_text(_("Unknown Mesh"))
|
||||
|
||||
|
||||
@@ -27,13 +27,24 @@ from sugar.graphics.palette import Palette
|
||||
from model.devices.network import wireless
|
||||
from model.devices import device
|
||||
|
||||
from hardware import hardwaremanager
|
||||
from hardware import nmclient
|
||||
|
||||
_ICON_NAME = 'network-wireless'
|
||||
|
||||
class DeviceView(CanvasIcon):
|
||||
def __init__(self, model):
|
||||
CanvasIcon.__init__(self, size=style.MEDIUM_ICON_SIZE)
|
||||
self._model = model
|
||||
self._palette = WirelessPalette(self._get_palette_primary_text())
|
||||
|
||||
meshdev = None
|
||||
network_manager = hardwaremanager.get_network_manager()
|
||||
for device in network_manager.get_devices():
|
||||
if device.get_type() == nmclient.DEVICE_TYPE_802_11_MESH_OLPC:
|
||||
meshdev = device
|
||||
break
|
||||
|
||||
self._palette = WirelessPalette(self._get_palette_primary_text(), meshdev)
|
||||
self.set_palette(self._palette)
|
||||
self._counter = 0
|
||||
self._palette.set_frequency(self._model.props.frequency)
|
||||
@@ -87,8 +98,9 @@ class DeviceView(CanvasIcon):
|
||||
self.props.stroke_color = style.COLOR_INACTIVE_STROKE.get_svg()
|
||||
|
||||
class WirelessPalette(Palette):
|
||||
def __init__(self, primary_text):
|
||||
Palette.__init__(self, primary_text)
|
||||
def __init__(self, primary_text, meshdev):
|
||||
Palette.__init__(self, primary_text, menu_after_content=True)
|
||||
self._meshdev = meshdev
|
||||
|
||||
self._chan_label = gtk.Label()
|
||||
self._chan_label.show()
|
||||
@@ -97,16 +109,23 @@ class WirelessPalette(Palette):
|
||||
vbox.pack_start(self._chan_label)
|
||||
vbox.show()
|
||||
|
||||
if meshdev:
|
||||
disconnect_item = gtk.MenuItem(_('Disconnect...'))
|
||||
disconnect_item.connect('activate', self._disconnect_activate_cb)
|
||||
self.menu.append(disconnect_item)
|
||||
disconnect_item.show()
|
||||
|
||||
self.set_content(vbox)
|
||||
|
||||
def _disconnect_activate_cb(self, menuitem):
|
||||
# Disconnection for an AP means activating the default mesh device
|
||||
network_manager = hardwaremanager.get_network_manager()
|
||||
if network_manager and self._meshdev:
|
||||
network_manager.set_active_device(self._meshdev)
|
||||
|
||||
def set_frequency(self, freq):
|
||||
chans = { 2.412: 1, 2.417: 2, 2.422: 3, 2.427: 4,
|
||||
2.432: 5, 2.437: 6, 2.442: 7, 2.447: 8,
|
||||
2.452: 9, 2.457: 10, 2.462: 11, 2.467: 12,
|
||||
2.472: 13
|
||||
}
|
||||
try:
|
||||
chan = chans[freq]
|
||||
chan = wireless.freq_to_channel(freq)
|
||||
except KeyError:
|
||||
chan = 0
|
||||
self._chan_label.set_text("%s: %d" % (_("Channel"), chan))
|
||||
|
||||
Reference in New Issue
Block a user