X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/45a8745519c1f7f77ebcbf555e485bdc5a1a5528..e25af60135ef62fca82147f64a584d4c781b5356:/lib/python/Screens/MessageBox.py diff --git a/lib/python/Screens/MessageBox.py b/lib/python/Screens/MessageBox.py index 51dd2fb4..c3e3813b 100644 --- a/lib/python/Screens/MessageBox.py +++ b/lib/python/Screens/MessageBox.py @@ -1,27 +1,33 @@ from Screen import Screen from Components.ActionMap import ActionMap from Components.Label import Label -from Components.Button import Button from Components.Pixmap import Pixmap from Components.MenuList import MenuList -from enigma import eSize, ePoint +from Components.Sources.StaticText import StaticText +from enigma import eTimer class MessageBox(Screen): TYPE_YESNO = 0 TYPE_INFO = 1 TYPE_WARNING = 2 TYPE_ERROR = 3 - - def __init__(self, session, text, type = TYPE_YESNO): + + def __init__(self, session, text, type = TYPE_YESNO, timeout = -1, close_on_any_key = False, default = True): self.type = type Screen.__init__(self, session) - + self["text"] = Label(text) - + self["Text"] = StaticText(text) + + self.text = text + self.close_on_any_key = close_on_any_key + self["ErrorPixmap"] = Pixmap() self["QuestionPixmap"] = Pixmap() self["InfoPixmap"] = Pixmap() - + self.timerRunning = False + self.initTimeout(timeout) + self.list = [] if type != self.TYPE_ERROR: self["ErrorPixmap"].hide() @@ -29,24 +35,76 @@ class MessageBox(Screen): self["QuestionPixmap"].hide() if type != self.TYPE_INFO: self["InfoPixmap"].hide() - - if type == self.TYPE_YESNO: - self.list = [ (_("yes"), 0), (_("no"), 1) ] + if type == self.TYPE_YESNO: + if default == True: + self.list = [ (_("yes"), 0), (_("no"), 1) ] + else: + self.list = [ (_("no"), 1), (_("yes"), 0) ] self["list"] = MenuList(self.list) - - self["actions"] = ActionMap(["MsgBoxActions"], + + self["actions"] = ActionMap(["MsgBoxActions", "DirectionActions"], { "cancel": self.cancel, "ok": self.ok, - "alwaysOK": self.alwaysOK - }) - - + "alwaysOK": self.alwaysOK, + "up": self.up, + "down": self.down, + "left": self.left, + "right": self.right, + "upRepeated": self.up, + "downRepeated": self.down, + "leftRepeated": self.left, + "rightRepeated": self.right + }, -1) + + def initTimeout(self, timeout): + self.timeout = timeout + if timeout > 0: + self.timer = eTimer() + self.timer.callback.append(self.timerTick) + self.onExecBegin.append(self.startTimer) + self.origTitle = None + if self.execing: + self.timerTick() + else: + self.onShown.append(self.__onShown) + self.timerRunning = True + else: + self.timerRunning = False + + def __onShown(self): + self.onShown.remove(self.__onShown) + self.timerTick() + + def startTimer(self): + self.timer.start(1000) + + def stopTimer(self): + if self.timerRunning: + del self.timer + self.setTitle(self.origTitle) + self.timerRunning = False + + def timerTick(self): + if self.execing: + self.timeout -= 1 + if self.origTitle is None: + self.origTitle = self.instance.getTitle() + self.setTitle(self.origTitle + " (" + str(self.timeout) + ")") + if self.timeout == 0: + self.timer.stop() + self.timerRunning = False + self.timeoutCallback() + + def timeoutCallback(self): + print "Timeout!" + self.ok() + def cancel(self): self.close(False) - + def ok(self): if self.type == self.TYPE_YESNO: self.close(self["list"].getCurrent()[1] == 0) @@ -55,3 +113,24 @@ class MessageBox(Screen): def alwaysOK(self): self.close(True) + + def up(self): + self.move(self["list"].instance.moveUp) + + def down(self): + self.move(self["list"].instance.moveDown) + + def left(self): + self.move(self["list"].instance.pageUp) + + def right(self): + self.move(self["list"].instance.pageDown) + + def move(self, direction): + if self.close_on_any_key: + self.close(True) + self["list"].instance.moveSelection(direction) + self.stopTimer() + + def __repr__(self): + return str(type(self)) + "(" + self.text + ")"