1 from Screen import Screen
2 from Components.ActionMap import ActionMap
3 from Components.config import config
4 from Components.AVSwitch import AVSwitch
5 from Components.SystemInfo import SystemInfo
6 from GlobalActions import globalActionMap
7 from enigma import eDVBVolumecontrol, eDVBLocalTimeHandler, eServiceReference
11 class Standby(Screen):
15 self.avswitch.setInput("ENCODER")
16 #restart last played service
23 if (eDVBVolumecontrol.getInstance().isMuted()):
25 print "mute already active"
28 eDVBVolumecontrol.getInstance().volumeToggleMute()
31 if self.wasMuted == 0:
32 eDVBVolumecontrol.getInstance().volumeToggleMute()
34 def __init__(self, session):
35 Screen.__init__(self, session)
36 self.avswitch = AVSwitch()
40 self["actions"] = ActionMap( [ "StandbyActions" ],
45 globalActionMap.setEnabled(False)
50 self.paused_service = None
51 self.prev_running_service = None
52 self.connected_time_handler = False
54 if self.session.current_dialog:
55 if self.session.current_dialog.ALLOW_SUSPEND == Screen.SUSPEND_STOPS:
56 #get currently playing service reference
57 self.prev_running_service = self.session.nav.getCurrentlyPlayingServiceReference()
58 #stop actual played dvb-service
59 self.session.nav.stopService()
60 elif self.session.current_dialog.ALLOW_SUSPEND == Screen.SUSPEND_PAUSES:
61 self.paused_service = self.session.current_dialog
62 self.paused_service.pauseService()
64 #set input to vcr scart
65 if SystemInfo["ScartSwitch"]:
66 self.avswitch.setInput("SCART")
68 self.avswitch.setInput("AUX")
69 self.onFirstExecBegin.append(self.__onFirstExecBegin)
70 self.onClose.append(self.__onClose)
72 if config.misc.standbyCounter.value == 0 and config.misc.useTransponderTime.value:
73 th = eDVBLocalTimeHandler.getInstance()
75 refstr = config.servicelist.lastmode.value == 'tv' and config.tv.lastservice.value or config.radio.lastservice.value
76 ref = eServiceReference(refstr)
78 th.m_timeUpdated.get().append(self.timeReady)
79 self.connected_time_handler = True
80 self.session.nav.playService(ref)
83 if self.connected_time_handler:
84 th = eDVBLocalTimeHandler.getInstance()
85 th.m_timeUpdated.get().remove(self.timeReady)
86 self.connected_time_handler = False
87 self.session.nav.stopService()
95 if not self.session.shutdown:
96 if self.prev_running_service:
97 self.session.nav.playService(self.prev_running_service)
98 elif self.paused_service:
99 self.paused_service.unPauseService()
100 self.session.screen["Standby"].boolean = False
101 globalActionMap.setEnabled(True)
103 def __onFirstExecBegin(self):
106 self.session.screen["Standby"].boolean = True
107 config.misc.standbyCounter.value += 1
109 def createSummary(self):
110 return StandbySummary
112 class StandbySummary(Screen):
114 <screen position="0,0" size="132,64">
115 <widget source="global.CurrentTime" render="Label" position="0,0" size="132,64" font="Regular;40" halign="center">
116 <convert type="ClockToText" />
118 <widget source="session.RecordState" render="FixedLabel" text=" " position="0,0" size="132,64" zPosition="1" >
119 <convert type="ConfigEntryTest">config.usage.blinking_display_clock_during_recording,True,CheckSourceBoolean</convert>
120 <convert type="ConditionalShowHide">Blink</convert>
124 from enigma import quitMainloop, iRecordableService
125 from Screens.MessageBox import MessageBox
126 from time import time
127 from Components.Task import job_manager
129 inTryQuitMainloop = False
131 class TryQuitMainloop(MessageBox):
132 def __init__(self, session, retvalue=1, timeout=-1, default_yes = True):
134 recordings = session.nav.getRecordings()
135 jobs = len(job_manager.getPendingJobs())
136 self.connected = False
140 next_rec_time = session.nav.RecordTimer.getNextRecordingTime()
141 if recordings or (next_rec_time > 0 and (next_rec_time - time()) < 360):
142 reason = _("Recording(s) are in progress or coming up in few seconds!") + '\n'
145 job = job_manager.getPendingJobs()[0]
146 reason += "%s: %s (%d%%)\n" % (job.getStatustext(), job.name, int(100*job.progress/float(job.end)))
148 reason += (_("%d jobs are running in the background!") % jobs) + '\n'
151 MessageBox.__init__(self, session, reason+_("Really shutdown now?"), type = MessageBox.TYPE_YESNO, timeout = timeout, default = default_yes)
153 MessageBox.__init__(self, session, reason+_("Really reboot now?"), type = MessageBox.TYPE_YESNO, timeout = timeout, default = default_yes)
157 MessageBox.__init__(self, session, reason+_("Really restart now?"), type = MessageBox.TYPE_YESNO, timeout = timeout, default = default_yes)
158 self.skinName = "MessageBox"
159 session.nav.record_event.append(self.getRecordEvent)
160 self.connected = True
161 self.onShow.append(self.__onShow)
162 self.onHide.append(self.__onHide)
164 self.skin = """<screen name="TryQuitMainloop" position="0,0" size="0,0" flags="wfNoBorder"/>"""
165 Screen.__init__(self, session)
168 def getRecordEvent(self, recservice, event):
169 if event == iRecordableService.evEnd:
170 recordings = self.session.nav.getRecordings()
171 if not recordings: # no more recordings exist
172 rec_time = self.session.nav.RecordTimer.getNextRecordingTime()
173 if rec_time > 0 and (rec_time - time()) < 360:
174 self.initTimeout(360) # wait for next starting timer
177 self.close(True) # immediate shutdown
178 elif event == iRecordableService.evStart:
181 def close(self, value):
183 self.conntected=False
184 self.session.nav.record_event.remove(self.getRecordEvent)
186 quitMainloop(self.retval)
188 MessageBox.close(self, True)
191 global inTryQuitMainloop
192 inTryQuitMainloop = True
195 global inTryQuitMainloop
196 inTryQuitMainloop = False