X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/5db1b523e89c6abca92c70916ef7a63b6d51b7e3..40c7c611cfab3dfe403a041e4921805cb107adf4:/lib/python/Screens/Setup.py?ds=sidebyside
diff --git a/lib/python/Screens/Setup.py b/lib/python/Screens/Setup.py
index 582314d5..2981e25a 100644
--- a/lib/python/Screens/Setup.py
+++ b/lib/python/Screens/Setup.py
@@ -1,5 +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 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
@@ -7,13 +12,16 @@ from skin import elementsWithTag
from Tools import XMLTools
-setupdom = xml.dom.minidom.parseString(
- """
-
- - config.inputDevices.repeat
- - config.inputDevices.delay
-
- """)
+# FIXME: use resolveFile!
+# read the setupmenu
+try:
+ # first we search in the current path
+ setupfile = file('data/setup.xml', 'r')
+except:
+ # if not found in the current path, we use the global datadir-path
+ setupfile = file('/usr/share/enigma2/setup.xml', 'r')
+setupdom = xml.dom.minidom.parseString(setupfile.read())
+setupfile.close()
def getValbyAttr(x, attr):
for p in range(x.attributes.length):
@@ -25,26 +33,95 @@ def getValbyAttr(x, attr):
return ""
-class Setup(Screen):
+class SetupSummary(Screen):
+ skin = """
+
+
+
+
+ """
+
+ def __init__(self, session, parent):
+ Screen.__init__(self, session)
+ self["SetupTitle"] = Label(_(parent.setup_title))
+ self["SetupEntry"] = Label("")
+ self["SetupValue"] = Label("")
+ self.parent = parent
+ self.onShow.append(self.addWatcher)
+ self.onHide.append(self.removeWatcher)
+
+ def addWatcher(self):
+ self.parent.onChangedEntry.append(self.selectionChanged)
+ self.parent["config"].onSelectionChanged.append(self.selectionChanged)
+ self.selectionChanged()
+
+ def removeWatcher(self):
+ self.parent.onChangedEntry.remove(self.selectionChanged)
+ self.parent["config"].onSelectionChanged.remove(self.selectionChanged)
+
+ def selectionChanged(self):
+ self["SetupEntry"].text = self.parent.getCurrentEntry()
+ self["SetupValue"].text = self.parent.getCurrentValue()
- def createDialog(self, childNode):
- print "createDialog"
+class Setup(Screen):
+ def addItems(self, list, childNode):
for x in childNode:
if x.nodeType != xml.dom.minidom.Element.nodeType:
continue
elif x.tagName == 'item':
- ItemText = getValbyAttr(x, "text")
- b = XMLTools.mergeText(x.childNodes);
- print "item " + ItemText + " " + b
+ ItemText = _(getValbyAttr(x, "text"))
+ b = eval(XMLTools.mergeText(x.childNodes));
+ print "item " + ItemText + " " + b.configPath
+ if b == "":
+ continue
#add to configlist
+ item = b.controlType(b)
+ # the first b is the item itself, ignored by the configList.
+ # the second one is converted to string.
+ list.append( (ItemText, item) )
+
+ def handleKey(self, key):
+ # ignore keys when not enabled
+ if self["config"].getCurrent()[1].parent.enabled:
+ self["config"].handleKey(config.key[key])
+ print self["config"].getCurrent()
+ self.changedEntry()
+
+ def keyOk(self):
+ self.handleKey("choseElement")
+
+ def keyLeft(self):
+ self.handleKey("prevElement")
+
+ def keyRight(self):
+ self.handleKey("nextElement")
+
+ def keySave(self):
+ print "save requested"
+ for x in self["config"].list:
+ x[1].save()
+ self.close()
+
+ def keyCancel(self):
+ print "cancel requested"
+ for x in self["config"].list:
+ x[1].cancel()
+ self.close()
+
+ def keyNumberGlobal(self, number):
+ self.handleKey(str(number))
+
def __init__(self, session, setup):
Screen.__init__(self, session)
- print "request setup for " + setup
-
- entries = setupdom.childNodes
+ xmldata = setupdom.childNodes[0]
+ entries = xmldata.childNodes
+
+ self.onChangedEntry = [ ]
+ list = []
+
for x in entries: #walk through the actual nodelist
if x.nodeType != xml.dom.minidom.Element.nodeType:
continue
@@ -52,11 +129,52 @@ class Setup(Screen):
ItemText = getValbyAttr(x, "key")
if ItemText != setup:
continue
- self.createDialog(x.childNodes);
-
+ self.addItems(list, x.childNodes);
+ myTitle = getValbyAttr(x, "title")
+
+ #check for list.entries > 0 else self.close
+
+ self["config"] = ConfigList(list)
- self["actions"] = ActionMap(["OkCancelActions"],
+ self.setup_title = myTitle
+ self["title"] = Label(_(self.setup_title))
+
+ self["oktext"] = Label(_("OK"))
+ self["canceltext"] = Label(_("Cancel"))
+ self["ok"] = Pixmap()
+ self["cancel"] = Pixmap()
+
+ self["actions"] = NumberActionMap(["SetupActions"],
{
- #"ok": self.inc,
- "cancel": self.close
- })
+ "cancel": self.keyCancel,
+ "ok": self.keyOk,
+ "left": self.keyLeft,
+ "right": self.keyRight,
+ "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)
+
+ self.changedEntry()
+
+ # for summary:
+ def changedEntry(self):
+ for x in self.onChangedEntry:
+ x()
+
+ def getCurrentEntry(self):
+ return self["config"].getCurrent()[0]
+
+ def getCurrentValue(self):
+ return str(self["config"].getCurrent()[1].parent.value)
+
+ def createSummary(self):
+ return SetupSummary