X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/b38677078a8882dfecd87533291863bbf76d1d63..193333b7bc72ab13d4dee5750b31c3c33041c696:/lib/python/Screens/TimerEdit.py diff --git a/lib/python/Screens/TimerEdit.py b/lib/python/Screens/TimerEdit.py index 965c35b6..4a4185c3 100644 --- a/lib/python/Screens/TimerEdit.py +++ b/lib/python/Screens/TimerEdit.py @@ -3,12 +3,11 @@ from Components.TimerList import TimerList, TimerEntryComponent from Components.ConfigList import ConfigList from Components.MenuList import MenuList from Components.ActionMap import ActionMap -from Components.TimeInput import TimeInput from Components.Label import Label from Components.Button import Button from Screens.MessageBox import MessageBox from TimerEntry import TimerEntry, TimerLog -from RecordTimer import RecordTimerEntry, parseEvent +from RecordTimer import RecordTimerEntry, parseEvent, AFTEREVENT from time import * from ServiceReference import ServiceReference from Components.config import * @@ -63,9 +62,18 @@ class TimerEditList(Screen): self.updateState() def toggleDisabledState(self): - self["timerlist"].getCurrent()[0].disabled = not self["timerlist"].getCurrent()[0].disabled - self.updateState() - self.refill() + cur=self["timerlist"].getCurrent() + if cur: + t = cur[0] + + if t.disabled: + t.enable() + else: + t.disable() + + self.session.nav.RecordTimer.timeChanged(t) + self.updateState() + self.refill() def updateState(self): if len(self.list) > 0: @@ -83,14 +91,18 @@ class TimerEditList(Screen): for timer in self.session.nav.RecordTimer.processed_timers: self.list.append(TimerEntryComponent(timer, processed=True)) + self.list.sort(cmp = lambda x, y: x[0].begin < y[0].begin) def showLog(self): - self.session.openWithCallback(self.finishedEdit, TimerLog, self["timerlist"].getCurrent()[0]) + cur=self["timerlist"].getCurrent() + if cur: + self.session.openWithCallback(self.finishedEdit, TimerLog, cur[0]) def openEdit(self): - self.session.openWithCallback(self.finishedEdit, TimerEntry, self["timerlist"].getCurrent()[0]) - #self.session.open(TimerEdit, self["timerlist"].getCurrent()[0]) - + cur=self["timerlist"].getCurrent() + if cur: + self.session.openWithCallback(self.finishedEdit, TimerEntry, cur[0]) + def cleanupQuestion(self): self.session.openWithCallback(self.cleanupTimer, MessageBox, _("Really delete done timers?")) @@ -101,14 +113,12 @@ class TimerEditList(Screen): def removeTimer(self): list = self["timerlist"] - timer = list.getCurrent()[0] - currentIndex = list.getCurrentIndex() - self.session.nav.RecordTimer.removeEntry(timer) - list.moveDown() - if list.getCurrentIndex() == currentIndex: - currentIndex -= 1 - self.refill() - list.moveToIndex(currentIndex) + cur = list.getCurrent() + if cur: + timer = cur[0] + timer.afterEvent = AFTEREVENT.NONE + self.session.nav.RecordTimer.removeEntry(timer) + self.refill() def refill(self): self.fillTimerList() @@ -130,7 +140,7 @@ class TimerEditList(Screen): else: data = parseEvent(event) - self.addTimer(RecordTimerEntry(serviceref, *data)) + self.addTimer(RecordTimerEntry(serviceref, checkOldTimers = True, *data)) def addTimer(self, timer): self.session.openWithCallback(self.finishedAdd, TimerEntry, timer) @@ -180,7 +190,7 @@ class TimerSanityConflict(Screen): def __init__(self, session, timer): Screen.__init__(self, session) self.timer = timer - print timer + print "TimerSanityConflict", timer self["timer1"] = TimerList(self.getTimerList(timer[0])) if len(timer) > 1: