implement lineup retrieval and submission

This commit is contained in:
2021-11-12 08:58:48 -06:00
parent 7bc4e540ad
commit 9bf90a2cea
4 changed files with 29 additions and 19 deletions

View File

@@ -1,13 +1,26 @@
from django import forms from django import forms
from .models import Positioning from .models import Positioning
from django.forms import modelformset_factory from events.models import Event
from players.models import Player
from django.forms import modelformset_factory, inlineformset_factory, NumberInput
from crispy_forms.helper import FormHelper, Layout from crispy_forms.helper import FormHelper, Layout
PositioningFormSet = modelformset_factory(model=Positioning, class PositioningForm(forms.ModelForm):
fields = ['player', 'position', 'order'], class Meta:
model = Positioning
widgets = { widgets = {
'order':forms.NumberInput(attrs={'style':'width:6ch'}) 'order': forms.NumberInput(attrs={'class':'input-group-text w-25'}),
}) 'player': forms.Select(attrs={'class': 'form-control'}),
'position': forms.Select(attrs={'class': 'input-group-text w-25'})
}
exclude = ()
PositioningFormSet = modelformset_factory(
model=Positioning,
form=PositioningForm,
fields = ['player', 'position', 'order'],
min_num=9
)
# class PositioningFormSet(modelformset_factory): # class PositioningFormSet(modelformset_factory):
# class Meta: # class Meta:

View File

@@ -2,6 +2,7 @@ from django.db import models
from players.models import Player from players.models import Player
from events.models import Event from events.models import Event
# Create your models here. # Create your models here.
class Positioning(models.Model): class Positioning(models.Model):
player = models.ForeignKey(Player, on_delete=models.CASCADE) player = models.ForeignKey(Player, on_delete=models.CASCADE)
event = models.ForeignKey(Event, on_delete=models.CASCADE) event = models.ForeignKey(Event, on_delete=models.CASCADE)

View File

@@ -14,18 +14,11 @@
{% csrf_token %} {% csrf_token %}
{{ positionings_formset.management_form }} {{ positionings_formset.management_form }}
{% for pos in positionings_formset %} {% for pos in positionings_formset %}
<div class="list-group-item"> <div class="input-group mb-1">
<div class="row"> {{ pos.id }}
<div class="col-3"> {{ pos.order }}
{{ pos.order }} {{ pos.player }}
</div> {{ pos.position }}
<div class="col-6">
{{ pos.player }}
</div>
<div class="col-3">
{{ pos.position }}
</div>
</div>
</div> </div>
{% endfor %} {% endfor %}
<input type="submit" value="Submit"> <input type="submit" value="Submit">

View File

@@ -18,13 +18,16 @@ def edit(request, id):
# process the data in form.cleaned_data as required # process the data in form.cleaned_data as required
# ... # ...
# redirect to a new URL: # redirect to a new URL:
new_event, did_create = Positioning.objects.update_or_create(player_id=form['player'].data, event_id=id, defaults=form.cleaned_data) form.cleaned_data.pop('id') #FIXME this is a workaround, not sure why it is necessary
print (form.cleaned_data) new_positioning, did_create = Positioning.objects.update_or_create(id=form['id'].data, defaults=form.cleaned_data)
# return render(request, 'success.html', {'call_back':'schedule'}) # return render(request, 'success.html', {'call_back':'schedule'})
event = Event.objects.get(id=id) event = Event.objects.get(id=id)
players = Player.objects.all() players = Player.objects.all()
qset = Positioning.objects.filter(event_id=id, order__isnull = False) qset = Positioning.objects.filter(event_id=id, order__isnull = False)
formset = PositioningFormSet(queryset=qset) formset = PositioningFormSet(queryset=qset)
for form in formset:
for field in form.fields:
field
return render(request, 'lineups/lineup.html', {'title': 'Lineup', return render(request, 'lineups/lineup.html', {'title': 'Lineup',
'event': event, 'event': event,
'players': players, 'players': players,