aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorRonny Strutz <ronny.strutz@multimedia-labs.de>2005-10-15 14:39:14 +0000
committerRonny Strutz <ronny.strutz@multimedia-labs.de>2005-10-15 14:39:14 +0000
commitd04d03175ca6e6df022b09b0b8e068355626b5dd (patch)
tree2b57a874a1339ac4c98c2dea76ea063412fac30f /lib
parent4cb23507b16682ceeb4ad31a7de837ef2f4326f3 (diff)
downloadenigma2-d04d03175ca6e6df022b09b0b8e068355626b5dd.tar.gz
enigma2-d04d03175ca6e6df022b09b0b8e068355626b5dd.zip
added pin controls
list (w/o choice is still missing)
Diffstat (limited to 'lib')
-rw-r--r--lib/python/Screens/Ci.py102
1 files changed, 91 insertions, 11 deletions
diff --git a/lib/python/Screens/Ci.py b/lib/python/Screens/Ci.py
index 79e06b33..e95672d6 100644
--- a/lib/python/Screens/Ci.py
+++ b/lib/python/Screens/Ci.py
@@ -1,16 +1,81 @@
from Screen import *
from Components.MenuList import MenuList
from Components.ActionMap import ActionMap
+from Components.ActionMap import NumberActionMap
from Components.Header import Header
from Components.Button import Button
from Components.Label import Label
+from Components.HTMLComponent import *
+from Components.GUIComponent import *
+from Components.config import *
+
+from enigma import eListbox, eListboxPythonConfigContent
+
+class CiEntryList(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):
+ selection = self.getCurrent()
+ selection[1].toggle()
+ self.invalidateCurrent()
+
+ def handleKey(self, key):
+ #not every element got an .handleKey
+ try:
+ selection = self.getCurrent()
+ selection[1].handleKey(key)
+ self.invalidateCurrent()
+ except:
+ pass
+
+
+ def getCurrent(self):
+ return self.l.getCurrentSelection()
+
+ def getCurrentIndex(self):
+ return self.l.getCurrentSelectionIndex()
+
+ def invalidateCurrent(self):
+ self.l.invalidateEntry(self.l.getCurrentSelectionIndex())
+
+ 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):
+ def addEntry(self, list, entry, index):
if entry[0] == "TEXT": #handle every item (text / pin only?)
- pass
- pass
+ list.append( (entry[1], index) )
+ if entry[0] == "PIN":
+ x = configElement_nonSave("", configSequence, [1234], configsequencearg.get("INTEGER", (0, ((10**entry[1])-1))))
+ list.append( getConfigListEntry(entry[2],x) )
+
+ def okbuttonClick(self):
+ print "actual:" + str(self["entries"].getCurrentIndex())
+
+ def keyNumberGlobal(self, number):
+ self["entries"].handleKey(config.key[str(number)])
+
+ def keyLeft(self):
+ self["entries"].handleKey(config.key["prevElement"])
+ def keyRight(self):
+ self["entries"].handleKey(config.key["nextElement"])
+
+ def keyCancel(self):
+ print "keyCancel"
+ self.close()
+
def __init__(self, session, slotid, title, subtitle, bottom, entries):
Screen.__init__(self, session)
@@ -20,15 +85,30 @@ class CiMmi(Screen):
self["bottom"] = Label(bottom)
list = [ ]
+ cnt = 0
for entry in entries:
- self.addEntry(list, entry)
- self["entries"] = MenuList(list) #menulist!?
-
- self["actions"] = ActionMap(["OkCancelActions"],
+ self.addEntry(list, entry, cnt)
+ cnt = cnt + 1
+ self["entries"] = CiEntryList(list)
+
+ self["actions"] = NumberActionMap(["SetupActions"],
{
- #"ok": self.okbuttonClick,
- "cancel": self.close
- })
+ "ok": self.okbuttonClick,
+ "cancel": self.keyCancel,
+ #for PIN
+ "left": self.keyLeft,
+ "right": self.keyRight,
+ "1": self.keyNumberGlobal,
+ "2": self.keyNumberGlobal,
+ "3": self.keyNumberGlobal,
+ "4": self.keyNumberGlobal,
+ "5": self.keyNumberGlobal,
+ "6": self.keyNumberGlobal,
+ "7": self.keyNumberGlobal,
+ "8": self.keyNumberGlobal,
+ "9": self.keyNumberGlobal,
+ "0": self.keyNumberGlobal
+ }, -1)
#just for testing - we need an cimanager? (or not?)
class CiSelection(Screen):
@@ -37,7 +117,7 @@ class CiSelection(Screen):
list = [ ]
list.append( ("TEXT", "CA-Info") )
list.append( ("TEXT", "Card Status") )
- #list.append( ("PIN", "Card Pin") )
+ list.append( ("PIN", 6, "Card Pin") )
self.session.open(CiMmi, 0, "Wichtiges CI", "Mainmenu", "Footer", list)
def __init__(self, session):