mirror of
https://github.com/ynput/ayon-core.git
synced 2026-01-01 16:34:53 +01:00
idle manager register Qaction and set icon to failed when service fails
This commit is contained in:
parent
f5e5e407d3
commit
a40818816a
1 changed files with 19 additions and 12 deletions
|
|
@ -17,9 +17,14 @@ class IdleManager(QtCore.QThread):
|
||||||
super(IdleManager, self).__init__()
|
super(IdleManager, self).__init__()
|
||||||
self.log = Logger().get_logger(self.__class__.__name__)
|
self.log = Logger().get_logger(self.__class__.__name__)
|
||||||
self.signal_reset_timer.connect(self._reset_time)
|
self.signal_reset_timer.connect(self._reset_time)
|
||||||
self._failed = False
|
self.qaction = None
|
||||||
|
self.failed_icon = None
|
||||||
self._is_running = False
|
self._is_running = False
|
||||||
|
|
||||||
|
def set_qaction(self, qaction, failed_icon):
|
||||||
|
self.qaction = qaction
|
||||||
|
self.failed_icon = failed_icon
|
||||||
|
|
||||||
def tray_start(self):
|
def tray_start(self):
|
||||||
self.start()
|
self.start()
|
||||||
|
|
||||||
|
|
@ -34,10 +39,6 @@ class IdleManager(QtCore.QThread):
|
||||||
self.time_signals[emit_time] = []
|
self.time_signals[emit_time] = []
|
||||||
self.time_signals[emit_time].append(signal)
|
self.time_signals[emit_time].append(signal)
|
||||||
|
|
||||||
@property
|
|
||||||
def failed(self):
|
|
||||||
return self._failed
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def is_running(self):
|
def is_running(self):
|
||||||
return self._is_running
|
return self._is_running
|
||||||
|
|
@ -55,20 +56,26 @@ class IdleManager(QtCore.QThread):
|
||||||
thread_mouse.start()
|
thread_mouse.start()
|
||||||
thread_keyboard = KeyboardThread(self.signal_reset_timer)
|
thread_keyboard = KeyboardThread(self.signal_reset_timer)
|
||||||
thread_keyboard.start()
|
thread_keyboard.start()
|
||||||
while self._is_running:
|
try:
|
||||||
self.idle_time += 1
|
while self.is_running:
|
||||||
if self.idle_time in self.time_signals:
|
self.idle_time += 1
|
||||||
for signal in self.time_signals[self.idle_time]:
|
if self.idle_time in self.time_signals:
|
||||||
signal.emit()
|
for signal in self.time_signals[self.idle_time]:
|
||||||
time.sleep(1)
|
signal.emit()
|
||||||
|
time.sleep(1)
|
||||||
|
except Exception:
|
||||||
|
self.log.warning(
|
||||||
|
'Idle Manager service has failed', exc_info=True
|
||||||
|
)
|
||||||
|
|
||||||
|
if self.qaction and self.failed_icon:
|
||||||
|
self.qaction.setIcon(self.failed_icon)
|
||||||
thread_mouse.signal_stop.emit()
|
thread_mouse.signal_stop.emit()
|
||||||
thread_mouse.terminate()
|
thread_mouse.terminate()
|
||||||
thread_mouse.wait()
|
thread_mouse.wait()
|
||||||
thread_keyboard.signal_stop.emit()
|
thread_keyboard.signal_stop.emit()
|
||||||
thread_keyboard.terminate()
|
thread_keyboard.terminate()
|
||||||
thread_keyboard.wait()
|
thread_keyboard.wait()
|
||||||
self._failed = True
|
|
||||||
self._is_running = False
|
self._is_running = False
|
||||||
self.log.info('IdleManager has stopped')
|
self.log.info('IdleManager has stopped')
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue