X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/e57b9fbf22d6b448be63b13c792439d1ef0a4a53..b81f605c664954ebf637cc4280eaa88d023a7ab4:/lib/python/Components/MenuList.py diff --git a/lib/python/Components/MenuList.py b/lib/python/Components/MenuList.py index b12cb236..b1b115b7 100644 --- a/lib/python/Components/MenuList.py +++ b/lib/python/Components/MenuList.py @@ -4,24 +4,27 @@ from GUIComponent import * from enigma import eListboxPythonStringContent, eListbox class MenuList(HTMLComponent, GUIComponent): - def __init__(self, list): + def __init__(self, list, enableWrapAround=False): GUIComponent.__init__(self) self.list = list self.l = eListboxPythonStringContent() self.l.setList(self.list) self.onSelectionChanged = [ ] + self.enableWrapAround = enableWrapAround def getCurrent(self): return self.l.getCurrentSelection() + + GUI_WIDGET = eListbox - def GUIcreate(self, parent): - self.instance = eListbox(parent) - self.instance.setContent(self.l) - self.instance.selectionChanged.get().append(self.selectionChanged) + def postWidgetCreate(self, instance): + instance.setContent(self.l) + instance.selectionChanged.get().append(self.selectionChanged) + if self.enableWrapAround: + self.instance.setWrapAround(True) - def GUIdelete(self): - self.instance.setContent(None) - self.instance = None + def preWidgetRemove(self, instance): + instance.setContent(None) def selectionChanged(self): for f in self.onSelectionChanged: @@ -33,3 +36,23 @@ class MenuList(HTMLComponent, GUIComponent): def moveToIndex(self, idx): self.instance.moveSelectionTo(idx) + + def pageUp(self): + if self.instance is not None: + self.instance.moveSelection(self.instance.pageUp) + + def pageDown(self): + if self.instance is not None: + self.instance.moveSelection(self.instance.pageDown) + + def up(self): + if self.instance is not None: + self.instance.moveSelection(self.instance.moveUp) + + def down(self): + if self.instance is not None: + self.instance.moveSelection(self.instance.moveDown) + + def selectionEnabled(self, enabled): + if self.instance is not None: + self.instance.setSelectionEnable(enabled)