fix inverted setting (meaning was inverted too)
[enigma2.git] / lib / python / Components / ServiceList.py
index 93c79296203134cfea0b69c17fe971e8930e407a..2cef35c16c3d1256f956fc1723240d81bc42553d 100644 (file)
@@ -3,50 +3,105 @@ from GUIComponent import *
 
 from enigma import *
 
+from string import upper
+
 class ServiceList(HTMLComponent, GUIComponent):
 
        MODE_NORMAL = 0
        MODE_FAVOURITES = 1
-       
+
        def __init__(self):
                GUIComponent.__init__(self)
                self.l = eListboxServiceContent()
+               self.root = None
                
+               self.mode = self.MODE_NORMAL
+
+       def setCurrent(self, ref):
+               self.l.setCurrent(ref)
+
        def getCurrent(self):
                r = eServiceReference()
                self.l.getCurrent(r)
                return r
-               
+
        def moveUp(self):
                self.instance.moveSelection(self.instance.moveUp)
 
        def moveDown(self):
                self.instance.moveSelection(self.instance.moveDown)
+               
+       def moveToChar(self, char):
+               # TODO fill with life
+               print "Next char: "
+               index = self.l.getNextBeginningWithChar(char)
+               indexup = self.l.getNextBeginningWithChar(upper(char))
+               if indexup != 0:
+                       if (index > indexup or index == 0):
+                               index = indexup
+
+               self.instance.moveSelectionTo(index)
+               print "Moving to character " + str(char)
+
+       def moveToIndex(self, index):
+               self.instance.moveSelectionTo(index)
+
+       def getCurrentIndex(self):
+               return self.instance.getCurrentIndex()
 
        def GUIcreate(self, parent):
                self.instance = eListbox(parent)
                self.instance.setContent(self.l)
+               self.setMode(self.mode)
        
        def GUIdelete(self):
                self.instance = None
 
-       def setRoot(self, root):
-               self.l.setRoot(root)
+       def getRoot(self):
+               return self.root
+
+       def getRootServices(self):
+               serviceHandler = eServiceCenter.getInstance()
+               list = serviceHandler.list(self.root)
+               dest = [ ]
+               if list is not None:
+                       while 1:
+                               s = list.getNext()
+                               if s.valid():
+                                       dest.append(s.toString())
+                               else:
+                                       break
+               return dest
+
+       def setNumberOffset(self, offset):
+               self.l.setNumberOffset(offset)
+
+       def setPlayableIgnoreService(self, ref):
+               self.l.setIgnoreService(ref)
+
+       def setRoot(self, root, justSet=False):
+               self.root = root
+               self.l.setRoot(root, justSet)
+               if not justSet:
+                       self.l.sort()
+
+       def addService(self, service):
+               self.l.addService(service)
+
+       def finishFill(self):
+               self.l.FillFinished()
                self.l.sort()
-               
-               # mark stuff
-       def clearMarked(self):
-               self.l.clearMarked()
-               
+
+# stuff for multiple marks (edit mode / later multiepg)
        def clearMarks(self):
                self.l.initMarked()
-       
+
        def isMarked(self, ref):
                return self.l.isMarked(ref)
 
        def addMarked(self, ref):
                self.l.addMarked(ref)
-       
+
        def removeMarked(self, ref):
                self.l.removeMarked(ref)
 
@@ -56,20 +111,32 @@ class ServiceList(HTMLComponent, GUIComponent):
                ref = eServiceReference()
                marked = [ ]
                while i.markedQueryNext(ref) == 0:
-                       marked.append(ref)
+                       marked.append(ref.toString())
                        ref = eServiceReference()
-
                return marked
 
+#just for movemode.. only one marked entry..
+       def setCurrentMarked(self, state):
+               self.l.setCurrentMarked(state)
+
        def setMode(self, mode):
+               self.mode = mode
+
+               try:
+                       self.instance
+               except:
+                       return
+               
                if mode == self.MODE_NORMAL:
-                       self.instance.setItemHeight(20)
+                       self.instance.setItemHeight(28)
                        self.l.setVisualMode(eListboxServiceContent.visModeSimple)
+                       self.l.setElementFont(self.l.celServiceName, gFont("Regular", 22))
+                       self.l.setElementPosition(self.l.celServiceName, eRect(0, 0, self.instance.size().width(), 28))
                else:
-                       self.instance.setItemHeight(40)
-                       self.l.setElementFont(self.l.celServiceName, gFont("Arial", 30))
-                       self.l.setElementPosition(self.l.celServiceName, eRect(40, 0, self.instance.size().width(), 40))
-                       self.l.setElementFont(self.l.celServiceNumber, gFont("Arial", 20))
-                       self.l.setElementPosition(self.l.celServiceNumber, eRect(0, 10, 40, 30))
-
+                       self.instance.setItemHeight(28)
+                       self.l.setElementFont(self.l.celServiceNumber, gFont("Regular", 20))
+                       self.l.setElementPosition(self.l.celServiceNumber, eRect(0, 0, 40, 28))
+                       self.l.setElementFont(self.l.celServiceName, gFont("Regular", 22))
+                       self.l.setElementPosition(self.l.celServiceName, eRect(50, 0, self.instance.size().width()-50, 28))
+                       self.l.setElementFont(self.l.celServiceInfo, gFont("Regular", 18))
                        self.l.setVisualMode(eListboxServiceContent.visModeComplex)