add a condition to the wizard-parser
authorStefan Pluecken <stefan.pluecken@multimedia-labs.de>
Fri, 16 Dec 2005 23:40:01 +0000 (23:40 +0000)
committerStefan Pluecken <stefan.pluecken@multimedia-labs.de>
Fri, 16 Dec 2005 23:40:01 +0000 (23:40 +0000)
use this condition to discover, whether we need to show the tuner configs in the start wizard (single tuner-boxes should
work now)

data/startwizard.xml
lib/python/Screens/StartWizard.py
lib/python/Screens/Wizard.py

index ae181f4d71cbd8020177616083cb227e09b667f0..37a5b1e5c33edf9940dbf47cbf572868a5892144 100644 (file)
@@ -28,6 +28,10 @@ self["rc"].startMoving()
                        </code>
                </step>
                <step number="3">
+                       <condition>
+from Components.NimManager import nimmanager
+self.condition = nimmanager.nimCount > 0
+                       </condition>
                        <text value="Use the left and right buttons to change an option.\n\nPlease set up tuner A" />
                        <config screen="NimSetup" module="Satconfig" args="0" type="ConfigList" />
                        <code>
@@ -43,6 +47,10 @@ self["arrowdown"].startMoving()
                        </code>
                </step>
                <step number="4">
+                       <condition>
+from Components.NimManager import nimmanager
+self.condition = nimmanager.nimCount > 1
+                       </condition>
                        <text value="Please set up tuner B" />
                        <config screen="NimSetup" module="Satconfig" args="1" type="ConfigList" />
                        <code>
index 8fdd340e8be934b16c5f765b71ddb622f269056c..501ea6c5d508b1a2bf86e68ca4b6b70090a22268 100644 (file)
@@ -1,6 +1,7 @@
 from Wizard import Wizard, wizardManager
 
 from Components.Pixmap import *
+
 from LanguageSelection import LanguageSelection
 
 class StartWizard(Wizard):
index fd9e9c3c44ab1fd042a13578de8986f5b51580db..01797267189853f7db4fd974dfb771bc7e54ff73 100644 (file)
@@ -29,7 +29,7 @@ class Wizard(Screen, HelpableScreen):
                        self.currContent = name
                        if (name == "step"):
                                self.lastStep = int(attrs.get('number'))
-                               self.wizard[self.lastStep] = {"text": "", "list": [], "config": {"screen": None, "args": None, "type": "" }, "code": ""}
+                               self.wizard[self.lastStep] = {"condition": "", "text": "", "list": [], "config": {"screen": None, "args": None, "type": "" }, "code": ""}
                        elif (name == "text"):
                                self.wizard[self.lastStep]["text"] = string.replace(str(attrs.get('value')), "\\n", "\n")
                        elif (name == "listentry"):
@@ -41,15 +41,20 @@ class Wizard(Screen, HelpableScreen):
                                        print "has args"
                                        self.wizard[self.lastStep]["config"]["args"] = str(attrs.get('args'))
                                self.wizard[self.lastStep]["config"]["type"] = str(attrs.get('type'))
+                       elif (name == "condition"):
+                               pass
                def endElement(self, name):
                        self.currContent = ""
                        if name == 'code':
                                self.wizard[self.lastStep]["code"] = self.wizard[self.lastStep]["code"].strip()
-                               
+                       elif name == 'condition':
+                               self.wizard[self.lastStep]["condition"] = self.wizard[self.lastStep]["condition"].strip()
+                                                               
                def characters(self, ch):
                        if self.currContent == "code":
                                 self.wizard[self.lastStep]["code"] = self.wizard[self.lastStep]["code"] + ch
-                               
+                       elif self.currContent == "condition":
+                                self.wizard[self.lastStep]["condition"] = self.wizard[self.lastStep]["condition"] + ch
        def __init__(self, session):
                Screen.__init__(self, session)
                HelpableScreen.__init__(self)
@@ -166,40 +171,47 @@ class Wizard(Screen, HelpableScreen):
                
        def updateValues(self):
                print "Updating values in step " + str(self.currStep)
-               self["step"].setText(_("Step ") + str(self.currStep) + "/" + str(self.numSteps))
-               self["stepslider"].setValue(self.currStep)
-
-               print _(self.wizard[self.currStep]["text"])
-               self["text"].setText(_(self.wizard[self.currStep]["text"]))
-
-               if self.wizard[self.currStep]["code"] != "":
-                       print self.wizard[self.currStep]["code"]
-                       exec(self.wizard[self.currStep]["code"])
                
-               self["list"].instance.setZPosition(1)
-               self.list = []
-               if (len(self.wizard[self.currStep]["list"]) > 0):
-                       self["list"].instance.setZPosition(2)
-                       for x in self.wizard[self.currStep]["list"]:
-                               self.list.append((_(x[0]), None))
-               self["list"].l.setList(self.list)
-
-               self["config"].instance.setZPosition(1)
-               if (self.wizard[self.currStep]["config"]["screen"] != None):
-                       if self.wizard[self.currStep]["config"]["type"] == "standalone":
-                               print "Type is standalone"
-                               self.session.openWithCallback(self.ok, self.wizard[self.currStep]["config"]["screen"])
-                       else:
-                               self["config"].instance.setZPosition(2)
-                               print self.wizard[self.currStep]["config"]["screen"]
-                               if self.wizard[self.currStep]["config"]["args"] == None:
-                                       self.configInstance = self.session.instantiateDialog(self.wizard[self.currStep]["config"]["screen"])
+               self.condition = True
+               exec (self.wizard[self.currStep]["condition"])
+               if self.condition:
+                       self["step"].setText(_("Step ") + str(self.currStep) + "/" + str(self.numSteps))
+                       self["stepslider"].setValue(self.currStep)
+               
+                       print _(self.wizard[self.currStep]["text"])
+                       self["text"].setText(_(self.wizard[self.currStep]["text"]))
+       
+                       if self.wizard[self.currStep]["code"] != "":
+                               print self.wizard[self.currStep]["code"]
+                               exec(self.wizard[self.currStep]["code"])
+                       
+                       self["list"].instance.setZPosition(1)
+                       self.list = []
+                       if (len(self.wizard[self.currStep]["list"]) > 0):
+                               self["list"].instance.setZPosition(2)
+                               for x in self.wizard[self.currStep]["list"]:
+                                       self.list.append((_(x[0]), None))
+                       self["list"].l.setList(self.list)
+       
+                       self["config"].instance.setZPosition(1)
+                       if (self.wizard[self.currStep]["config"]["screen"] != None):
+                               if self.wizard[self.currStep]["config"]["type"] == "standalone":
+                                       print "Type is standalone"
+                                       self.session.openWithCallback(self.ok, self.wizard[self.currStep]["config"]["screen"])
                                else:
-                                       self.configInstance = self.session.instantiateDialog(self.wizard[self.currStep]["config"]["screen"], eval(self.wizard[self.currStep]["config"]["args"]))
-                               self["config"].l.setList(self.configInstance["config"].list)
-                               self.configInstance["config"] = self["config"]
-               else:
-                       self["config"].l.setList([])
+                                       self["config"].instance.setZPosition(2)
+                                       print self.wizard[self.currStep]["config"]["screen"]
+                                       if self.wizard[self.currStep]["config"]["args"] == None:
+                                               self.configInstance = self.session.instantiateDialog(self.wizard[self.currStep]["config"]["screen"])
+                                       else:
+                                               self.configInstance = self.session.instantiateDialog(self.wizard[self.currStep]["config"]["screen"], eval(self.wizard[self.currStep]["config"]["args"]))
+                                       self["config"].l.setList(self.configInstance["config"].list)
+                                       self.configInstance["config"] = self["config"]
+                       else:
+                               self["config"].l.setList([])
+               else: # condition false
+                               self.currStep += 1
+                               self.updateValues()
 
        def delReferences(self):
                del self.configInstance