X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/301bab11f8453a6899153b7be338a352803b22cb..05c8bbbbdb6e4175264e6b55f26957b0a0f874a9:/lib/python/Screens/Setup.py
diff --git a/lib/python/Screens/Setup.py b/lib/python/Screens/Setup.py
index a694ab16..432d8245 100644
--- a/lib/python/Screens/Setup.py
+++ b/lib/python/Screens/Setup.py
@@ -1,10 +1,9 @@
from Screen import Screen
-from Components.ActionMap import ActionMap
-from Components.config import config #global config instance
-from Components.config import configEntry
-from Components.config import configBoolean
-from Components.ConfigList import ConfigList
+from Components.ActionMap import NumberActionMap
+from Components.config import config, KEY_LEFT, KEY_RIGHT, KEY_OK
+from Components.ConfigList import ConfigList, ConfigListScreen
from Components.Label import Label
+from Components.Pixmap import Pixmap
import xml.dom.minidom
from xml.dom import EMPTY_NAMESPACE
@@ -12,144 +11,121 @@ from skin import elementsWithTag
from Tools import XMLTools
-setupdom = xml.dom.minidom.parseString(
- """
-
-
- - config.inputDevices.repeat
- - config.inputDevices.delay
- - config.rc.map
-
-
- - config.timezone.val
-
-
- - config.av.colorformat
- - config.av.aspectratio
- - config.av.tvsystem
- - config.av.wss
- - config.av.defaultac3
- - config.av.vcrswitch
-
-
- - config.rfmod.enable
- - config.rfmod.test
- - config.rfmod.sound
- - config.rfmod.soundcarrier
- - config.rfmod.channel
- - config.rfmod.finetune
-
-
- - config.keyboard.keymap
-
-
- - config.osd.alpha
- - config.osd.bright
- - config.osd.contrast
- - config.osd.language
-
-
- - config.lcd.bright
- - config.lcd.standby
- - config.lcd.invert
-
-
- - config.parental.lock
- - config.parental.setuplock
-
-
- - config.expert.splitsize
- - config.expert.satpos
- - config.expert.fastzap
- - config.expert.skipconfirm
- - config.expert.hideerrors
- - config.expert.autoinfo
-
-
- - config.sat.diseqcA
- - config.sat.posA
- - config.sat.satA
- - config.sat.diseqcB
- - config.sat.posB
- - config.sat.satB
-
-
- """)
-
-def getValbyAttr(x, attr):
- for p in range(x.attributes.length):
- a = x.attributes.item(p)
- attrib = str(a.name)
- value = str(a.value)
- if attrib == attr:
- return value
-
- return ""
+# 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()
-class Setup(Screen):
+class SetupSummary(Screen):
+ skin = """
+
+
+
+
+ """
- 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 = 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 __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 keyOk(self):
- self["config"].handleKey(0)
- def keyLeft(self):
- self["config"].handleKey(1)
- def keyRight(self):
- self["config"].handleKey(2)
+ def selectionChanged(self):
+ self["SetupEntry"].text = self.parent.getCurrentEntry()
+ self["SetupValue"].text = self.parent.getCurrentValue()
- def keySave(self):
- print "save requested"
- for x in self["config"]:
- selection = self["config"].getCurrent()
- selection.save()
+class Setup(ConfigListScreen, Screen):
+
+ ALLOW_SUSPEND = True
def __init__(self, session, setup):
Screen.__init__(self, session)
- print "request setup for " + setup
-
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
elif x.tagName == 'setup':
- ItemText = getValbyAttr(x, "key")
- if ItemText != setup:
+ if x.getAttribute("key") != setup:
continue
self.addItems(list, x.childNodes);
-
+ myTitle = x.getAttribute("title").encode("UTF-8")
+
#check for list.entries > 0 else self.close
- self["config"] = ConfigList(list)
-
- self["ok"] = Label("OK")
- self["cancel"] = Label("Cancel")
+ self.setup_title = myTitle
+ self["title"] = Label(_(self.setup_title))
- self["actions"] = ActionMap(["SetupActions"],
+ self["oktext"] = Label(_("OK"))
+ self["canceltext"] = Label(_("Cancel"))
+ self["ok"] = Pixmap()
+ self["cancel"] = Pixmap()
+
+ self["actions"] = NumberActionMap(["SetupActions"],
{
- "cancel": self.close,
- "ok": self.keyOk,
- "left": self.keyLeft,
- "right": self.keyRight,
- "save": self.keySave
- })
+ "cancel": self.keyCancel,
+ "save": self.keySave,
+ }, -2)
+
+ ConfigListScreen.__init__(self, list, session = session, on_change = self.changedEntry)
+
+ 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].getText())
+
+ def createSummary(self):
+ return SetupSummary
+
+ def addItems(self, list, childNode):
+ for x in childNode:
+ if x.nodeType != xml.dom.minidom.Element.nodeType:
+ continue
+ elif x.tagName == 'item':
+ item_text = _(x.getAttribute("text").encode("UTF-8") or "??")
+ b = eval(XMLTools.mergeText(x.childNodes));
+ if b == "":
+ continue
+ #add to configlist
+ item = b
+ # the first b is the item itself, ignored by the configList.
+ # the second one is converted to string.
+ list.append( (item_text, item) )
+
+def getSetupTitle(id):
+ xmldata = setupdom.childNodes[0].childNodes
+ for x in elementsWithTag(xmldata, "setup"):
+ if x.getAttribute("key") == id:
+ return x.getAttribute("title").encode("UTF-8")