X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/d7d95c7b2435ab1819bc23eff5ff53aaac2b9ff1..58445511632b8e6c043e6bf7e5ef63630ecbc829:/lib/python/Screens/TimerEntry.py diff --git a/lib/python/Screens/TimerEntry.py b/lib/python/Screens/TimerEntry.py index 5893749b..14aa1ce3 100644 --- a/lib/python/Screens/TimerEntry.py +++ b/lib/python/Screens/TimerEntry.py @@ -5,12 +5,14 @@ from Components.ConfigList import ConfigList from Components.NimManager import nimmanager from Components.Label import Label from time import * +from datetime import * class TimerEntry(Screen): def __init__(self, session, timer): Screen.__init__(self, session) - - self.createConfig(timer) + self.timer = timer; + + self.createConfig() self["actions"] = NumberActionMap(["SetupActions"], { @@ -34,40 +36,105 @@ class TimerEntry(Screen): self["config"] = ConfigList(self.list) self.createSetup() - self["introduction"] = Label("Press OK to start the scan") - - def createConfig(self, timer): + def createConfig(self): config.timerentry = ConfigSubsection() - config.timerentry.startdate = configElement_nonSave("config.timerentry.startdate", configDateTime, timer.begin, ("%d.%B %Y", 86400)) - config.timerentry.starttime = configElement_nonSave("config.timerentry.starttime", configDateTime, timer.begin, ("%H:%M", 60)) - config.timerentry.enddate = configElement_nonSave("config.timerentry.enddate", configDateTime, timer.end, ("%d.%B %Y", 86400)) - config.timerentry.endtime = configElement_nonSave("config.timerentry.endtime", configDateTime, timer.end, ("%H:%M", 60)) - #config.timerentry.weekday = configElement_nonSave("config.timerentry.weekday", configDateTime, time(), ("%A", 86400)) + config.timerentry.type = configElement_nonSave("config.timerentry.type", configSelection, 0, ("once", "repeated")) + config.timerentry.description = configElement_nonSave("config.timerentry.description", configText, self.timer.description, (configText.extendableSize, self.keyRightCallback)) + + config.timerentry.repeated = configElement_nonSave("config.timerentry.repeated", configSelection, 0, ("daily", "weekly", "Mon-Fri", "user-defined")) + + config.timerentry.startdate = configElement_nonSave("config.timerentry.startdate", configDateTime, self.timer.begin, ("%d.%B %Y", 86400)) + config.timerentry.starttime = configElement_nonSave("config.timerentry.starttime", configSequence, [int(strftime("%H", localtime(self.timer.begin))), int(strftime("%M", localtime(self.timer.begin)))], configsequencearg.get("CLOCK")) + + config.timerentry.enddate = configElement_nonSave("config.timerentry.enddate", configDateTime, self.timer.end, ("%d.%B %Y", 86400)) + config.timerentry.endtime = configElement_nonSave("config.timerentry.endtime", configSequence, [int(strftime("%H", localtime(self.timer.end))), int(strftime("%M", localtime(self.timer.end)))], configsequencearg.get("CLOCK")) + + config.timerentry.weekday = configElement_nonSave("config.timerentry.weekday", configDateTime, time(), ("%A", 86400)) + + config.timerentry.monday = configElement_nonSave("config.timerentry.monday", configSelection, 0, ("yes", "no")) + config.timerentry.tuesday = configElement_nonSave("config.timerentry.tuesday", configSelection, 0, ("yes", "no")) + config.timerentry.wednesday = configElement_nonSave("config.timerentry.wednesday", configSelection, 0, ("yes", "no")) + config.timerentry.thursday = configElement_nonSave("config.timerentry.thursday", configSelection, 0, ("yes", "no")) + config.timerentry.friday = configElement_nonSave("config.timerentry.friday", configSelection, 0, ("yes", "no")) + config.timerentry.saturday = configElement_nonSave("config.timerentry.saturday", configSelection, 0, ("yes", "no")) + config.timerentry.sunday = configElement_nonSave("config.timerentry.sunday", configSelection, 0, ("yes", "no")) + + # FIXME some service-chooser needed here + config.timerentry.service = configElement_nonSave("config.timerentry.service", configSelection, 0, ((str(self.timer.service_ref.getServiceName())),)) + + config.timerentry.startdate.addNotifier(self.checkDate) + config.timerentry.enddate.addNotifier(self.checkDate) + + def checkDate(self, configElement): + if (configElement.getConfigPath() == "config.timerentry.startdate"): + if (config.timerentry.enddate.value < config.timerentry.startdate.value): + config.timerentry.enddate.value = config.timerentry.startdate.value + config.timerentry.enddate.change() + self["config"].invalidate(config.timerentry.enddate) + if (configElement.getConfigPath() == "config.timerentry.enddate"): + if (config.timerentry.enddate.value < config.timerentry.startdate.value): + config.timerentry.startdate.value = config.timerentry.enddate.value + config.timerentry.startdate.change() + self["config"].invalidate(config.timerentry.startdate) def createSetup(self): self.list = [] + self.list.append(getConfigListEntry("Description", config.timerentry.description)) + self.list.append(getConfigListEntry("TimerType", config.timerentry.type)) - self.list.append(getConfigListEntry("StartDate", config.timerentry.startdate)) + if (config.timerentry.type.value == 0): # once + pass + else: # repeated + self.list.append(getConfigListEntry("Frequency", config.timerentry.repeated)) + if (config.timerentry.repeated.value == 0): # daily + pass + if (config.timerentry.repeated.value == 2): # Mon-Fri + pass + if (config.timerentry.repeated.value == 1): # weekly + self.list.append(getConfigListEntry("Weekday", config.timerentry.weekday)) + + if (config.timerentry.repeated.value == 3): # user-defined + self.list.append(getConfigListEntry("Monday", config.timerentry.monday)) + self.list.append(getConfigListEntry("Tuesday", config.timerentry.tuesday)) + self.list.append(getConfigListEntry("Wednesday", config.timerentry.wednesday)) + self.list.append(getConfigListEntry("Thursday", config.timerentry.thursday)) + self.list.append(getConfigListEntry("Friday", config.timerentry.friday)) + self.list.append(getConfigListEntry("Saturday", config.timerentry.saturday)) + self.list.append(getConfigListEntry("Sunday", config.timerentry.sunday)) + + #self.list.append(getConfigListEntry("StartDate", config.timerentry.startdate)) +# self.list.append(getConfigListEntry("Weekday", config.timerentry.weekday)) + + if (config.timerentry.type.value == 0): # once + self.list.append(getConfigListEntry("StartDate", config.timerentry.startdate)) self.list.append(getConfigListEntry("StartTime", config.timerentry.starttime)) - self.list.append(getConfigListEntry("EndDate", config.timerentry.enddate)) + if (config.timerentry.type.value == 0): # once + self.list.append(getConfigListEntry("EndDate", config.timerentry.enddate)) self.list.append(getConfigListEntry("EndTime", config.timerentry.endtime)) -# self.list.append(getConfigListEntry("Weekday", config.timerentry.weekday)) + + self.list.append(getConfigListEntry("Channel", config.timerentry.service)) self["config"].list = self.list self["config"].l.setList(self.list) def newConfig(self): print self["config"].getCurrent() - if self["config"].getCurrent()[0] == "Type of scan": + if self["config"].getCurrent()[0] == "TimerType": self.createSetup() - if self["config"].getCurrent()[0] == "Tuner": + if self["config"].getCurrent()[0] == "Frequency": self.createSetup() def keyLeft(self): self["config"].handleKey(config.key["prevElement"]) self.newConfig() + def keyRightCallback(self, configPath): + currentConfigPath = self["config"].getCurrent()[1].parent.getConfigPath() + # check if we are still on the same config entry + if (currentConfigPath == configPath): + self.keyRight() + def keyRight(self): self["config"].handleKey(config.key["nextElement"]) self.newConfig() @@ -77,14 +144,17 @@ class TimerEntry(Screen): if (self["config"].getCurrent()[1].parent.enabled == True): self["config"].handleKey(config.key[str(number)]) - def keyGo(self): - for x in self["config"].list: - x[1].save() - self.session.openWithCallback(self.keyCancel, ServiceScan) + def getTimestamp(self, date, time): + d = localtime(date) # for gettin indexes 0(year), 1(month) and 2(day) + dt = datetime(d.tm_year, d.tm_mon, d.tm_mday, time[0], time[1]) + print dt + return int(mktime(dt.timetuple())) - #self.close() + def keyGo(self): + if (config.timerentry.type.value == 0): # once + self.timer.begin = self.getTimestamp(config.timerentry.startdate.value, config.timerentry.starttime.value) + self.timer.end = self.getTimestamp(config.timerentry.enddate.value, config.timerentry.endtime.value) + self.close((True, self.timer)) def keyCancel(self): - for x in self["config"].list: - x[1].cancel() - self.close() \ No newline at end of file + self.close((False,)) \ No newline at end of file