mirror of
https://github.com/ynput/ayon-core.git
synced 2026-01-01 16:34:53 +01:00
180 lines
5.8 KiB
Python
180 lines
5.8 KiB
Python
from pype.api import Logger
|
|
|
|
|
|
class TimersManager:
|
|
""" Handles about Timers.
|
|
|
|
Should be able to start/stop all timers at once.
|
|
If IdleManager is imported then is able to handle about stop timers
|
|
when user idles for a long time (set in presets).
|
|
"""
|
|
|
|
# Presetable attributes
|
|
# - when timer will stop if idle manager is running (minutes)
|
|
full_time = 15
|
|
# - how many minutes before the timer is stopped will popup the message
|
|
message_time = 0.5
|
|
|
|
def __init__(self, tray_widget, main_widget):
|
|
self.log = Logger().get_logger(self.__class__.__name__)
|
|
|
|
self.modules = []
|
|
self.is_running = False
|
|
self.last_task = None
|
|
|
|
self.tray_widget = tray_widget
|
|
self.main_widget = main_widget
|
|
|
|
self.idle_man = None
|
|
self.signal_handler = None
|
|
|
|
self.trat_init(tray_widget, main_widget)
|
|
|
|
def trat_init(self, tray_widget, main_widget):
|
|
from .widget_user_idle import WidgetUserIdle, SignalHandler
|
|
self.widget_user_idle = WidgetUserIdle(self, tray_widget)
|
|
self.signal_handler = SignalHandler(self)
|
|
|
|
def set_signal_times(self):
|
|
try:
|
|
full_time = int(self.full_time * 60)
|
|
message_time = int(self.message_time * 60)
|
|
self.time_show_message = full_time - message_time
|
|
self.time_stop_timer = full_time
|
|
return True
|
|
except Exception:
|
|
self.log.error("Couldn't set timer signals.", exc_info=True)
|
|
|
|
def add_module(self, module):
|
|
""" Adds module to context
|
|
|
|
Module must have implemented methods:
|
|
- ``start_timer_manager(data)``
|
|
- ``stop_timer_manager()``
|
|
"""
|
|
self.modules.append(module)
|
|
|
|
def start_timers(self, data):
|
|
'''
|
|
:param data: basic information needed to start any timer
|
|
:type data: dict
|
|
..note::
|
|
Dictionary "data" should contain:
|
|
- project_name(str) - Name of Project
|
|
- hierarchy(list/tuple) - list of parents(except project)
|
|
- task_type(str)
|
|
- task_name(str)
|
|
|
|
Example:
|
|
- to run timers for task in
|
|
'C001_BackToPast/assets/characters/villian/Lookdev BG'
|
|
- input data should contain:
|
|
.. code-block:: Python
|
|
data = {
|
|
'project_name': 'C001_BackToPast',
|
|
'hierarchy': ['assets', 'characters', 'villian'],
|
|
'task_type': 'lookdev',
|
|
'task_name': 'Lookdev BG'
|
|
}
|
|
'''
|
|
if len(data['hierarchy']) < 1:
|
|
self.log.error((
|
|
'Not allowed action in Pype!!'
|
|
' Timer has been launched on task which is child of Project.'
|
|
))
|
|
return
|
|
|
|
self.last_task = data
|
|
|
|
for module in self.modules:
|
|
module.start_timer_manager(data)
|
|
self.is_running = True
|
|
|
|
def restart_timers(self):
|
|
if self.last_task is not None:
|
|
self.start_timers(self.last_task)
|
|
|
|
def stop_timers(self):
|
|
if self.is_running is False:
|
|
return
|
|
self.widget_user_idle.bool_not_stopped = False
|
|
self.widget_user_idle.refresh_context()
|
|
for module in self.modules:
|
|
module.stop_timer_manager()
|
|
self.is_running = False
|
|
|
|
def process_modules(self, modules):
|
|
""" Gives ability to connect with imported modules from TrayManager.
|
|
|
|
:param modules: All imported modules from TrayManager
|
|
:type modules: dict
|
|
"""
|
|
|
|
if 'IdleManager' in modules:
|
|
if self.set_signal_times() is True:
|
|
self.register_to_idle_manager(modules['IdleManager'])
|
|
|
|
def time_callback(self, int_def):
|
|
if not self.signal_handler:
|
|
return
|
|
|
|
if int_def == 0:
|
|
self.signal_handler.signal_show_message.emit()
|
|
elif int_def == 1:
|
|
self.signal_handler.signal_change_label.emit()
|
|
elif int_def == 2:
|
|
self.signal_handler.signal_stop_timers.emit()
|
|
|
|
def register_to_idle_manager(self, man_obj):
|
|
self.idle_man = man_obj
|
|
|
|
# Time when message is shown
|
|
self.idle_man.add_time_callback(
|
|
self.time_show_message,
|
|
lambda: self.time_callback(0)
|
|
)
|
|
|
|
# Times when idle is between show widget and stop timers
|
|
show_to_stop_range = range(
|
|
self.time_show_message - 1, self.time_stop_timer
|
|
)
|
|
for num in show_to_stop_range:
|
|
self.idle_man.add_time_callback(
|
|
num, lambda: self.time_callback(1)
|
|
)
|
|
# Times when widget is already shown and user restart idle
|
|
shown_and_moved_range = range(
|
|
self.time_stop_timer - self.time_show_message
|
|
)
|
|
for num in shown_and_moved_range:
|
|
self.idle_man.add_time_callback(
|
|
num, lambda: self.time_callback(1)
|
|
)
|
|
|
|
# Time when timers are stopped
|
|
self.idle_man.add_time_callback(
|
|
self.time_stop_timer,
|
|
lambda: self.time_callback(2)
|
|
)
|
|
|
|
def change_label(self):
|
|
if self.is_running is False:
|
|
return
|
|
if not self.idle_man or self.widget_user_idle.bool_is_showed is False:
|
|
return
|
|
|
|
if self.idle_man.idle_time > self.time_show_message:
|
|
value = self.time_stop_timer - self.idle_man.idle_time
|
|
else:
|
|
value = 1 + (
|
|
self.time_stop_timer -
|
|
self.time_show_message -
|
|
self.idle_man.idle_time
|
|
)
|
|
self.widget_user_idle.change_count_widget(value)
|
|
|
|
def show_message(self):
|
|
if self.is_running is False:
|
|
return
|
|
if self.widget_user_idle.bool_is_showed is False:
|
|
self.widget_user_idle.show()
|