X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/347a471b63ec3c0fdcee0368378f8f5d5e1e9ca4..1068f9bc04ef901d7031026b1a9b25e32dd0da8a:/lib/python/Screens/Setup.py diff --git a/lib/python/Screens/Setup.py b/lib/python/Screens/Setup.py index 9693a0b7..d6215afd 100644 --- a/lib/python/Screens/Setup.py +++ b/lib/python/Screens/Setup.py @@ -1,9 +1,10 @@ from Screen import Screen -from Components.ActionMap import ActionMap +from Components.ActionMap import NumberActionMap from Components.config import config #global config instance -from Components.config import configBoolean +from Components.config import configSelection from Components.ConfigList import ConfigList from Components.Label import Label +from Components.Pixmap import Pixmap import xml.dom.minidom from xml.dom import EMPTY_NAMESPACE @@ -38,7 +39,7 @@ class Setup(Screen): if x.nodeType != xml.dom.minidom.Element.nodeType: continue elif x.tagName == 'item': - ItemText = getValbyAttr(x, "text") + ItemText = _(getValbyAttr(x, "text")) b = eval(XMLTools.mergeText(x.childNodes)); print "item " + ItemText + " " + b.configPath if b == "": @@ -51,11 +52,14 @@ class Setup(Screen): list.append( (ItemText, item) ) def keyOk(self): - self["config"].handleKey(0) + if (self["config"].getCurrent()[1].parent.enabled == True): + self["config"].handleKey(config.key["choseElement"]) def keyLeft(self): - self["config"].handleKey(1) + if (self["config"].getCurrent()[1].parent.enabled == True): + self["config"].handleKey(config.key["prevElement"]) def keyRight(self): - self["config"].handleKey(2) + if (self["config"].getCurrent()[1].parent.enabled == True): + self["config"].handleKey(config.key["nextElement"]) def keySave(self): print "save requested" @@ -68,6 +72,12 @@ class Setup(Screen): for x in self["config"].list: x[1].cancel() self.close() + + def keyNumberGlobal(self, number): + print "You pressed number " + str(number) + if (self["config"].getCurrent()[1].parent.enabled == True): + self["config"].handleKey(config.key[str(number)]) + def __init__(self, session, setup): Screen.__init__(self, session) @@ -88,19 +98,34 @@ class Setup(Screen): if ItemText != setup: continue self.addItems(list, x.childNodes); + myTitle = getValbyAttr(x, "title") #check for list.entries > 0 else self.close self["config"] = ConfigList(list) - self["ok"] = Label("OK") - self["cancel"] = Label("Cancel") + self["title"] = Label(_(myTitle)); - self["actions"] = ActionMap(["SetupActions"], + self["oktext"] = Label(_("OK")) + self["canceltext"] = Label(_("Cancel")) + self["ok"] = Pixmap() + self["cancel"] = Pixmap() + + self["actions"] = NumberActionMap(["SetupActions"], { "cancel": self.keyCancel, "ok": self.keyOk, "left": self.keyLeft, "right": self.keyRight, - "save": self.keySave - }) + "save": self.keySave, + "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)