Merge branch 'master' of /home/tmbinc/enigma2-git into tmbinc/FixTimingBugs
[vuplus_dvbapp] / lib / python / Screens / Standby.py
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 enigma import eDVBVolumecontrol
7
8 inStandby = None
9
10 class Standby(Screen):
11         def Power(self):
12                 print "leave standby"
13                 #set input to encoder
14                 self.avswitch.setInput("ENCODER")
15                 #restart last played service
16                 #unmute adc
17                 self.leaveMute()
18                 #set brightness of lcd
19                 config.lcd.bright.apply()
20                 #kill me
21                 self.close(True)
22
23         def setMute(self):
24                 if (eDVBVolumecontrol.getInstance().isMuted()):
25                         self.wasMuted = 1
26                         print "mute already active"
27                 else:   
28                         self.wasMuted = 0
29                         eDVBVolumecontrol.getInstance().volumeToggleMute()
30
31         def leaveMute(self):
32                 if self.wasMuted == 0:
33                         eDVBVolumecontrol.getInstance().volumeToggleMute()
34
35         def __init__(self, session):
36                 Screen.__init__(self, session)
37                 self.avswitch = AVSwitch()
38
39                 print "enter standby"
40
41                 self["actions"] = ActionMap( [ "StandbyActions" ],
42                 {
43                         "power": self.Power
44                 }, -1)
45
46                 #mute adc
47                 self.setMute()
48                 #get currently playing service reference
49                 self.prev_running_service = self.session.nav.getCurrentlyPlayingServiceReference()
50                 #stop actual played dvb-service
51                 self.session.nav.stopService()
52                 #set input to vcr scart
53                 if SystemInfo["ScartSwitch"]:
54                         self.avswitch.setInput("SCART")
55                 else:
56                         self.avswitch.setInput("AUX")
57                 #set lcd brightness to standby value
58                 config.lcd.standby.apply()
59                 self.onShow.append(self.__onShow)
60                 self.onHide.append(self.__onHide)
61                 self.onClose.append(self.__onClose)
62
63         def __onClose(self):
64                 if self.prev_running_service:
65                         self.session.nav.playService(self.prev_running_service)
66
67         def createSummary(self):
68                 return StandbySummary
69
70         def __onShow(self):
71                 global inStandby
72                 inStandby = self
73
74         def __onHide(self):
75                 global inStandby
76                 inStandby = None
77
78 class StandbySummary(Screen):
79         skin = """
80         <screen position="0,0" size="132,64">
81                 <widget source="global.CurrentTime" render="Label" position="0,0" size="132,64" font="Regular;40" halign="center">
82                         <convert type="ClockToText" />
83                 </widget>
84                 <widget source="session.RecordState" render="FixedLabel" text=" " position="0,0" size="132,64" zPosition="1" >
85                         <convert type="ConfigEntryTest">config.usage.blinking_display_clock_during_recording,True,CheckSourceBoolean</convert>
86                         <convert type="ConditionalShowHide">Blink</convert>
87                 </widget>
88         </screen>"""
89
90         def __init__(self, session, parent):
91                 Screen.__init__(self, session)
92
93 from enigma import quitMainloop, iRecordableService
94 from Screens.MessageBox import MessageBox
95 from time import time
96 from Components.Task import job_manager
97
98 inTryQuitMainloop = False
99
100 class TryQuitMainloop(MessageBox):
101         def __init__(self, session, retvalue=1, timeout=-1, default_yes = True):
102                 self.retval=retvalue
103                 recordings = len(session.nav.getRecordings())
104                 jobs = len(job_manager.getPendingJobs())
105                 self.connected = False
106                 reason = ""
107                 next_rec_time = -1
108                 if not recordings:
109                         next_rec_time = session.nav.RecordTimer.getNextRecordingTime()  
110                 if recordings or (next_rec_time > 0 and (next_rec_time - time()) < 360):
111                         reason = _("Recording(s) are in progress or coming up in few seconds!") + '\n'
112                 if jobs:
113                         if jobs == 1:
114                                 job = job_manager.getPendingJobs()[0]
115                                 reason += "%s: %s (%d%%)\n" % (job.getStatustext(), job.name, int(100*job.progress/float(job.end)))
116                         else:
117                                 reason += (_("%d jobs are running in the background!") % jobs) + '\n'
118                 if reason:
119                         if retvalue == 1:
120                                 MessageBox.__init__(self, session, reason+_("Really shutdown now?"), type = MessageBox.TYPE_YESNO, timeout = timeout, default = default_yes)
121                         elif retvalue == 2:
122                                 MessageBox.__init__(self, session, reason+_("Really reboot now?"), type = MessageBox.TYPE_YESNO, timeout = timeout, default = default_yes)
123                         elif retvalue == 4:
124                                 pass
125                         else:
126                                 MessageBox.__init__(self, session, reason+_("Really restart now?"), type = MessageBox.TYPE_YESNO, timeout = timeout, default = default_yes)
127                         self.skinName = "MessageBox"
128                         session.nav.record_event.append(self.getRecordEvent)
129                         self.connected = True
130                         self.onShow.append(self.__onShow)
131                         self.onHide.append(self.__onHide)
132                 else:
133                         self.skin = """<screen position="0,0" size="0,0"/>"""
134                         Screen.__init__(self, session)
135                         self.close(True)
136
137         def getRecordEvent(self, recservice, event):
138                 if event == iRecordableService.evEnd:
139                         recordings = self.session.nav.getRecordings()
140                         if not len(recordings): # no more recordings exist
141                                 rec_time = self.session.nav.RecordTimer.getNextRecordingTime()
142                                 if rec_time > 0 and (rec_time - time()) < 360:
143                                         self.initTimeout(360) # wait for next starting timer
144                                         self.startTimer()
145                                 else:
146                                         self.close(True) # immediate shutdown
147                 elif event == iRecordableService.evStart:
148                         self.stopTimer()
149
150         def close(self, value):
151                 if self.connected:
152                         self.conntected=False
153                         self.session.nav.record_event.remove(self.getRecordEvent)
154                 if value:
155                         quitMainloop(self.retval)
156                 else:
157                         MessageBox.close(self, True)
158
159         def __onShow(self):
160                 global inTryQuitMainloop
161                 inTryQuitMainloop = True
162
163         def __onHide(self):
164                 global inTryQuitMainloop
165                 inTryQuitMainloop = False