Compare screen time with last screen time

This commit is contained in:
Gobinath 2019-03-12 19:55:03 -04:00
parent ae35813f64
commit 09ded85ec8
1 changed files with 20 additions and 2 deletions

View File

@ -30,6 +30,7 @@ no_of_cycles = -1
session = None
safe_eyes_start_time = datetime.datetime.now()
total_idle_time = 0
last_screen_time = -1
reset_interval = 86400 # 24 hours in seconds
@ -45,6 +46,7 @@ def init(ctx, safeeyes_config, plugin_config):
global reset_interval
global safe_eyes_start_time
global total_idle_time
global last_screen_time
logging.debug('Initialize Health Stats plugin')
context = ctx
reset_interval = plugin_config.get('statistics_reset_interval', 24) * 3600
@ -55,12 +57,14 @@ def init(ctx, safeeyes_config, plugin_config):
'no_of_breaks': 0,
'no_of_cycles': -1,
'safe_eyes_start_time': safe_eyes_start_time.strftime("%Y-%m-%d %H:%M:%S"),
'total_idle_time': 0}
'total_idle_time': 0,
'last_screen_time': -1}
context['session']['plugin']['healthstats'] = session
no_of_skipped_breaks = session.get('no_of_skipped_breaks', 0)
no_of_breaks = session.get('no_of_breaks', 0)
no_of_cycles = session.get('no_of_cycles', -1)
total_idle_time = session.get('total_idle_time', 0)
last_screen_time = session.get('last_screen_time', -1)
str_time = session.get('safe_eyes_start_time', None)
if str_time:
safe_eyes_start_time = datetime.datetime.strptime(str_time, "%Y-%m-%d %H:%M:%S")
@ -90,6 +94,7 @@ def get_widget_title(break_obj):
session['no_of_cycles'] = no_of_cycles
session['safe_eyes_start_time'] = safe_eyes_start_time.strftime("%Y-%m-%d %H:%M:%S")
session['total_idle_time'] = total_idle_time
session['last_screen_time'] = last_screen_time
return _('Health Statistics')
@ -99,12 +104,14 @@ def _reset_stats():
global safe_eyes_start_time
global total_idle_time
global no_of_skipped_breaks
global last_screen_time
current_time = datetime.datetime.now()
total_duration_sec = (current_time - safe_eyes_start_time).total_seconds()
if total_duration_sec >= reset_interval:
total_duration_sec -= reset_interval
safe_eyes_start_time = current_time - \
datetime.timedelta(seconds=total_duration_sec)
last_screen_time = round((total_duration_sec - total_idle_time) / 60)
total_idle_time = 0
no_of_breaks = 0
no_of_cycles = 0
@ -114,6 +121,7 @@ def _reset_stats():
session['no_of_skipped_breaks'] = 0
session['safe_eyes_start_time'] = safe_eyes_start_time.strftime("%Y-%m-%d %H:%M:%S")
session['total_idle_time'] = total_idle_time
session['last_screen_time'] = last_screen_time
return total_duration_sec
@ -132,7 +140,17 @@ def get_widget_content(break_obj):
else:
# Healthy behavior -> Green heart
heart = '💚'
return "{}\tBREAKS: {}\tSKIPPED: {}\tCYCLES: {}\tSCREEN TIME: {}".format(heart, no_of_breaks, no_of_skipped_breaks, no_of_cycles, time_format)
if last_screen_time < 0:
screen_time_diff = ''
else:
hrs_diff, mins_diff = divmod(abs(screen_time - last_screen_time), 60)
symbol = ''
if screen_time > last_screen_time:
symbol = '+'
elif screen_time < last_screen_time:
symbol = '-'
screen_time_diff = ' ( {}{:02d}:{:02d} )'.format(symbol, hrs_diff, mins_diff)
return "{}\tBREAKS: {}\tSKIPPED: {}\tCYCLES: {}\tSCREEN TIME: {}{}".format(heart, no_of_breaks, no_of_skipped_breaks, no_of_cycles, time_format, screen_time_diff)
def on_start():