X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/2601ee77efe1f10be7cbeb8af94e2fb229cc1ec1..43b204fbde9c5b36848320079eb7e9576536ddc3:/lib/python/Components/MovieList.py diff --git a/lib/python/Components/MovieList.py b/lib/python/Components/MovieList.py index 2e010ab6..25c32b66 100644 --- a/lib/python/Components/MovieList.py +++ b/lib/python/Components/MovieList.py @@ -1,6 +1,7 @@ from HTMLComponent import * from GUIComponent import * from Tools.FuzzyDate import FuzzyTime +from ServiceReference import ServiceReference from enigma import eListboxPythonMultiContent, eListbox, gFont, iServiceInformation @@ -24,8 +25,6 @@ RT_WRAP = 32 # | name of movie | # def MovieListEntry(serviceref, serviceHandler): - res = [ serviceref ] - info = serviceHandler.info(serviceref) if info is None: @@ -38,19 +37,21 @@ def MovieListEntry(serviceref, serviceHandler): else: len = "?:??" - res.append((0, 0, 400, 30, 0, RT_HALIGN_LEFT, info.getName(serviceref))) - - description = info.getInfoString(serviceref, iServiceInformation.sDescription) begin = info.getInfo(serviceref, iServiceInformation.sTimeCreate) + res = [ (serviceref, begin) ] + + res.append((0, 0, 0, 560, 30, 0, RT_HALIGN_LEFT, info.getName(serviceref))) + description = info.getInfoString(serviceref, iServiceInformation.sDescription) + begin_string = "" if begin > 0: t = FuzzyTime(begin) begin_string = t[0] + ", " + t[1] - res.append((0, 30, 200, 20, 1, RT_HALIGN_LEFT, description)) - res.append((0, 50, 200, 20, 1, RT_HALIGN_LEFT, begin_string)) - res.append((200, 50, 200, 20, 1, RT_HALIGN_RIGHT, len)) + res.append((eListboxPythonMultiContent.TYPE_TEXT, 0, 30, 560, 20, 1, RT_HALIGN_LEFT, description)) + res.append((eListboxPythonMultiContent.TYPE_TEXT, 0, 50, 270, 20, 1, RT_HALIGN_LEFT, begin_string)) + res.append((eListboxPythonMultiContent.TYPE_TEXT, 290, 50, 270, 20, 1, RT_HALIGN_RIGHT, len)) return res @@ -58,13 +59,19 @@ class MovieList(HTMLComponent, GUIComponent): def __init__(self, root): GUIComponent.__init__(self) self.l = eListboxPythonMultiContent() - self.load(root) - self.l.setList(self.list) - self.l.setFont(0, gFont("Arial", 30)) - self.l.setFont(1, gFont("Arial", 18)) - + if root is not None: + self.reload(root) + self.l.setFont(0, gFont("Regular", 30)) + self.l.setFont(1, gFont("Regular", 18)) + + def moveToIndex(self, index): + self.instance.moveSelectionTo(index) + + def getCurrentIndex(self): + return self.instance.getCurrentIndex() + def getCurrent(self): - return self.l.getCurrentSelection() + return self.l.getCurrentSelection()[0] def GUIcreate(self, parent): self.instance = eListbox(parent) @@ -75,6 +82,13 @@ class MovieList(HTMLComponent, GUIComponent): self.instance.setContent(None) self.instance = None + def reload(self, root = None): + if root is not None: + self.load(root) + else: + self.load(self.root) + self.l.setList(self.list) + def load(self, root): # this lists our root service, then building a # nice list @@ -99,7 +113,17 @@ class MovieList(HTMLComponent, GUIComponent): # now process them... for ref in movieList: self.list.append(MovieListEntry(ref, serviceHandler)) + + self.list.sort(key=lambda x: -x[0][1]) - def reload(self): - self.load(self.root) - self.l.setList(self.list) + def moveTo(self, serviceref): + found = 0 + count = 0 + for x in self.list: + if str(ServiceReference(x[0][0])) == str(ServiceReference(serviceref)): + found = count + count += 1 + self.instance.moveSelectionTo(found) + + def moveDown(self): + self.instance.moveSelection(self.instance.moveDown)