Infobar split
authorFelix Domke <tmbinc@elitedvb.net>
Tue, 15 Nov 2005 02:08:46 +0000 (02:08 +0000)
committerFelix Domke <tmbinc@elitedvb.net>
Tue, 15 Nov 2005 02:08:46 +0000 (02:08 +0000)
data/keymap.xml
lib/python/Screens/InfoBar.py
lib/python/Screens/InfoBarGenerics.py [new file with mode: 0644]

index 30270c0..8eaa10e 100644 (file)
                <key id="KEY_0" mapto="0" flags="m" />
        </map>
 
-       <map context="InfobarActions">
-               <key id="m" mapto="mainMenu" flags="mr" />
-               <key id="c" mapto="switchChannelDown" flags="mr" />
-<!--           <key id="r" mapto="instantRecord" flags="m" /> -->
-               <key id="r" mapto="showEPGList" flags="m" />
+       <map context="InfobarEPGActions">
                <key id="KEY_INFO" mapto="showEPGList" flags="m" />
-<!--           <key id="KEY_RED" mapto="instantRecord" flags="m" /> -->
-               <key id="1" mapto="zapUp" flags="mr" />
-               <key id="2" mapto="zapDown" flags="mr" />
-               <key id="KEY_M" mapto="mainMenu" flags="mr" />
-               <key id="KEY_C" mapto="switchChannelDown" flags="mr" />
+       </map>
+       
+       <map context="InfoBarInstantRecord">
                <key id="KEY_R" mapto="instantRecord" flags="m" />
+       </map>
+
+       <map context="InfoBarChannelSelection">
                <key id="KEY_LEFT" mapto="zapUp" flags="mr" />
                <key id="KEY_RIGHT" mapto="zapDown" flags="mr" />
                <key id="KEY_UP" mapto="switchChannelUp" flags="mr" />
                <key id="KEY_DOWN" mapto="switchChannelDown" flags="mr" />
+
+               <key id="BTN_0" mapto="zapUp" flags="mr" />
+               <key id="BTN_1" mapto="zapDown" flags="mr" />
+       </map>
+       
+       <map context="InfoBarMenuActions">
                <key id="KEY_MENU" mapto="mainMenu" flags="mr" />
+       </map>
+       
+       <map context="InfobarShowHideActions">
                <key id="KEY_OK" mapto="toggleShow" flags="m" />
                <key id="KEY_EXIT" mapto="hide" flags="m" />
+       </map>
+
+       <map context="InfobarActions">
                <key id="KEY_VIDEO" mapto="showMovies" flags="m" />
                <key id="KEY_AUDIO" mapto="audioSelection" flags="m" />
+       </map>
+
+       <map context="InfobarVolumeActions">
                <key id="KEY_VOLUMEUP" mapto="volumeUp" flags="mr" />
                <key id="KEY_VOLUMEDOWN" mapto="volumeDown" flags="mr" />
                <key id="KEY_MUTE" mapto="volumeMute" flags="mr" />
+       </map>
+       
+       <map context="PowerKeyActions">
                <key id="KEY_POWER" mapto="powerdown" flags="m" />
                <key id="KEY_POWER" mapto="powerup" flags="b" />
+       </map>
+       
+       <map context="NumberZapActions">
                <key id="KEY_1" mapto="1" flags="m" />
                <key id="KEY_2" mapto="2" flags="m" />
                <key id="KEY_3" mapto="3" flags="m" />
                <key id="KEY_8" mapto="8" flags="m" />
                <key id="KEY_9" mapto="9" flags="m" />
                <key id="KEY_0" mapto="0" flags="m" />
+       </map>
+       
 
-               <key id="BTN_0" mapto="zapUp" flags="mr" />
-               <key id="BTN_1" mapto="zapDown" flags="mr" />
-               
+       <map context="InfobarPVRActions">
                <key id="KEY_YELLOW" mapto="pauseService" flags="m" />
                <key id="KEY_GREEN" mapto="unPauseService" flags="m" />
                <key id="KEY_RED" mapto="seekBack" flags="m" />
                <key id="KEY_GREEN" mapto="bouquet:(provider == ARD) &amp;&amp; (type == 1)" flags="m" />
                <key id="KEY_YELLOW" mapto="bouquet:(provider == ZDF) &amp;&amp; (type == 1)" flags="m" />
                <!--<key id="KEY_BLUE" mapto="bouquet:(type == 1) FROM BOUQUET &quot;bouquets.tv&quot; ORDER BY bouquet" flags="m" />-->
-               <key id="KEY_BLUE" mapto="bouquet:(type == 1) FROM BOUQUET &quot;userbouquet.favourites.tv&quot; ORDER BY bouquet" flags="m" />
+               <key id="KEY_BLUE" mapto="showFavourites" flags="m" />
                <key id="KEY_INFO" mapto="showEPGList" flags="m" />
        </map>
+
        <map context="EPGSelectActions">
                <key id="KEY_GREEN" mapto="timerAdd" flags="m" />
        </map>
+
        <map context="EventViewActions">
                <key id="KEY_UP" mapto="pageUp" flags="mr" />
                <key id="KEY_DOWN" mapto="pageDown" flags="mr" />
                <key id="KEY_LEFT" mapto="prevEvent" flags="mr" />
                <key id="KEY_RIGHT" mapto="nextEvent" flags="mr" />
        </map>
+
        <map context="OkCancelActions">
                <key id="\x0a" mapto="ok" flags="m" />
                <key id="\x1b" mapto="cancel" flags="m" />
                <key id="KEY_ENTER" mapto="ok" flags="m" />
                <key id="KEY_ESC" mapto="cancel" flags="m" />
        </map>
+
        <map context="WindowActions">
                
        </map>
index 7e059c5..38bb032 100644 (file)
 from Screen import Screen
-from EpgSelection import EPGSelection
-from ChannelSelection import ChannelSelection
+
 from Components.Clock import Clock
 from Components.ActionMap import ActionMap
-from Components.ActionMap import NumberActionMap
-from Components.Button import Button
-from Components.ServiceName import ServiceName
-from Components.EventInfo import EventInfo
-from Components.ServicePosition import ServicePosition
-from Components.config import configfile
-from Components.Label import Label
-
-from Screens.MessageBox import MessageBox
-from Screens.MovieSelection import MovieSelection
-from Screens.Volume import Volume
-from Screens.Mute import Mute
-from Screens.Standby import Standby
 from Screens.AudioSelection import AudioSelection
 
-from ServiceReference import ServiceReference
+from Screens.InfoBarGenerics import InfoBarVolumeControl, InfoBarShowHide, \
+       InfoBarPowerKey, InfoBarNumberZap, InfoBarChannelSelection, InfoBarMenu, \
+       InfoBarEPG, InfoBarEvent, InfoBarServiceName, InfoBarPVR, InfoBarInstantRecord
 
 from enigma import *
 
 import time
 
-# hack alert!
-from Menu import MainMenu, mdom
-
-class NumberZap(Screen):
-       def quit(self):
-               self.Timer.stop()
-               self.close()
-
-       def keyOK(self):
-               self.Timer.stop()
-               print "do the action here"
-               self.close()
-
-       def keyNumberGlobal(self, number):
-               self.Timer.start(3000)          #reset timer
-               self.field = self.field + str(number)
-               self["number"].setText(self.field)
-               if len(self.field) >= 4:
-                       self.keyOK()
-
-       def __init__(self, session, number):
-               Screen.__init__(self, session)
-               self.field = str(number)
-               
-               self["number"] = Label(self.field)
-
-               self["actions"] = NumberActionMap( [ "SetupActions" ], 
-                       {
-                               "cancel": self.quit,
-                               "ok": self.keyOK,
-                               "1": self.keyNumberGlobal,
-                               "2": self.keyNumberGlobal,
-                               "3": self.keyNumberGlobal,
-                               "4": self.keyNumberGlobal,
-                               "5": self.keyNumberGlobal,
-                               "6": self.keyNumberGlobal,
-                               "7": self.keyNumberGlobal,
-                               "8": self.keyNumberGlobal,
-                               "9": self.keyNumberGlobal,
-                               "0": self.keyNumberGlobal
-                       })
-
-               self.Timer = eTimer()
-               self.Timer.timeout.get().append(self.keyOK)
-               self.Timer.start(3000)
-
-
-class InfoBar(Screen):
-       STATE_HIDDEN = 0
-       STATE_HIDING = 1
-       STATE_SHOWING = 2
-       STATE_SHOWN = 3
-       
+class InfoBar(Screen, InfoBarVolumeControl, InfoBarShowHide, InfoBarPowerKey, \
+       InfoBarNumberZap, InfoBarChannelSelection, InfoBarMenu, InfoBarEPG, \
+       InfoBarEvent, InfoBarServiceName, InfoBarPVR, InfoBarInstantRecord):
        def __init__(self, session):
                Screen.__init__(self, session)
-
-               #instantiate forever
-               self.servicelist = self.session.instantiateDialog(ChannelSelection)
-               
-               self.state = self.STATE_HIDDEN
-               
-               self.volumeDialog = self.session.instantiateDialog(Volume)
-               self.muteDialog = self.session.instantiateDialog(Mute)
-               
-               self.hideTimer = eTimer()
-               self.hideTimer.timeout.get().append(self.doTimerHide)
-               #self.hideTimer.start(1000)
                
-               self.hideVolTimer = eTimer()
-               self.hideVolTimer.timeout.get().append(self.volHide)
-               
-               self.powerKeyTimer = eTimer()
-               self.powerKeyTimer.timeout.get().append(self.powertimer)
+               for x in InfoBarVolumeControl, InfoBarShowHide, InfoBarPowerKey, \
+                       InfoBarNumberZap, InfoBarChannelSelection, InfoBarMenu, InfoBarEPG, \
+                       InfoBarEvent, InfoBarServiceName, InfoBarPVR, InfoBarInstantRecord:
+                       x.__init__(self)
 
-               #self["actions"] = ActionMap( [ "InfobarActions" ], 
-               self["actions"] = NumberActionMap( [ "InfobarActions" ], 
+               self["actions"] = ActionMap( [ "InfobarActions" ], 
                        {
-                               "switchChannelUp": self.switchChannelUp,
-                               "switchChannelDown": self.switchChannelDown,
-                               "mainMenu": self.mainMenu,
-                               "zapUp": self.zapUp,
-                               "zapDown": self.zapDown,
-                               "volumeUp": self.volUp,
-                               "volumeDown": self.volDown,
-                               "volumeMute": self.volMute,
-                               "instantRecord": self.instantRecord,
-                               "hide": self.hide,
-                               "toggleShow": self.toggleShow,
                                "showMovies": self.showMovies,
                                #"quit": self.quit,
-                               "powerdown": self.powerdown,
-                               "powerup": self.powerup,
-                               "1": self.keyNumberGlobal,
-                               "2": self.keyNumberGlobal,
-                               "3": self.keyNumberGlobal,
-                               "4": self.keyNumberGlobal,
-                               "5": self.keyNumberGlobal,
-                               "6": self.keyNumberGlobal,
-                               "7": self.keyNumberGlobal,
-                               "8": self.keyNumberGlobal,
-                               "9": self.keyNumberGlobal,
-                               "0": self.keyNumberGlobal,
-                               "showEPGList": self.showEPGList,
-                               
-                               "pauseService": self.pauseService,
-                               "unPauseService": self.unPauseService,
-                               
-                               "seekFwd": self.seekFwd,
-                               "seekBack": self.seekBack,
-                               
                                "audioSelection": self.audioSelection,
                        })
-#              self["okbutton"] = Button("mainMenu", [self.mainMenu])
-               
+
                self["CurrentTime"] = Clock()
                # ServicePosition(self.session.nav, ServicePosition.TYPE_REMAINING)
                # Clock()
 
-               self["ServiceName"] = ServiceName(self.session.nav)
-               
-               self["Event_Now_StartTime"] = EventInfo(self.session.nav, EventInfo.Now_StartTime)
-               self["Event_Next_StartTime"] = EventInfo(self.session.nav, EventInfo.Next_StartTime)
-                               
-               self["Event_Now"] = EventInfo(self.session.nav, EventInfo.Now)
-               self["Event_Next"] = EventInfo(self.session.nav, EventInfo.Next)
-
-               self["Event_Now_Duration"] = EventInfo(self.session.nav, EventInfo.Now_Duration)
-               self["Event_Next_Duration"] = EventInfo(self.session.nav, EventInfo.Next_Duration)
-               
-               self.recording = None
-               
-               self.pos = 0
-       
-       def mainMenu(self):
-               print "loading mainmenu XML..."
-               menu = mdom.childNodes[0]
-               assert menu.tagName == "menu", "root element in menu must be 'menu'!"
-               self.session.open(MainMenu, menu, menu.childNodes)
-
-       def powertimer(self):   
-               print "PowerOff - Now!"
-               self.quit()
-       
-       def powerdown(self):
-               self.standbyblocked = 0
-               self.powerKeyTimer.start(3000)
-
-       def powerup(self):
-               self.powerKeyTimer.stop()
-               if self.standbyblocked == 0:
-                       self.standbyblocked = 1
-                       self.session.open(Standby, self)
-                       
-
-       def keyNumberGlobal(self, number):
-               print "You pressed number " + str(number)
-               self.session.open(NumberZap, number)
-
-       def switchChannelUp(self):      
-               self.servicelist.moveUp()
-               self.session.execDialog(self.servicelist)
-
-       def switchChannelDown(self):    
-               self.servicelist.moveDown()
-               self.session.execDialog(self.servicelist)
-
-       def hide(self): 
-               self.instance.hide()
-
-       def doTimerHide(self):
-               if self.state == self.STATE_SHOWN:
-                       self.instance.hide()
-                       self.state = self.STATE_HIDDEN
-
-       def toggleShow(self):
-               if self.state == self.STATE_SHOWN:
-                       self.instance.hide()
-                       #pls check animation support, sorry
-#                      self.startHide()
-                       self.state = self.STATE_HIDDEN
-               else:
-                       self.instance.show()
-#                      self.startShow()
-                       self.state = self.STATE_SHOWN
-                       #TODO: make it customizable
-                       self.hideTimer.start(5000)
-
-       def     zapUp(self):
-               self.servicelist.moveUp()
-               self.servicelist.zap()
-
-       def     zapDown(self):
-               self.servicelist.moveDown()
-               self.servicelist.zap()
-
-       def     volUp(self):
-               eDVBVolumecontrol.getInstance().volumeUp()
-               self.volumeDialog.instance.show()
-               self.volumeDialog.setValue(eDVBVolumecontrol.getInstance().getVolume())
-               self.hideVolTimer.start(3000)
-
-       def     volDown(self):
-               eDVBVolumecontrol.getInstance().volumeDown()
-               self.volumeDialog.instance.show()
-               self.volumeDialog.setValue(eDVBVolumecontrol.getInstance().getVolume())
-               self.hideVolTimer.start(3000)
-               
-       def volHide(self):
-               self.volumeDialog.instance.hide()
-
-       def startShow(self):
-               self.instance.m_animation.startMoveAnimation(ePoint(0, 600), ePoint(0, 380), 100)
-               self.state = self.STATE_SHOWN
-       
-       def startHide(self):
-               self.instance.m_animation.startMoveAnimation(ePoint(0, 380), ePoint(0, 600), 100)
-               self.state = self.STATE_HIDDEN
-
-       def     volMute(self):
-               eDVBVolumecontrol.getInstance().volumeToggleMute()
-               self.volumeDialog.setValue(eDVBVolumecontrol.getInstance().getVolume())
-               
-               if (eDVBVolumecontrol.getInstance().isMuted()):
-                       self.muteDialog.instance.show()
-               else:
-                       self.muteDialog.instance.hide()
-
-       def showEPGList(self):
-               ref=self.session.nav.getCurrentlyPlayingServiceReference()
-               ptr=eEPGCache.getInstance()
-               if ptr.startTimeQuery(ref) != -1:
-                       self.session.open(EPGSelection, ref)
-               else:
-                       print 'no epg for service', ref.toString()
-
-       def quit(self):
-               #       self.session.open(Standby, self)
-               configfile.save()
-               quitMainloop(0)
-       
-       def stopCurrentRecording(self): 
-               print "remove entry"
-               self.session.nav.RecordTimer.removeEntry(self.recording)
-               self.recording = None
-       
-       def startInstantRecording(self):
-               serviceref = self.session.nav.getCurrentlyPlayingServiceReference()
-                       
-               # try to get event info
-               epg = None
-               try:
-                       service = self.session.nav.getCurrentService()
-                       info = service.info()
-                       ev = info.getEvent(0)
-                       epg = ev
-               except:
-                       pass
-               
-               # fix me, description. 
-               self.recording = self.session.nav.recordWithTimer(time.time(), time.time() + 3600, serviceref, epg, "instant record")
-
-       def recordQuestionCallback(self, answer):
-               if answer == False:
-                       return
-               
-               if self.recording != None:
-                       self.stopCurrentRecording()
-               else:
-                       self.startInstantRecording()
-
-       def instantRecord(self):
-               if self.recording != None:
-                       self.session.openWithCallback(self.recordQuestionCallback, MessageBox, "Do you want to stop the current\n(instant) recording?")
-               else:
-                       self.session.openWithCallback(self.recordQuestionCallback, MessageBox, "Start recording?")
-
        def showMovies(self):
                self.session.open(MovieSelection)
 
-       def pauseService(self):
-               self.session.nav.pause(1)
-               
-       def unPauseService(self):
-               self.session.nav.pause(0)
-       
-       def doSeek(self, dir, seektime):
-               service = self.session.nav.getCurrentService()
-               if service is None:
-                       return
-               
-               seekable = service.seek()
-               if seekable is None:
-                       return
-               seekable.seekRelative(dir, 90 * seektime)
-
-       def seekFwd(self):
-               self.doSeek(+1, 10000)
-       
-       def seekBack(self):
-               self.doSeek(-1, 10000)
-
        def audioSelection(self):
                service = self.session.nav.getCurrentService()
                audio = service.audioTracks()
diff --git a/lib/python/Screens/InfoBarGenerics.py b/lib/python/Screens/InfoBarGenerics.py
new file mode 100644 (file)
index 0000000..77ca0ef
--- /dev/null
@@ -0,0 +1,368 @@
+from Screen import Screen
+from Components.ActionMap import ActionMap
+from Components.ActionMap import NumberActionMap
+from Components.Label import Label
+from Components.config import configfile
+from ChannelSelection import ChannelSelection
+
+
+from Components.ServiceName import ServiceName
+from Components.EventInfo import EventInfo
+from Components.ServicePosition import ServicePosition
+
+from EpgSelection import EPGSelection
+
+from Screens.MessageBox import MessageBox
+from Screens.MovieSelection import MovieSelection
+from Screens.Volume import Volume
+from Screens.Mute import Mute
+from Screens.Standby import Standby
+
+from enigma import eTimer, eDVBVolumecontrol, quitMainloop
+
+# hack alert!
+from Menu import MainMenu, mdom
+
+class InfoBarVolumeControl:
+       """Volume control, handles volUp, volDown, volMute actions and display 
+       a corresponding dialog"""
+       
+       def __init__(self):
+               self["VolumeActions"] = ActionMap( ["InfobarVolumeActions"] ,
+                       {
+                               "volumeUp": self.volUp,
+                               "volumeDown": self.volDown,
+                               "volumeMute": self.volMute,
+                       })
+
+               self.volumeDialog = self.session.instantiateDialog(Volume)
+               self.muteDialog = self.session.instantiateDialog(Mute)
+
+               self.hideVolTimer = eTimer()
+               self.hideVolTimer.timeout.get().append(self.volHide)
+       
+       def     volUp(self):
+               eDVBVolumecontrol.getInstance().volumeUp()
+               self.volumeDialog.instance.show()
+               self.volumeDialog.setValue(eDVBVolumecontrol.getInstance().getVolume())
+               self.hideVolTimer.start(3000)
+
+       def     volDown(self):
+               eDVBVolumecontrol.getInstance().volumeDown()
+               self.volumeDialog.instance.show()
+               self.volumeDialog.setValue(eDVBVolumecontrol.getInstance().getVolume())
+               self.hideVolTimer.start(3000)
+               
+       def volHide(self):
+               self.volumeDialog.instance.hide()
+
+       def     volMute(self):
+               eDVBVolumecontrol.getInstance().volumeToggleMute()
+               self.volumeDialog.setValue(eDVBVolumecontrol.getInstance().getVolume())
+               
+               if (eDVBVolumecontrol.getInstance().isMuted()):
+                       self.muteDialog.instance.show()
+               else:
+                       self.muteDialog.instance.hide()
+
+class InfoBarShowHide:
+       """ InfoBar show/hide control, accepts toggleShow and hide actions, might start
+       fancy animations. """
+       STATE_HIDDEN = 0
+       STATE_HIDING = 1
+       STATE_SHOWING = 2
+       STATE_SHOWN = 3
+       
+       def __init__(self):
+               self["ShowHideActions"] = ActionMap( ["InfobarShowHideActions"] ,
+                       {
+                               "toggleShow": self.toggleShow,
+                               "hide": self.hide,
+                       })
+
+               self.state = self.STATE_HIDDEN
+               
+               self.hideTimer = eTimer()
+               self.hideTimer.timeout.get().append(self.doTimerHide)
+               #self.hideTimer.start(1000)
+
+       def hide(self): 
+               self.instance.hide()
+
+       def doTimerHide(self):
+               if self.state == self.STATE_SHOWN:
+                       self.instance.hide()
+                       self.state = self.STATE_HIDDEN
+
+       def toggleShow(self):
+               if self.state == self.STATE_SHOWN:
+                       self.instance.hide()
+                       #pls check animation support, sorry
+#                      self.startHide()
+                       self.state = self.STATE_HIDDEN
+               else:
+                       self.instance.show()
+#                      self.startShow()
+                       self.state = self.STATE_SHOWN
+                       #TODO: make it customizable
+                       self.hideTimer.start(5000)
+
+       def startShow(self):
+               self.instance.m_animation.startMoveAnimation(ePoint(0, 600), ePoint(0, 380), 100)
+               self.state = self.STATE_SHOWN
+       
+       def startHide(self):
+               self.instance.m_animation.startMoveAnimation(ePoint(0, 380), ePoint(0, 600), 100)
+               self.state = self.STATE_HIDDEN
+
+class NumberZap(Screen):
+       def quit(self):
+               self.Timer.stop()
+               self.close()
+
+       def keyOK(self):
+               self.Timer.stop()
+               print "do the action here"
+               self.close()
+
+       def keyNumberGlobal(self, number):
+               self.Timer.start(3000)          #reset timer
+               self.field = self.field + str(number)
+               self["number"].setText(self.field)
+               if len(self.field) >= 4:
+                       self.keyOK()
+
+       def __init__(self, number):
+               Screen.__init__(self)
+               self.field = str(number)
+               
+               self["number"] = Label(self.field)
+
+               self["actions"] = NumberActionMap( [ "SetupActions" ], 
+                       {
+                               "cancel": self.quit,
+                               "ok": self.keyOK,
+                               "1": self.keyNumberGlobal,
+                               "2": self.keyNumberGlobal,
+                               "3": self.keyNumberGlobal,
+                               "4": self.keyNumberGlobal,
+                               "5": self.keyNumberGlobal,
+                               "6": self.keyNumberGlobal,
+                               "7": self.keyNumberGlobal,
+                               "8": self.keyNumberGlobal,
+                               "9": self.keyNumberGlobal,
+                               "0": self.keyNumberGlobal
+                       })
+
+               self.Timer = eTimer()
+               self.Timer.timeout.get().append(self.keyOK)
+               self.Timer.start(3000)
+
+class InfoBarPowerKey:
+       """ PowerKey stuff - handles the powerkey press and powerkey release actions"""
+       
+       def __init__(self):
+               self.powerKeyTimer = eTimer()
+               self.powerKeyTimer.timeout.get().append(self.powertimer)
+               self["PowerKeyActions"] = ActionMap( ["PowerKeyActions"],
+                       {
+                               "powerdown": self.powerdown,
+                               "powerup": self.powerup,
+                       })
+
+       def powertimer(self):   
+               print "PowerOff - Now!"
+               self.quit()
+       
+       def powerdown(self):
+               self.standbyblocked = 0
+               self.powerKeyTimer.start(3000)
+
+       def powerup(self):
+               self.powerKeyTimer.stop()
+               if self.standbyblocked == 0:
+                       self.standbyblocked = 1
+                       self.session.open(Standby, self)
+
+       def quit(self):
+               #       self.session.open(Standby, self)
+               configfile.save()
+               quitMainloop(0)
+
+
+class InfoBarNumberZap:
+       """ Handles an initial number for NumberZapping """
+       def __init__(self):
+               self["NumberZapActions"] = NumberActionMap( [ "NumberZapActions"],
+                       {
+                               "1": self.keyNumberGlobal,
+                               "2": self.keyNumberGlobal,
+                               "3": self.keyNumberGlobal,
+                               "4": self.keyNumberGlobal,
+                               "5": self.keyNumberGlobal,
+                               "6": self.keyNumberGlobal,
+                               "7": self.keyNumberGlobal,
+                               "8": self.keyNumberGlobal,
+                               "9": self.keyNumberGlobal,
+                               "0": self.keyNumberGlobal,
+                       })
+
+       def keyNumberGlobal(self, number):
+               print "You pressed number " + str(number)
+               self.session.open(NumberZap, number)
+
+class InfoBarChannelSelection:
+       """ ChannelSelection - handles the channelSelection dialog and the initial 
+       channelChange actions which open the channelSelection dialog """
+       def __init__(self):
+               #instantiate forever
+               self.servicelist = self.session.instantiateDialog(ChannelSelection)
+
+               self["ChannelSelectActions"] = ActionMap( ["InfoBarChannelSelection"],
+                       {
+                               "switchChannelUp": self.switchChannelUp,
+                               "switchChannelDown": self.switchChannelDown,
+                               "zapUp": self.zapUp,
+                               "zapDown": self.zapDown,
+                       })
+                       
+       def switchChannelUp(self):      
+               self.servicelist.moveUp()
+               self.session.execDialog(self.servicelist)
+
+       def switchChannelDown(self):    
+               self.servicelist.moveDown()
+               self.session.execDialog(self.servicelist)
+
+       def     zapUp(self):
+               self.servicelist.moveUp()
+               self.servicelist.zap()
+
+       def     zapDown(self):
+               self.servicelist.moveDown()
+               self.servicelist.zap()
+
+class InfoBarMenu:
+       """ Handles a menu action, to open the (main) menu """
+       def __init__(self):
+               self["MenuActions"] = ActionMap( [ "InfoBarMenuActions" ], 
+                       {
+                               "mainMenu": self.mainMenu,
+                       })
+
+       def mainMenu(self):
+               print "loading mainmenu XML..."
+               menu = mdom.childNodes[0]
+               assert menu.tagName == "menu", "root element in menu must be 'menu'!"
+               self.session.open(MainMenu, menu, menu.childNodes)
+
+class InfoBarEPG:
+       """ EPG - Opens an EPG list when the showEPGList action fires """
+       def __init__(self):
+               self["EPGActions"] = ActionMap( [ "InfobarEPGActions" ], 
+                       {
+                               "showEPGList": self.showEPGList,
+                       })
+
+       def showEPGList(self):
+               ref=self.session.nav.getCurrentlyPlayingServiceReference()
+               ptr=eEPGCache.getInstance()
+               if ptr.startTimeQuery(ref) != -1:
+                       self.session.open(EPGSelection, ref)
+               else:
+                       print 'no epg for service', ref.toString()
+
+class InfoBarEvent:    
+       """provides a current/next event info display"""
+       def __init__(self):
+               self["Event_Now_StartTime"] = EventInfo(self.session.nav, EventInfo.Now_StartTime)
+               self["Event_Next_StartTime"] = EventInfo(self.session.nav, EventInfo.Next_StartTime)
+                               
+               self["Event_Now"] = EventInfo(self.session.nav, EventInfo.Now)
+               self["Event_Next"] = EventInfo(self.session.nav, EventInfo.Next)
+
+               self["Event_Now_Duration"] = EventInfo(self.session.nav, EventInfo.Now_Duration)
+               self["Event_Next_Duration"] = EventInfo(self.session.nav, EventInfo.Next_Duration)
+
+class InfoBarServiceName:
+       def __init__(self):
+               self["ServiceName"] = ServiceName(self.session.nav)
+
+class InfoBarPVR:
+       """handles PVR specific actions like seeking, pause"""
+       def __init__(self):
+               self["PVRActions"] = ActionMap( [ "InfobarPVRActions" ], 
+                       {
+                               "pauseService": self.pauseService,
+                               "unPauseService": self.unPauseService,
+                               
+                               "seekFwd": self.seekFwd,
+                               "seekBack": self.seekBack,
+                       })
+               
+       def pauseService(self):
+               self.session.nav.pause(1)
+               
+       def unPauseService(self):
+               self.session.nav.pause(0)
+       
+       def doSeek(self, dir, seektime):
+               service = self.session.nav.getCurrentService()
+               if service is None:
+                       return
+               
+               seekable = service.seek()
+               if seekable is None:
+                       return
+               seekable.seekRelative(dir, 90 * seektime)
+
+       def seekFwd(self):
+               self.doSeek(+1, 10000)
+       
+       def seekBack(self):
+               self.doSeek(-1, 10000)
+
+class InfoBarInstantRecord:
+       """Instant Record - handles the instantRecord action in order to 
+       start/stop instant records"""
+       def __init__(self):
+               self["InstnantRecordActions"] = ActionMap( [ "InfoBarInstantRecord" ],
+                       {
+                               "instantRecord": self.instantRecord,
+                       })
+               self.recording = None
+
+       def stopCurrentRecording(self): 
+               self.session.nav.RecordTimer.removeEntry(self.recording)
+               self.recording = None
+       
+       def startInstantRecording(self):
+               serviceref = self.session.nav.getCurrentlyPlayingServiceReference()
+                       
+               # try to get event info
+               epg = None
+               try:
+                       service = self.session.nav.getCurrentService()
+                       info = service.info()
+                       ev = info.getEvent(0)
+                       epg = ev
+               except:
+                       pass
+               
+               # fix me, description. 
+               self.recording = self.session.nav.recordWithTimer(time.time(), time.time() + 3600, serviceref, epg, "instant record")
+
+       def recordQuestionCallback(self, answer):
+               if answer == False:
+                       return
+               
+               if self.recording != None:
+                       self.stopCurrentRecording()
+               else:
+                       self.startInstantRecording()
+
+       def instantRecord(self):
+               if self.recording != None:
+                       self.session.openWithCallback(self.recordQuestionCallback, MessageBox, "Do you want to stop the current\n(instant) recording?")
+               else:
+                       self.session.openWithCallback(self.recordQuestionCallback, MessageBox, "Start recording?")