X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/d791fb8522a5b2fe7859fee6158ed99f1714dd22..90d9f3e7624282749eb59b57d4996f5d1d06c6b1:/lib/python/Screens/Ci.py diff --git a/lib/python/Screens/Ci.py b/lib/python/Screens/Ci.py index bf137f40..9fe7d854 100644 --- a/lib/python/Screens/Ci.py +++ b/lib/python/Screens/Ci.py @@ -12,9 +12,48 @@ from Components.config import * from enigma import * +class CiConfigList(HTMLComponent, GUIComponent): + def __init__(self, list): + GUIComponent.__init__(self) + self.l = eListboxPythonConfigContent() + self.l.setList(list) + self.l.setSeperation(100) + self.list = list + + def toggle(self): + pass + + def handleKey(self, key): + selection = self.getCurrent() + selection[1].handleKey(key) + self.invalidateCurrent() + + def getCurrent(self): + return self.l.getCurrentSelection() + + def invalidateCurrent(self): + self.l.invalidateEntry(self.l.getCurrentSelectionIndex()) + + def invalidate(self, entry): + i = 0 + for x in self.list: + if (entry.getConfigPath() == x[1].parent.getConfigPath()): + self.l.invalidateEntry(i) + i += 1 + pass + + def GUIcreate(self, parent): + self.instance = eListbox(parent) + self.instance.setContent(self.l) + + def GUIdelete(self): + self.instance.setContent(None) + self.instance = None + class CiMmi(Screen): def addEntry(self, list, entry): if entry[0] == "TEXT": #handle every item (text / pin only?) + #list.append( (entry[1], entry[2]) ) list.append( (entry[1], entry[2]) ) if entry[0] == "PIN": if entry[3] == 1: @@ -23,8 +62,9 @@ class CiMmi(Screen): else: # unmasked pins: x = configElement_nonSave("", configSequence, [1234], configsequencearg.get("PINCODE", (entry[1], ""))) - - self.pin = getConfigListEntry(entry[2],x) + + list.append( (entry[2], 0) ) + self.pin = getConfigListEntry("",x) list.append( self.pin ) def okbuttonClick(self): @@ -39,6 +79,10 @@ class CiMmi(Screen): print "answer LIST" eDVBCI_UI.getInstance().answerMenu(self.slotid, 0) self.showWait() + elif self.tag == "ENQ": + print "answer ENQ" + eDVBCI_UI.getInstance().answerEnq(self.slotid, str(self.pin[1].parent.value)) + self.showWait() def closeMmi(self): self.Timer.stop() @@ -54,6 +98,9 @@ class CiMmi(Screen): elif self.tag == "LIST": eDVBCI_UI.getInstance().answerMenu(self.slotid, 0) self.showWait() + elif self.tag == "ENQ": + eDVBCI_UI.getInstance().cancelEnq(self.slotid) + self.showWait() else: print "give cancel action to ci" @@ -110,6 +157,10 @@ class CiMmi(Screen): #module still there ? if eDVBCI_UI.getInstance().getState(self.slotid) != 2: self.closeMmi() + + #mmi session still active ? + if eDVBCI_UI.getInstance().getMMIState(self.slotid) != 1: + self.closeMmi() #new screen available? if eDVBCI_UI.getInstance().availableMMI(self.slotid) == 1: @@ -133,6 +184,7 @@ class CiMmi(Screen): self["subtitle"] = Label("") self["bottom"] = Label("") self["entries"] = MenuList([ ]) + #self["entries"] = CiConfigList([ ]) self["actions"] = NumberActionMap(["SetupActions"], {