improved session completion date
This commit is contained in:
@@ -104,7 +104,8 @@ def get_session_metrics(ps):
|
|||||||
completedatev = ''
|
completedatev = ''
|
||||||
statusv = 0
|
statusv = 0
|
||||||
|
|
||||||
ws = Workout.objects.filter(user=r,plannedsession=ps)
|
ws = Workout.objects.filter(user=r,plannedsession=ps).order_by("date")
|
||||||
|
|
||||||
if len(ws) != 0:
|
if len(ws) != 0:
|
||||||
for w in ws:
|
for w in ws:
|
||||||
distancev += w.distance
|
distancev += w.distance
|
||||||
@@ -112,8 +113,11 @@ def get_session_metrics(ps):
|
|||||||
trimpv += dataprep.workout_trimp(w)
|
trimpv += dataprep.workout_trimp(w)
|
||||||
rscorev += dataprep.workout_rscore(w)[0]
|
rscorev += dataprep.workout_rscore(w)[0]
|
||||||
|
|
||||||
ratio,statusv = is_session_complete_ws(ws,ps)
|
ratio,statusv,completiondate = is_session_complete_ws(ws,ps)
|
||||||
completedatev = ws[0].date.strftime('%Y-%m-%d')
|
try:
|
||||||
|
completedatev = completiondate.strftime('%Y-%m-%d')
|
||||||
|
except AttributeError:
|
||||||
|
completedatev = ''
|
||||||
durationv /= 60.
|
durationv /= 60.
|
||||||
|
|
||||||
trimp.append(int(trimpv))
|
trimp.append(int(trimpv))
|
||||||
@@ -139,16 +143,35 @@ def get_session_metrics(ps):
|
|||||||
return thedict
|
return thedict
|
||||||
|
|
||||||
def is_session_complete_ws(ws,ps):
|
def is_session_complete_ws(ws,ps):
|
||||||
|
ws = ws.order_by("date")
|
||||||
if len(ws)==0:
|
if len(ws)==0:
|
||||||
today = date.today()
|
today = date.today()
|
||||||
if today > ps.enddate:
|
if today > ps.enddate:
|
||||||
status = 'missed'
|
status = 'missed'
|
||||||
ratio = 0
|
ratio = 0
|
||||||
return ratio,status
|
return ratio,status,None
|
||||||
else:
|
else:
|
||||||
return 0,'not done'
|
return 0,'not done',None
|
||||||
|
|
||||||
|
value = ps.sessionvalue
|
||||||
|
if ps.sessionunit == 'min':
|
||||||
|
value *= 60.
|
||||||
|
elif ps.sessionunit == 'km':
|
||||||
|
value *= 1000.
|
||||||
|
|
||||||
|
cratiomin = 1
|
||||||
|
cratiomax = 1
|
||||||
|
if ps.criterium == 'none':
|
||||||
|
if ps.sessiontype == 'session':
|
||||||
|
cratiomin = 0.8
|
||||||
|
cratiomax = 1.2
|
||||||
|
else:
|
||||||
|
cratiomin = 0.9167
|
||||||
|
cratiomax = 1.0833
|
||||||
|
|
||||||
|
|
||||||
score = 0
|
score = 0
|
||||||
|
completiondate = None
|
||||||
for w in ws:
|
for w in ws:
|
||||||
if ps.sessionmode == 'distance':
|
if ps.sessionmode == 'distance':
|
||||||
score += w.distance
|
score += w.distance
|
||||||
@@ -161,12 +184,8 @@ def is_session_complete_ws(ws,ps):
|
|||||||
elif ps.sessionmode == 'rScore':
|
elif ps.sessionmode == 'rScore':
|
||||||
rscore = dataprep.workout_rscore(w)[0]
|
rscore = dataprep.workout_rscore(w)[0]
|
||||||
score += rscore
|
score += rscore
|
||||||
|
if not completiondate and score>=cratiomin*value:
|
||||||
value = ps.sessionvalue
|
completiondate = w.date
|
||||||
if ps.sessionunit == 'min':
|
|
||||||
value *= 60.
|
|
||||||
elif ps.sessionunit == 'km':
|
|
||||||
value *= 1000.
|
|
||||||
|
|
||||||
ratio = score/float(value)
|
ratio = score/float(value)
|
||||||
|
|
||||||
@@ -175,49 +194,47 @@ def is_session_complete_ws(ws,ps):
|
|||||||
if ps.sessiontype in ['session','cycletarget']:
|
if ps.sessiontype in ['session','cycletarget']:
|
||||||
if ps.criterium == 'exact':
|
if ps.criterium == 'exact':
|
||||||
if ratio == 1.0:
|
if ratio == 1.0:
|
||||||
return ratio,'completed'
|
return ratio,'completed',completiondate
|
||||||
else:
|
else:
|
||||||
return ratio,'partial'
|
return ratio,'partial',completiondate
|
||||||
elif ps.criterium == 'minimum':
|
elif ps.criterium == 'minimum':
|
||||||
if ratio >= 1.0:
|
if ratio >= 1.0:
|
||||||
return ratio,'completed'
|
return ratio,'completed',completiondate
|
||||||
else:
|
else:
|
||||||
return ratio,'partial'
|
return ratio,'partial',completiondate
|
||||||
else:
|
else:
|
||||||
if ratio>0.8 and ratio<1.2 and ps.sessiontype=='session':
|
if ratio>cratiomin and ratio<cratiomax:
|
||||||
return ratio,'completed'
|
return ratio,'completed',completiondate
|
||||||
elif ratio>0.9167 and ratio<1.0833 and ps.sessiontype=='cycletarget':
|
|
||||||
return ratio,'completed'
|
|
||||||
else:
|
else:
|
||||||
return ratio,'partial'
|
return ratio,'partial',completiondate
|
||||||
elif ps.sessiontype == 'test':
|
elif ps.sessiontype == 'test':
|
||||||
if ratio==1.0:
|
if ratio==1.0:
|
||||||
return ratio,'completed'
|
return ratio,'completed',completiondate
|
||||||
else:
|
else:
|
||||||
return ratio,'partial'
|
return ratio,'partial',completiondate
|
||||||
elif ps.sessiontype == 'challenge':
|
elif ps.sessiontype == 'challenge':
|
||||||
if ps.criterium == 'exact':
|
if ps.criterium == 'exact':
|
||||||
if ratio == 1.0:
|
if ratio == 1.0:
|
||||||
return ratio,'completed'
|
return ratio,'completed',completiondate
|
||||||
else:
|
else:
|
||||||
return ratio,'partial'
|
return ratio,'partial',completiondate
|
||||||
elif ps.criterium == 'minimum':
|
elif ps.criterium == 'minimum':
|
||||||
if ratio > 1.0:
|
if ratio > 1.0:
|
||||||
return ratio,'completed'
|
return ratio,'completed',completiondate
|
||||||
else:
|
else:
|
||||||
return ratio,'partial'
|
return ratio,'partial',completiondate
|
||||||
else:
|
else:
|
||||||
return ratio,'partial'
|
return ratio,'partial',completiondate
|
||||||
|
|
||||||
else:
|
else:
|
||||||
return ratio,status
|
return ratio,status,completiondate
|
||||||
|
|
||||||
|
|
||||||
def is_session_complete(r,ps):
|
def is_session_complete(r,ps):
|
||||||
status = 'not done'
|
status = 'not done'
|
||||||
|
|
||||||
if r not in ps.rower.all():
|
if r not in ps.rower.all():
|
||||||
return 0,'not assigned'
|
return 0,'not assigned',None
|
||||||
|
|
||||||
ws = Workout.objects.filter(user=r,plannedsession=ps)
|
ws = Workout.objects.filter(user=r,plannedsession=ps)
|
||||||
|
|
||||||
|
|||||||
@@ -92,7 +92,11 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<a href="/rowers/sessions/{{ key }}">
|
<a href="/rowers/sessions/{{ key }}">
|
||||||
|
{% if thedict|lookup:'name' %}
|
||||||
{{ thedict|lookup:'name' }}
|
{{ thedict|lookup:'name' }}
|
||||||
|
{% else %}
|
||||||
|
Unnamed Session
|
||||||
|
{% endif %}
|
||||||
</a>
|
</a>
|
||||||
</td>
|
</td>
|
||||||
{% for r in rowers %}
|
{% for r in rowers %}
|
||||||
|
|||||||
@@ -11991,7 +11991,7 @@ def plannedsessions_coach_view(request,timeperiod='thisweek',
|
|||||||
for ps in sps:
|
for ps in sps:
|
||||||
rowerstatus = {}
|
rowerstatus = {}
|
||||||
for r in rowers:
|
for r in rowers:
|
||||||
ratio, status = is_session_complete(r,ps)
|
ratio, status,completiondate = is_session_complete(r,ps)
|
||||||
rowerstatus[r.id] = status
|
rowerstatus[r.id] = status
|
||||||
sessiondict = {
|
sessiondict = {
|
||||||
'results':rowerstatus,
|
'results':rowerstatus,
|
||||||
@@ -12046,15 +12046,11 @@ def plannedsessions_view(request,timeperiod='thisweek',rowerid=0):
|
|||||||
completiondate = {}
|
completiondate = {}
|
||||||
|
|
||||||
for ps in sps:
|
for ps in sps:
|
||||||
ratio,status = is_session_complete(r,ps)
|
ratio,status,cdate = is_session_complete(r,ps)
|
||||||
actualvalue[ps.id] = int(ps.sessionvalue*ratio)
|
actualvalue[ps.id] = int(ps.sessionvalue*ratio)
|
||||||
completeness[ps.id] = status
|
completeness[ps.id] = status
|
||||||
ws = Workout.objects.filter(user=r,plannedsession=ps)
|
ws = Workout.objects.filter(user=r,plannedsession=ps)
|
||||||
if len(ws):
|
completiondate[ps.id] = cdate
|
||||||
date = min([w.date for w in ws])
|
|
||||||
completiondate[ps.id] = date
|
|
||||||
else:
|
|
||||||
completiondate[ps.id] = ''
|
|
||||||
|
|
||||||
unmatchedworkouts = Workout.objects.filter(
|
unmatchedworkouts = Workout.objects.filter(
|
||||||
user=r,
|
user=r,
|
||||||
@@ -12361,7 +12357,7 @@ def plannedsession_view(request,id=0,rowerid=0,
|
|||||||
|
|
||||||
ws = get_workouts_session(r,ps)
|
ws = get_workouts_session(r,ps)
|
||||||
|
|
||||||
ratio,status = is_session_complete(r,ps)
|
ratio,status,completiondate = is_session_complete(r,ps)
|
||||||
|
|
||||||
ratio = int(100.*ratio)
|
ratio = int(100.*ratio)
|
||||||
|
|
||||||
@@ -12391,7 +12387,7 @@ def plannedsession_view(request,id=0,rowerid=0,
|
|||||||
'psdict': psdict,
|
'psdict': psdict,
|
||||||
'attrs':[
|
'attrs':[
|
||||||
'name','startdate','enddate','sessiontype',
|
'name','startdate','enddate','sessiontype',
|
||||||
'sessionmode',
|
'sessionmode','criterium',
|
||||||
'sessionvalue','sessionunit'
|
'sessionvalue','sessionunit'
|
||||||
],
|
],
|
||||||
'workouts': ws,
|
'workouts': ws,
|
||||||
|
|||||||
Reference in New Issue
Block a user