add initial shift signup flow
This commit is contained in:
parent
0566125299
commit
18b04a7102
|
@ -5,4 +5,8 @@ class RegisterForm(forms.Form):
|
||||||
name = forms.CharField(max_length=Helper.name.field.max_length, label="Name")
|
name = forms.CharField(max_length=Helper.name.field.max_length, label="Name")
|
||||||
# actually verify phone number, lol
|
# actually verify phone number, lol
|
||||||
phone = forms.CharField(max_length=Helper.phone.field.max_length, label='Handynummer fuer Benarchrichtigungen')
|
phone = forms.CharField(max_length=Helper.phone.field.max_length, label='Handynummer fuer Benarchrichtigungen')
|
||||||
okf = forms.BooleanField(label='Ich moechte SMS erhalten')
|
okf = forms.BooleanField(label='Ich moechte SMS erhalten')
|
||||||
|
|
||||||
|
# placeholder form for simple submit button use cases so we get csrf protection
|
||||||
|
class EmptyForm(forms.Form):
|
||||||
|
pass
|
|
@ -0,0 +1,18 @@
|
||||||
|
{% extends "base.html" %}
|
||||||
|
|
||||||
|
{% block title %}Schichtansicht{% endblock %}
|
||||||
|
{% block content %}
|
||||||
|
{%if is_registered%}
|
||||||
|
<div>Du bist zu dieser Schicht angemeldet</div>
|
||||||
|
{%endif%}
|
||||||
|
Ort: {{shift.room.name}}<br>
|
||||||
|
Start: {{shift.start_at}}<br>
|
||||||
|
Dauer: {{shift.duration}}<br>
|
||||||
|
{%if can_register%}
|
||||||
|
<form action="" method="post">
|
||||||
|
{% csrf_token %}
|
||||||
|
{{shift_form.as_p}}
|
||||||
|
<input type="submit" value="Anmelden">
|
||||||
|
</form>
|
||||||
|
{%endif%}
|
||||||
|
{% endblock %}
|
|
@ -7,5 +7,5 @@ urlpatterns = [
|
||||||
path('login/<slug:token>', views.login, name='token_login'),
|
path('login/<slug:token>', views.login, name='token_login'),
|
||||||
path('logout', views.logout, name='token_logout'),
|
path('logout', views.logout, name='token_logout'),
|
||||||
path('register', views.register, name='register'),
|
path('register', views.register, name='register'),
|
||||||
|
path('shift/<int:shiftid>', views.shift, name='shift'),
|
||||||
]
|
]
|
||||||
|
|
|
@ -1,10 +1,11 @@
|
||||||
from django.shortcuts import render, redirect, get_object_or_404
|
from django.shortcuts import render, redirect, get_object_or_404
|
||||||
from .models import Shift, LoginToken, Helper
|
from .models import Shift, LoginToken, Helper, ShiftRegistration
|
||||||
import datetime
|
import datetime
|
||||||
from django.db.models import F, Count
|
from django.db.models import F, Count
|
||||||
from .forms import RegisterForm
|
from .forms import RegisterForm, EmptyForm
|
||||||
|
|
||||||
def index(request):
|
def index(request):
|
||||||
|
del request.session['last_seen_shift']
|
||||||
# dont show shifts starting in <60 minutes?
|
# dont show shifts starting in <60 minutes?
|
||||||
# currently only sorts by date
|
# currently only sorts by date
|
||||||
free_shifts = Shift.objects.annotate(reg_count=Count('shiftregistration')).filter(start_at__gt=datetime.datetime.now(),
|
free_shifts = Shift.objects.annotate(reg_count=Count('shiftregistration')).filter(start_at__gt=datetime.datetime.now(),
|
||||||
|
@ -20,6 +21,10 @@ def login(request, token):
|
||||||
tk.helper.number_validated=True
|
tk.helper.number_validated=True
|
||||||
tk.helper.save()
|
tk.helper.save()
|
||||||
request.session['token'] = token
|
request.session['token'] = token
|
||||||
|
# if the user was viewing a single shift before registering, they probably want to register for that
|
||||||
|
# shift so we redirect them there.
|
||||||
|
if request.session.get('last_seen_shift'):
|
||||||
|
return redirect('shift', shiftid=request.session['last_seen_shift'])
|
||||||
return redirect('index')
|
return redirect('index')
|
||||||
|
|
||||||
def logout(request):
|
def logout(request):
|
||||||
|
@ -41,6 +46,35 @@ def register(request):
|
||||||
token = helper.send_confirmation()
|
token = helper.send_confirmation()
|
||||||
request.session['token'] = token.pk
|
request.session['token'] = token.pk
|
||||||
return render(request, 'wait_confirmation.html', {'helper':helper})
|
return render(request, 'wait_confirmation.html', {'helper':helper})
|
||||||
|
|
||||||
context['form']=RegisterForm()
|
context['form']=RegisterForm()
|
||||||
return render(request, 'register.html', context)
|
return render(request, 'register.html', context)
|
||||||
|
|
||||||
|
def shift(request, shiftid):
|
||||||
|
shift = get_object_or_404(Shift, pk=shiftid)
|
||||||
|
helper = None
|
||||||
|
context = { 'can_register':False,
|
||||||
|
'is_registered':False,
|
||||||
|
'shift':shift,
|
||||||
|
'shift_form': EmptyForm,
|
||||||
|
}
|
||||||
|
# this currently ignores date/time
|
||||||
|
request.session['last_seen_shift'] = shiftid
|
||||||
|
if shift.room.required_helpers>shift.shiftregistration_set.count():
|
||||||
|
context['can_register'] = True
|
||||||
|
if request.session.get('token'):
|
||||||
|
helper = LoginToken.objects.get(pk=request.session['token']).helper
|
||||||
|
context['helper'] =helper
|
||||||
|
if ShiftRegistration.objects.filter(shift=shift, helper=helper).count()!=0:
|
||||||
|
context['is_registered']=True
|
||||||
|
context['can_register']=False
|
||||||
|
if request.method=='POST':
|
||||||
|
if EmptyForm(request.POST).is_valid():
|
||||||
|
if not helper:
|
||||||
|
# todo: add flash message that signup is required?
|
||||||
|
return redirect('register')
|
||||||
|
if context['can_register']:
|
||||||
|
s = ShiftRegistration(helper=helper, shift=shift)
|
||||||
|
s.save()
|
||||||
|
# redirect so page can be reloaded without resending post data
|
||||||
|
return redirect('shift', shiftid=shift.pk)
|
||||||
|
return render(request, 'shift.html', context)
|
Loading…
Reference in New Issue