Allow adding recurrence data to an existing event to create a new event series. Fixes #68

This commit is contained in:
Michael Hall 2018-05-06 22:43:07 -04:00
parent c7ebe12875
commit e4046f3e65
3 changed files with 23 additions and 2 deletions

View file

@ -184,9 +184,10 @@ class DeleteTeamForm(forms.Form):
confirm = forms.BooleanField(label="Yes, delete team", required=True) confirm = forms.BooleanField(label="Yes, delete team", required=True)
class TeamEventForm(forms.ModelForm): class TeamEventForm(forms.ModelForm):
recurrences = recurrence.forms.RecurrenceField(label="Repeat", required=False)
class Meta: class Meta:
model = Event model = Event
fields = ['name', 'start_time', 'end_time', 'summary', 'web_url', 'announce_url', 'tags'] fields = ['name', 'start_time', 'end_time', 'recurrences', 'summary', 'web_url', 'announce_url', 'tags']
widgets = { widgets = {
'place': Lookup(source=Place), 'place': Lookup(source=Place),
'start_time': DateTimeWidget, 'start_time': DateTimeWidget,

View file

@ -1,6 +1,12 @@
{% extends "get_together/base.html" %} {% extends "get_together/base.html" %}
{% load static %} {% load static %}
{% block meta %}
<script type="text/javascript" src="{% static 'recurrence/js/recurrence.js' %}"></script>
<script type="text/javascript" src="{% static 'recurrence/js/recurrence-widget.js' %}"></script>
<link href="{% static 'recurrence/css/recurrence.css' %}" rel="stylesheet">
{% endblock %}
{% block content %} {% block content %}
<h2>Updating {{event.name}}</h2> <h2>Updating {{event.name}}</h2>
<form action="{% url "edit-event" event.id%}" method="post"> <form action="{% url "edit-event" event.id%}" method="post">

View file

@ -123,6 +123,7 @@ def create_event(request, team_id):
new_series.save() new_series.save()
new_event.series = new_series new_event.series = new_series
new_event.save() new_event.save()
messages.add_message(request, messages.SUCCESS, message=_('Your event has been scheduled! Next, find a place for your event.')) messages.add_message(request, messages.SUCCESS, message=_('Your event has been scheduled! Next, find a place for your event.'))
return redirect('add-place', new_event.id) return redirect('add-place', new_event.id)
else: else:
@ -240,6 +241,8 @@ def edit_event(request, event_id):
if request.method == 'GET': if request.method == 'GET':
form = TeamEventForm(instance=event) form = TeamEventForm(instance=event)
if event.series is not None:
form.initial['recurrences'] = event.series.recurrences
context = { context = {
'team': event.team, 'team': event.team,
@ -251,6 +254,17 @@ def edit_event(request, event_id):
form = TeamEventForm(request.POST,instance=event) form = TeamEventForm(request.POST,instance=event)
if form.is_valid: if form.is_valid:
new_event = form.save() new_event = form.save()
if form.cleaned_data.get('recurrences', None):
if event.series is not None:
event.series.recurrences = form.cleaned_data['recurrences']
event.series.save()
else:
new_series = EventSeries.from_event(new_event, recurrences=form.cleaned_data['recurrences'])
new_series.save()
new_event.series = new_series
new_event.save()
return redirect(new_event.get_absolute_url()) return redirect(new_event.get_absolute_url())
else: else:
context = { context = {