Private
Public Access
1
0

Merge tag 'v6.87' into develop

releasing workout form improvements
This commit is contained in:
Sander Roosendaal
2018-06-08 09:41:42 +02:00
6 changed files with 61 additions and 17 deletions

View File

@@ -748,9 +748,8 @@ def fetchcp(rower,theworkouts,table='cpdata'):
# create a new workout from manually entered data # create a new workout from manually entered data
def create_row_df(r,distance,duration,startdatetime, def create_row_df(r,distance,duration,startdatetime,workouttype='rower'):
title = 'Manually added workout',notes='',
workouttype='rower'):
nr_strokes = int(distance/10.) nr_strokes = int(distance/10.)
@@ -808,10 +807,10 @@ def create_row_df(r,distance,duration,startdatetime,
row.write_csv(csvfilename, gzip = True) row.write_csv(csvfilename, gzip = True)
id, message = save_workout_database(csvfilename, r, id, message = save_workout_database(csvfilename, r,
title=title, # title=title,
notes=notes, # notes=notes,
dosmooth=False, dosmooth=False,
workouttype=workouttype, # workouttype=workouttype,
consistencychecks=False, consistencychecks=False,
totaltime=totalseconds) totaltime=totalseconds)

View File

@@ -85,7 +85,7 @@ $( document ).ready(function() {
$(this).val() == 'rower' $(this).val() == 'rower'
|| $(this).val() == 'skierg' || $(this).val() == 'skierg'
|| $(this).val() == 'dynamic' || $(this).val() == 'dynamic'
|| $(this).val() == 'sliders' || $(this).val() == 'slides'
|| $(this).val() == 'paddle' || $(this).val() == 'paddle'
|| $(this).val() == 'snow' || $(this).val() == 'snow'
) { ) {

View File

@@ -6,6 +6,34 @@
{% get_current_timezone as TIME_ZONE %} {% get_current_timezone as TIME_ZONE %}
{% block scripts %}
<script type='text/javascript'
src='https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js'>
</script>
<script>
$( document ).ready(function() {
$('#id_workouttype').on('change', function(){
if (
$(this).val() == 'rower'
|| $(this).val() == 'skierg'
|| $(this).val() == 'dynamic'
|| $(this).val() == 'slides'
|| $(this).val() == 'paddle'
|| $(this).val() == 'snow'
) {
$('#id_boattype').toggle(false);
$('#id_boattype').val('1x');
} else {
$('#id_boattype').toggle(true);
}
});
$('#id_workouttype').change();
});
</script>
{% endblock %}
{% block content %} {% block content %}
<div class="grid_12 alpha"> <div class="grid_12 alpha">
<h1>Add Workout Manually</h1> <h1>Add Workout Manually</h1>

View File

@@ -18,7 +18,7 @@
<script type='text/javascript' <script type='text/javascript'
src='https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js'> src='https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js'>
</script> </script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js"></script>
<script> <script>
$( document ).ready(function() { $( document ).ready(function() {
$('#id_workouttype').on('change', function(){ $('#id_workouttype').on('change', function(){
@@ -26,7 +26,7 @@ $( document ).ready(function() {
$(this).val() == 'rower' $(this).val() == 'rower'
|| $(this).val() == 'skierg' || $(this).val() == 'skierg'
|| $(this).val() == 'dynamic' || $(this).val() == 'dynamic'
|| $(this).val() == 'sliders' || $(this).val() == 'slides'
|| $(this).val() == 'paddle' || $(this).val() == 'paddle'
|| $(this).val() == 'snow' || $(this).val() == 'snow'
) { ) {

View File

@@ -450,6 +450,8 @@ class DataTest(TestCase):
'notes':'Aap noot \n mies', 'notes':'Aap noot \n mies',
'weightcategory':'lwt', 'weightcategory':'lwt',
'workouttype':'water', 'workouttype':'water',
'boattype':'1x',
'private':False,
} }
form = WorkoutForm(data=form_data) form = WorkoutForm(data=form_data)
self.assertTrue(form.is_valid()) self.assertTrue(form.is_valid())
@@ -680,6 +682,8 @@ class ViewTest(TestCase):
'distance':'15000', 'distance':'15000',
'weightcategory':'hwt', 'weightcategory':'hwt',
'workouttype':'rower', 'workouttype':'rower',
'boattype':'1x',
'private':True,
'notes':'noot mies', 'notes':'noot mies',
} }
form = WorkoutForm(data=form_data) form = WorkoutForm(data=form_data)

View File

@@ -3604,6 +3604,7 @@ def addmanual_view(request):
distance = form.cleaned_data['distance'] distance = form.cleaned_data['distance']
notes = form.cleaned_data['notes'] notes = form.cleaned_data['notes']
thetimezone = form.cleaned_data['timezone'] thetimezone = form.cleaned_data['timezone']
private = form.cleaned_data['private']
try: try:
boattype = request.POST['boattype'] boattype = request.POST['boattype']
except KeyError: except KeyError:
@@ -3617,6 +3618,11 @@ def addmanual_view(request):
except KeyError: except KeyError:
rankingpiece =- Workout.objects.get(id=id).rankingpiece rankingpiece =- Workout.objects.get(id=id).rankingpiece
if private:
privacy = 'private'
else:
privacy = 'visible'
startdatetime = (str(date) + ' ' + str(starttime)) startdatetime = (str(date) + ' ' + str(starttime))
startdatetime = datetime.datetime.strptime(startdatetime, startdatetime = datetime.datetime.strptime(startdatetime,
"%Y-%m-%d %H:%M:%S") "%Y-%m-%d %H:%M:%S")
@@ -3628,10 +3634,10 @@ def addmanual_view(request):
id,message = dataprep.create_row_df(r, id,message = dataprep.create_row_df(r,
distance, distance,
weightcategory, # weightcategory,
duration,startdatetime, duration,startdatetime,
title = name, # title = name,
notes=notes, # notes=notes,
workouttype=workouttype) workouttype=workouttype)
@@ -3642,7 +3648,12 @@ def addmanual_view(request):
if id: if id:
w = Workout.objects.get(id=id) w = Workout.objects.get(id=id)
w.rankingpiece = rankingpiece or is_ranking_piece(w) w.rankingpiece = rankingpiece or is_ranking_piece(w)
w.privacy = privacy
w.weightcategory = weightcategory
w.notes = notes w.notes = notes
w.name = name
w.workouttype = workouttype
w.boattype = boattype
w.save() w.save()
messages.info(request,'New workout created') messages.info(request,'New workout created')
@@ -7541,7 +7552,7 @@ def workout_otwsetpower_view(request,id=0,message="",successmessage=""):
def instroke_view(request,id=0): def instroke_view(request,id=0):
row = get_workout(id) row = get_workout(id)
form = WorkoutForm(instance=row) # form = WorkoutForm(instance=row)
g = GraphImage.objects.filter(workout=row).order_by("-creationdatetime") g = GraphImage.objects.filter(workout=row).order_by("-creationdatetime")
# check if user is owner of this workout # check if user is owner of this workout
@@ -7573,7 +7584,7 @@ def instroke_view(request,id=0):
def workout_geeky_view(request,id=0,message="",successmessage=""): def workout_geeky_view(request,id=0,message="",successmessage=""):
row = get_workout(id) row = get_workout(id)
form = WorkoutForm(instance=row) # form = WorkoutForm(instance=row)
g = GraphImage.objects.filter(workout=row).order_by("-creationdatetime") g = GraphImage.objects.filter(workout=row).order_by("-creationdatetime")
rowdata = rrdata(csvfile=row.csvfilename) rowdata = rrdata(csvfile=row.csvfilename)
instrokemetrics = rowdata.get_instroke_columns() instrokemetrics = rowdata.get_instroke_columns()
@@ -8131,7 +8142,7 @@ def workout_stats_view(request,id=0,message="",successmessage=""):
def workout_advanced_view(request,id=0,message="",successmessage=""): def workout_advanced_view(request,id=0,message="",successmessage=""):
row = get_workout(id) row = get_workout(id)
form = WorkoutForm(instance=row) # form = WorkoutForm(instance=row)
g = GraphImage.objects.filter(workout=row).order_by("-creationdatetime") g = GraphImage.objects.filter(workout=row).order_by("-creationdatetime")
for i in g: for i in g:
try: try:
@@ -8851,7 +8862,7 @@ def workout_export_view(request,id=0, message="", successmessage=""):
rkuserid = 0 rkuserid = 0
form = WorkoutForm(instance=row) # form = WorkoutForm(instance=row)
g = GraphImage.objects.filter(workout=row).order_by("-creationdatetime") g = GraphImage.objects.filter(workout=row).order_by("-creationdatetime")
for i in g: for i in g:
try: try:
@@ -10175,11 +10186,13 @@ def workout_getc2workout_view(request,c2id):
distance, distance,
duration, duration,
startdatetime, startdatetime,
title = 'Imported from C2', # title = 'Imported from C2',
workouttype=workouttype) workouttype=workouttype)
w = Workout.objects.get(id=id) w = Workout.objects.get(id=id)
w.uploadedtoc2 = c2id w.uploadedtoc2 = c2id
w.name = 'Imported from C2'
w.workouttype = 'rower'
w.save() w.save()
message = "This workout does not have any stroke data associated with it. We created synthetic stroke data." message = "This workout does not have any stroke data associated with it. We created synthetic stroke data."