save "last" service
[enigma2.git] / lib / python / Screens / ChannelSelection.py
index 496131bdcb94c4c17044aabef8140aa76e0d3322..2631827f0d87edf267fe6ee176c4e14926517475 100644 (file)
@@ -4,6 +4,7 @@ from Components.ServiceList import ServiceList
 from Components.ActionMap import ActionMap
 from EpgSelection import EPGSelection
 from enigma import eServiceReference, eEPGCache, eEPGCachePtr, eServiceCenter, eServiceCenterPtr, iMutableServiceListPtr
+from Components.config import config
 
 from Screens.FixedMenu import FixedMenu
 
@@ -13,8 +14,8 @@ class ChannelContextMenu(FixedMenu):
        def __init__(self, session, csel):
                self.csel = csel
                
-               menu = [("back", self.close)]
-
+               menu = [ ]
+               
                if csel.mutableList is not None:
                        if not csel.bouquet_mark_edit:
                                if csel.movemode:
@@ -31,6 +32,9 @@ class ChannelContextMenu(FixedMenu):
 
                        if not csel.bouquet_mark_edit and not csel.movemode:
                                menu.append(("remove service", self.removeCurrentService))
+                       menu.append(("back", self.close))
+               else:
+                       menu.append(("back", self.close))
 
                FixedMenu.__init__(self, session, "Channel Selection", menu)
                self.skinName = "Menu"
@@ -80,6 +84,8 @@ class ChannelSelection(Screen):
                        def action(self, contexts, action):
                                if action[:7] == "bouquet":
                                        l = self.csel
+                                       list = l["list"]
+                                       list.setMode(list.MODE_NORMAL)
                                        l.setRoot(eServiceReference("1:7:1:0:0:0:0:0:0:0:" + action[8:]))
                                else:
                                        if action == "cancel":
@@ -97,7 +103,8 @@ class ChannelSelection(Screen):
                                "ok": self.channelSelected,
                                "mark": self.doMark,
                                "contextMenu": self.doContext,
-                           "showEPGList": self.showEPGList
+                               "showFavourites": self.showFavourites,
+                   "showEPGList": self.showEPGList
                        })
                self["actions"].csel = self
 
@@ -126,10 +133,8 @@ class ChannelSelection(Screen):
                ref=l.getCurrent()
                if ref.valid() and self.mutableList is not None:
                        self.mutableList.removeService(ref)
-                       pos = l.cursorGet()
                        self.mutableList.flushChanges() #FIXME dont flush on each single removed service
                        self.setRoot(l.getRoot())
-#                      l.cursorSet(pos) #whats going wrong here????
 
        def endMarkedEdit(self, abort):
                l = self["list"]
@@ -147,7 +152,8 @@ class ChannelSelection(Screen):
                                self.mutableList.addService(eServiceReference(x))
                        if changed:
                                self.mutableList.flushChanges()
-                               self.setRoot(self.bouquetRoot)
+                               #self.setRoot(self.bouquetRoot)
+                               self.showFavourites()
                self.__marked = []
                self.clearMarks()
                self.bouquet_mark_edit = False
@@ -191,11 +197,13 @@ class ChannelSelection(Screen):
                        self.doMark()
                else:
                        self.session.nav.playService(ref)
+                       self.saveChannel()
                        self.close()
 
        #called from infoBar
        def zap(self):
                self.session.nav.playService(self["list"].getCurrent())
+               self.saveChannel()
 
        def moveUp(self):
                self["list"].moveUp()
@@ -208,7 +216,23 @@ class ChannelSelection(Screen):
 
        def toggleMoveMode(self):
                if self.movemode:
+                       if self.entry_marked:
+                               self.channelSelected() # unmark current entry
                        self.movemode = False
                        self.mutableList.flushChanges() # FIXME add check if changes was made
                else:
                        self.movemode = True
+
+       def showFavourites(self):
+               self.setRoot(eServiceReference('1:7:1:0:0:0:0:0:0:0:(type == 1) FROM BOUQUET "userbouquet.favourites.tv" ORDER BY bouquet'))
+               list = self["list"]
+               list.setMode(list.MODE_FAVOURITES)
+
+       def saveChannel(self):
+               ref = self.session.nav.getCurrentlyPlayingServiceReference()
+               if ref is not None:
+                       refstr = ref.toString()
+               else:
+                       refstr = ""
+               config.tv.lastservice.value = refstr
+               config.tv.lastservice.save()