aboutsummaryrefslogtreecommitdiff
path: root/lib/python
diff options
context:
space:
mode:
authorghost <andreas.monzner@multimedia-labs.de>2009-09-03 16:34:21 +0200
committerghost <andreas.monzner@multimedia-labs.de>2009-09-03 16:34:21 +0200
commiteb7939bd2988c40f56af80a64a557e2c41a896c9 (patch)
treedce5e60946dc28ca09e543c8bdf1a12521f44028 /lib/python
parent29b7c8d9920725729d6acb5b7795cd65f8cae00a (diff)
parenta053f35db7edbd467bf01b9054d90dad3ce12803 (diff)
downloadenigma2-eb7939bd2988c40f56af80a64a557e2c41a896c9.tar.gz
enigma2-eb7939bd2988c40f56af80a64a557e2c41a896c9.zip
Merge branch 'master' of git.opendreambox.org:/git/enigma2
Diffstat (limited to 'lib/python')
-rw-r--r--lib/python/Screens/MessageBox.py1
-rw-r--r--lib/python/Screens/NumericalTextInputHelpDialog.py8
-rwxr-xr-xlib/python/Screens/Wizard.py26
3 files changed, 30 insertions, 5 deletions
diff --git a/lib/python/Screens/MessageBox.py b/lib/python/Screens/MessageBox.py
index 10485680..86bf07d3 100644
--- a/lib/python/Screens/MessageBox.py
+++ b/lib/python/Screens/MessageBox.py
@@ -88,6 +88,7 @@ class MessageBox(Screen):
def stopTimer(self):
if self.timerRunning:
del self.timer
+ self.onExecBegin.remove(self.startTimer)
self.setTitle(self.origTitle)
self.timerRunning = False
diff --git a/lib/python/Screens/NumericalTextInputHelpDialog.py b/lib/python/Screens/NumericalTextInputHelpDialog.py
index e0979587..de8e8d66 100644
--- a/lib/python/Screens/NumericalTextInputHelpDialog.py
+++ b/lib/python/Screens/NumericalTextInputHelpDialog.py
@@ -4,13 +4,15 @@ from Components.Label import Label
class NumericalTextInputHelpDialog(Screen):
def __init__(self, session, textinput):
Screen.__init__(self, session)
- for x in (1, 2, 3, 4, 5, 6, 7, 8, 9):
+ self["help1"] = Label(text="<")
+ self["help2"] = Label(text=">")
+ for x in (1, 2, 3, 4, 5, 6, 7, 8, 9, 0):
self["key%d" % x] = Label(text=textinput.mapping[x].encode("utf-8"))
self.last_marked = 0
def update(self, textinput):
- if 1 <= self.last_marked <= 9:
+ if 0 <= self.last_marked <= 9:
self["key%d" % self.last_marked].setMarkedPos(-1)
- if 1 <= textinput.lastKey <= 9:
+ if 0 <= textinput.lastKey <= 9:
self["key%d" % textinput.lastKey].setMarkedPos(textinput.pos)
self.last_marked = textinput.lastKey
diff --git a/lib/python/Screens/Wizard.py b/lib/python/Screens/Wizard.py
index 555110a4..74219eb1 100755
--- a/lib/python/Screens/Wizard.py
+++ b/lib/python/Screens/Wizard.py
@@ -1,6 +1,7 @@
from Screen import Screen
from Screens.HelpMenu import HelpableScreen
+from Screens.MessageBox import MessageBox
from Components.config import config, KEY_LEFT, KEY_RIGHT, KEY_HOME, KEY_END, KEY_0, KEY_DELETE, KEY_BACKSPACE, KEY_OK, KEY_TOGGLEOW, KEY_ASCII, KEY_TIMEOUT, KEY_NUMBERS
from Components.Label import Label
@@ -84,6 +85,8 @@ class Wizard(Screen):
else:
timeoutstep = ''
self.wizard[self.lastStep] = {"id": id, "condition": "", "text": "", "timeout": timeout, "timeoutaction": timeoutaction, "timeoutstep": timeoutstep, "list": [], "config": {"screen": None, "args": None, "type": "" }, "code": "", "codeafter": "", "code_async": "", "codeafter_async": "", "nextstep": nextstep}
+ if attrs.has_key('laststep'):
+ self.wizard[self.lastStep]["laststep"] = str(attrs.get('laststep'))
elif (name == "text"):
self.wizard[self.lastStep]["text"] = str(attrs.get('value')).replace("\\n", "\n")
elif (name == "displaytext"):
@@ -162,6 +165,8 @@ class Wizard(Screen):
def __init__(self, session, showSteps = True, showStepSlider = True, showList = True, showConfig = True):
Screen.__init__(self, session)
+
+ self.isLastWizard = False # can be used to skip a "goodbye"-screen in a wizard
self.stepHistory = []
@@ -284,6 +289,8 @@ class Wizard(Screen):
if len(self.stepHistory) > 1:
self.currStep = self.stepHistory[-2]
self.stepHistory = self.stepHistory[:-2]
+ else:
+ self.session.openWithCallback(self.exitWizardQuestion, MessageBox, (_("Are you sure you want to exit this wizard?") ) )
if self.currStep < 1:
self.currStep = 1
print "currStep:", self.currStep
@@ -291,6 +298,11 @@ class Wizard(Screen):
self.updateValues()
print "after updateValues stepHistory:", self.stepHistory
+ def exitWizardQuestion(self, ret = False):
+ if (ret):
+ self.markDone()
+ self.close()
+
def markDone(self):
pass
@@ -472,8 +484,14 @@ class Wizard(Screen):
self.condition = True
exec (self.wizard[self.currStep]["condition"])
if not self.condition:
- self.currStep += 1
- self.updateValues()
+ print "keys*******************:", self.wizard[self.currStep].keys()
+ if self.wizard[self.currStep].has_key("laststep"): # exit wizard, if condition of laststep doesn't hold
+ self.markDone()
+ self.close()
+ return
+ else:
+ self.currStep += 1
+ self.updateValues()
else:
if self.wizard[self.currStep].has_key("displaytext"):
displaytext = self.wizard[self.currStep]["displaytext"]
@@ -605,6 +623,10 @@ class WizardManager:
def getWizards(self):
# x[1] is precondition
+ for wizard in self.wizards:
+ wizard[0].isLastWizard = False
+ if len(self.wizards) > 0:
+ self.wizards[-1][0].isLastWizard = True
return [(x[2], x[0]) for x in self.wizards if x[1] == 1]
wizardManager = WizardManager()