dont show display contrast setting in display setup when a oled is detected
[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 enigma import eDVBVolumecontrol
6 from Components.Sources.Source import ObsoleteSource
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                 if self.prev_running_service:
17                         self.session.nav.playService(self.prev_running_service)
18                 #unmute adc
19                 self.leaveMute()
20                 #set brightness of lcd
21                 config.lcd.bright.apply()
22                 #kill me
23                 self.close(True)
24
25         def setMute(self):
26                 if (eDVBVolumecontrol.getInstance().isMuted()):
27                         self.wasMuted = 1
28                         print "mute already active"
29                 else:   
30                         self.wasMuted = 0
31                         eDVBVolumecontrol.getInstance().volumeToggleMute()
32
33         def leaveMute(self):
34                 if self.wasMuted == 0:
35                         eDVBVolumecontrol.getInstance().volumeToggleMute()
36
37         def __init__(self, session):
38                 Screen.__init__(self, session)
39                 self.avswitch = AVSwitch()
40
41                 print "enter standby"
42
43                 self["actions"] = ActionMap( [ "StandbyActions" ],
44                 {
45                         "power": self.Power
46                 }, -1)
47
48                 #mute adc
49                 self.setMute()
50                 #get currently playing service reference
51                 self.prev_running_service = self.session.nav.getCurrentlyPlayingServiceReference()
52                 #stop actual played dvb-service
53                 self.session.nav.stopService()
54                 #set input to vcr scart
55                 self.avswitch.setInput("SCART")
56                 #set lcd brightness to standby value
57                 config.lcd.standby.apply()
58                 self.onShow.append(self.__onShow)
59                 self.onHide.append(self.__onHide)
60
61         def createSummary(self):
62                 return StandbySummary
63
64         def __onShow(self):
65                 global inStandby
66                 inStandby = self
67
68         def __onHide(self):
69                 global inStandby
70                 inStandby = None
71
72 class StandbySummary(Screen):
73         skin = """
74         <screen position="0,0" size="132,64">
75                 <widget source="global.CurrentTime" render="Label" position="0,0" size="132,64" font="Regular;40" halign="center">
76                         <convert type="ClockToText" />
77                 </widget>
78                 <widget source="session.RecordState" render="FixedLabel" text=" " position="0,0" size="132,64" zPosition="1" >
79                         <convert type="ConfigEntryTest">config.usage.blinking_display_clock_during_recording,True,CheckSourceBoolean</convert>
80                         <convert type="ConditionalShowHide">Blink</convert>
81                 </widget>
82         </screen>"""
83
84         def __init__(self, session, parent):
85                 Screen.__init__(self, session)
86                 self["CurrentTime"] = ObsoleteSource(new_source = "global.CurrentTime", removal_date = "2008-01")
87
88 from enigma import quitMainloop, iRecordableService
89 from Screens.MessageBox import MessageBox
90 from time import time
91
92 inTryQuitMainloop = False
93
94 class TryQuitMainloop(MessageBox):
95         def __init__(self, session, retvalue=1, timeout=-1):
96                 self.retval=retvalue
97                 recordings = len(session.nav.getRecordings())
98                 self.connected = False
99                 next_rec_time = -1
100                 if not recordings:
101                         next_rec_time = session.nav.RecordTimer.getNextRecordingTime()
102                 if recordings or (next_rec_time > 0 and (next_rec_time - time()) < 360):
103                         if retvalue == 1:
104                                 MessageBox.__init__(self, session, _("Recording(s) are in progress or coming up in few seconds... really shutdown now?"), type = MessageBox.TYPE_YESNO, timeout = timeout)
105                         elif retvalue == 2:
106                                 MessageBox.__init__(self, session, _("Recording(s) are in progress or coming up in few seconds... really reboot now?"), type = MessageBox.TYPE_YESNO, timeout = timeout)
107                         elif retvalue == 4:
108                                 pass
109                         else:
110                                 MessageBox.__init__(self, session, _("Recording(s) are in progress or coming up in few seconds... really restart now?"), type = MessageBox.TYPE_YESNO, timeout = timeout)
111                         self.skinName = "MessageBox"
112                         session.nav.record_event.append(self.getRecordEvent)
113                         self.connected = True
114                         self.onShow.append(self.__onShow)
115                         self.onHide.append(self.__onHide)
116                 else:
117                         self.skin = """<screen position="0,0" size="0,0"/>"""
118                         Screen.__init__(self, session)
119                         self.close(True)
120
121         def getRecordEvent(self, recservice, event):
122                 if event == iRecordableService.evEnd:
123                         recordings = self.session.nav.getRecordings()
124                         if not len(recordings): # no more recordings exist
125                                 rec_time = self.session.nav.RecordTimer.getNextRecordingTime()
126                                 if rec_time > 0 and (rec_time - time()) < 360:
127                                         self.initTimeout(360) # wait for next starting timer
128                                         self.startTimer()
129                                 else:
130                                         self.close(True) # immediate shutdown
131                 elif event == iRecordableService.evStart:
132                         self.stopTimer()
133
134         def close(self, value):
135                 if self.connected:
136                         self.conntected=False
137                         self.session.nav.record_event.remove(self.getRecordEvent)
138                 if value:
139                         quitMainloop(self.retval)
140                 else:
141                         MessageBox.close(self, True)
142
143         def __onShow(self):
144                 global inTryQuitMainloop
145                 inTryQuitMainloop = True
146
147         def __onHide(self):
148                 global inTryQuitMainloop
149                 inTryQuitMainloop = False