-from Screen import Screen
-from Components.TimerList import TimerList, TimerEntryComponent
-from Components.ConfigList import ConfigList
-from Components.MenuList import MenuList
from Components.ActionMap import ActionMap
-from Components.Label import Label
from Components.Button import Button
+from Components.MenuList import MenuList
+from Components.TimerList import TimerList, TimerEntryComponent
+from Components.TimerSanityCheck import TimerSanityCheck
+from RecordTimer import RecordTimerEntry, parseEvent, AFTEREVENT
+from Screen import Screen
+from Screens.ChoiceBox import ChoiceBox
from Screens.MessageBox import MessageBox
-from TimerEntry import TimerEntry, TimerLog
-from RecordTimer import RecordTimerEntry, parseEvent
-from time import *
from ServiceReference import ServiceReference
-from Components.config import *
-from Components.TimerSanityCheck import TimerSanityCheck
+from TimerEntry import TimerEntry, TimerLog
+from Tools.BoundFunction import boundFunction
+from time import time
class TimerEditList(Screen):
def __init__(self, session):
{
"ok": self.openEdit,
"cancel": self.leave,
- "red": self.removeTimer,
+ "red": self.removeTimerQuestion,
"green": self.addCurrentTimer,
"blue": self.cleanupQuestion,
"yellow": self.toggleDisabledState,
if t.disabled:
t.enable()
+ self.session.nav.RecordTimer.timeChanged(t)
+
else:
- t.disable()
+ if t.isRunning() and t.repeated:
+ list = []
+ list.append((_("Stop current event but not coming events"), "stoponlycurrent"))
+ list.append((_("Stop current event and disable coming events"), "stopall"))
+ list.append((_("Don't stop current event but disable coming events"), "stoponlycoming"))
+ self.session.openWithCallback(boundFunction(self.runningEventCallback, t), ChoiceBox, title=_("Repeating event currently recording... What do you want to do?"), list = list)
+ else:
+ t.disable()
+ self.session.nav.RecordTimer.timeChanged(t)
+ self.updateState()
+ self.refill()
+ def runningEventCallback(self, t, result):
+ if result is not None:
+ if result[1] == "stoponlycurrent" or result[1] == "stopall":
+ t.enable()
+ t.processRepeated(findRunningEvent = False)
+ self.session.nav.RecordTimer.doActivate(t)
+ if result[1] == "stoponlycoming" or result[1] == "stopall":
+ t.disable()
self.session.nav.RecordTimer.timeChanged(t)
+
self.updateState()
self.refill()
if delete:
self.session.nav.RecordTimer.cleanup()
self.refill()
+
+ def removeTimerQuestion(self):
+ self.session.openWithCallback(self.removeTimer, MessageBox, _("Really delete this timer?"))
- def removeTimer(self):
+ def removeTimer(self, result):
+ if not result:
+ return
list = self["timerlist"]
cur = list.getCurrent()
if cur:
timer = cur[0]
+ timer.afterEvent = AFTEREVENT.NONE
self.session.nav.RecordTimer.removeEntry(timer)
self.refill()
serviceref = ServiceReference(self.session.nav.getCurrentlyPlayingServiceReference())
if event is None:
- data = (int(time()), int(time() + 60), "unknown event", "", None)
+ data = (int(time()), int(time() + 60), "", "", None)
else:
- data = parseEvent(event)
+ data = parseEvent(event, description = False)
self.addTimer(RecordTimerEntry(serviceref, checkOldTimers = True, *data))
self.finishedAdd(answer)
def leave(self):
- self.session.nav.RecordTimer.saveTimer()
self.session.nav.RecordTimer.on_state_change.remove(self.onStateChange)
self.close()
if len(timer) > 1:
self["timer2"] = TimerList(self.getTimerList(timer[1]))
else:
- self["timer2"] = Button("No conflict")
+ self["timer2"] = TimerList([])
self.list = []
count = 0