Add ability to delete events and teams. Fixes #14
This commit is contained in:
parent
37f4ca7869
commit
4e031ae07d
8 changed files with 121 additions and 16 deletions
|
@ -1,5 +1,5 @@
|
||||||
from django.utils.safestring import mark_safe
|
from django.utils.safestring import mark_safe
|
||||||
from django.forms import ModelForm, Field, SplitDateTimeWidget, DateInput, MultiWidget, Select
|
from django import forms
|
||||||
from django.forms.widgets import TextInput, Media
|
from django.forms.widgets import TextInput, Media
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
|
||||||
|
@ -52,7 +52,7 @@ class Lookup(TextInput):
|
||||||
else:
|
else:
|
||||||
return mark_safe('<option value="">--------</option>')
|
return mark_safe('<option value="">--------</option>')
|
||||||
|
|
||||||
class DateWidget(DateInput):
|
class DateWidget(forms.DateInput):
|
||||||
"""A more-friendly date widget with a p% if widget.value != None %} value="{{ widget.value|stringformat:'s' }}"{% endif %op-up calendar.
|
"""A more-friendly date widget with a p% if widget.value != None %} value="{{ widget.value|stringformat:'s' }}"{% endif %op-up calendar.
|
||||||
"""
|
"""
|
||||||
template_name = 'forms/widgets/date.html'
|
template_name = 'forms/widgets/date.html'
|
||||||
|
@ -68,7 +68,7 @@ class DateWidget(DateInput):
|
||||||
super(DateWidget, self).__init__(attrs=attrs)
|
super(DateWidget, self).__init__(attrs=attrs)
|
||||||
|
|
||||||
|
|
||||||
class TimeWidget(MultiWidget):
|
class TimeWidget(forms.MultiWidget):
|
||||||
"""A more-friendly time widget.
|
"""A more-friendly time widget.
|
||||||
"""
|
"""
|
||||||
def __init__(self, attrs=None):
|
def __init__(self, attrs=None):
|
||||||
|
@ -81,9 +81,9 @@ class TimeWidget(MultiWidget):
|
||||||
attrs['class'] = 'time'
|
attrs['class'] = 'time'
|
||||||
|
|
||||||
widgets = (
|
widgets = (
|
||||||
Select(attrs=attrs, choices=[(i + 1, "%02d" % (i + 1)) for i in range(0, 12)]),
|
forms.Select(attrs=attrs, choices=[(i + 1, "%02d" % (i + 1)) for i in range(0, 12)]),
|
||||||
Select(attrs=attrs, choices=[(i, "%02d" % i) for i in range(00, 60, 15)]),
|
forms.Select(attrs=attrs, choices=[(i, "%02d" % i) for i in range(00, 60, 15)]),
|
||||||
Select(attrs=attrs, choices=[('AM', _('AM')), ('PM', _('PM'))])
|
forms.Select(attrs=attrs, choices=[('AM', _('AM')), ('PM', _('PM'))])
|
||||||
)
|
)
|
||||||
|
|
||||||
super(TimeWidget, self).__init__(widgets, attrs)
|
super(TimeWidget, self).__init__(widgets, attrs)
|
||||||
|
@ -120,7 +120,7 @@ class TimeWidget(MultiWidget):
|
||||||
rendered_widgets[0], rendered_widgets[1], rendered_widgets[2]
|
rendered_widgets[0], rendered_widgets[1], rendered_widgets[2]
|
||||||
)
|
)
|
||||||
|
|
||||||
class DateTimeWidget(SplitDateTimeWidget):
|
class DateTimeWidget(forms.SplitDateTimeWidget):
|
||||||
"""
|
"""
|
||||||
A more-friendly date/time widget.
|
A more-friendly date/time widget.
|
||||||
"""
|
"""
|
||||||
|
@ -146,7 +146,7 @@ class DateTimeWidget(SplitDateTimeWidget):
|
||||||
values = super(DateTimeWidget, self).value_from_datadict(data, files, name)
|
values = super(DateTimeWidget, self).value_from_datadict(data, files, name)
|
||||||
return ' '.join(values)
|
return ' '.join(values)
|
||||||
|
|
||||||
class TeamForm(ModelForm):
|
class TeamForm(forms.ModelForm):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Team
|
model = Team
|
||||||
fields = ['name', 'description', 'country', 'spr', 'city', 'web_url', 'tz']
|
fields = ['name', 'description', 'country', 'spr', 'city', 'web_url', 'tz']
|
||||||
|
@ -157,7 +157,7 @@ class TeamForm(ModelForm):
|
||||||
}
|
}
|
||||||
raw_id_fields = ('country','spr','city')
|
raw_id_fields = ('country','spr','city')
|
||||||
|
|
||||||
class NewTeamForm(ModelForm):
|
class NewTeamForm(forms.ModelForm):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Team
|
model = Team
|
||||||
fields = ['name', 'description', 'city', 'web_url', 'tz']
|
fields = ['name', 'description', 'city', 'web_url', 'tz']
|
||||||
|
@ -168,7 +168,10 @@ class NewTeamForm(ModelForm):
|
||||||
}
|
}
|
||||||
raw_id_fields = ('city')
|
raw_id_fields = ('city')
|
||||||
|
|
||||||
class TeamEventForm(ModelForm):
|
class DeleteTeamForm(forms.Form):
|
||||||
|
confirm = forms.BooleanField(label="Yes, delete team", required=True)
|
||||||
|
|
||||||
|
class TeamEventForm(forms.ModelForm):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Event
|
model = Event
|
||||||
fields = ['name', 'start_time', 'end_time', 'summary', 'place', 'web_url', 'announce_url', 'tags']
|
fields = ['name', 'start_time', 'end_time', 'summary', 'place', 'web_url', 'announce_url', 'tags']
|
||||||
|
@ -178,7 +181,7 @@ class TeamEventForm(ModelForm):
|
||||||
'end_time': DateTimeWidget
|
'end_time': DateTimeWidget
|
||||||
}
|
}
|
||||||
|
|
||||||
class NewTeamEventForm(ModelForm):
|
class NewTeamEventForm(forms.ModelForm):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Event
|
model = Event
|
||||||
fields = ['name', 'start_time', 'end_time', 'summary', 'place']
|
fields = ['name', 'start_time', 'end_time', 'summary', 'place']
|
||||||
|
@ -188,7 +191,10 @@ class NewTeamEventForm(ModelForm):
|
||||||
'end_time': DateTimeWidget
|
'end_time': DateTimeWidget
|
||||||
}
|
}
|
||||||
|
|
||||||
class NewPlaceForm(ModelForm):
|
class DeleteEventForm(forms.Form):
|
||||||
|
confirm = forms.BooleanField(label="Yes, delete event", required=True)
|
||||||
|
|
||||||
|
class NewPlaceForm(forms.ModelForm):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Place
|
model = Place
|
||||||
fields = ['name', 'address', 'city', 'longitude', 'latitude', 'place_url', 'tz']
|
fields = ['name', 'address', 'city', 'longitude', 'latitude', 'place_url', 'tz']
|
||||||
|
|
15
get_together/templates/get_together/events/delete_event.html
Normal file
15
get_together/templates/get_together/events/delete_event.html
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
{% extends "get_together/base.html" %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<h2>Confirm deletion</h2>
|
||||||
|
Are you sure you want to delete <strong>{{event.name}}</strong>?
|
||||||
|
<form action="{% url "delete-event" event.id %}" method="post">
|
||||||
|
{% csrf_token %}
|
||||||
|
<div class="form-group">
|
||||||
|
{{ delete_form }}
|
||||||
|
<br />
|
||||||
|
<button type="submit" class="btn btn-danger">Delete Event</button>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
{% endblock %}
|
||||||
|
|
|
@ -4,12 +4,11 @@
|
||||||
<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">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<div class="form-group">
|
|
||||||
{% include "events/event_form.html" %}
|
{% include "events/event_form.html" %}
|
||||||
<br />
|
<br />
|
||||||
<button type="submit" class="btn btn-primary">Save</button>
|
<button type="submit" class="btn btn-primary">Save</button>
|
||||||
</div>
|
|
||||||
</form>
|
</form>
|
||||||
|
<a href="{% url 'delete-event' event.id %}" class="btn btn-danger">Delete</a>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
{% block javascript %}
|
{% block javascript %}
|
||||||
|
|
20
get_together/templates/get_together/teams/delete_team.html
Normal file
20
get_together/templates/get_together/teams/delete_team.html
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
{% extends "get_together/base.html" %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<h2>Confirm deletion</h2>
|
||||||
|
Are you sure you want to delete <strong>{{team.name}}</strong>?
|
||||||
|
{% if team.event_set.count > 0 %}
|
||||||
|
<div class="alerts">
|
||||||
|
<div class="alert alert-danger">This team has {{ team.event_set.count }} events!</div>
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
|
<form action="{% url "delete-team" team.id %}" method="post">
|
||||||
|
{% csrf_token %}
|
||||||
|
<div class="form-group">
|
||||||
|
{{ delete_form }}
|
||||||
|
<br />
|
||||||
|
<button type="submit" class="btn btn-danger">Delete Team</button>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
{% endblock %}
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
<br />
|
<br />
|
||||||
<button type="submit" class="btn btn-primary">Save</button>
|
<button type="submit" class="btn btn-primary">Save</button>
|
||||||
</form>
|
</form>
|
||||||
|
<a href="{% url 'delete-team' team.id %}" class="btn btn-danger">Delete</a>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
{% block javascript %}
|
{% block javascript %}
|
||||||
|
|
|
@ -40,9 +40,12 @@ urlpatterns = [
|
||||||
path('team/<int:team_id>/+edit/', views.edit_team, name='edit-team'),
|
path('team/<int:team_id>/+edit/', views.edit_team, name='edit-team'),
|
||||||
path('team/<int:team_id>/+join/', event_views.join_team, name='join-team'),
|
path('team/<int:team_id>/+join/', event_views.join_team, name='join-team'),
|
||||||
path('team/<int:team_id>/+leave/', event_views.leave_team, name='leave-team'),
|
path('team/<int:team_id>/+leave/', event_views.leave_team, name='leave-team'),
|
||||||
|
path('team/<int:team_id>/+delete/', views.delete_team, name='delete-team'),
|
||||||
|
|
||||||
path('team/<int:team_id>/+create-event/', views.create_event, name='create-event'),
|
path('team/<int:team_id>/+create-event/', views.create_event, name='create-event'),
|
||||||
path('events/<int:event_id>/+edit/', views.edit_event, name='edit-event'),
|
path('events/<int:event_id>/+edit/', views.edit_event, name='edit-event'),
|
||||||
path('events/<int:event_id>/+attend/', event_views.attend_event, name='attend-event'),
|
path('events/<int:event_id>/+attend/', event_views.attend_event, name='attend-event'),
|
||||||
|
path('events/<int:event_id>/+delete/', views.delete_event, name='delete-event'),
|
||||||
path('events/<int:event_id>/<str:event_slug>/', views.show_event, name='show-event'),
|
path('events/<int:event_id>/<str:event_slug>/', views.show_event, name='show-event'),
|
||||||
|
|
||||||
path('places/', views.places_list, name='places'),
|
path('places/', views.places_list, name='places'),
|
||||||
|
|
|
@ -6,7 +6,7 @@ from django.shortcuts import render, redirect
|
||||||
from django.http import HttpResponse, JsonResponse
|
from django.http import HttpResponse, JsonResponse
|
||||||
|
|
||||||
from events.models.profiles import Team, UserProfile, Member
|
from events.models.profiles import Team, UserProfile, Member
|
||||||
from events.forms import TeamForm, NewTeamForm, TeamEventForm, NewTeamEventForm, NewPlaceForm
|
from events.forms import TeamEventForm, NewTeamEventForm, DeleteEventForm
|
||||||
|
|
||||||
from events.models.events import Event, Place, Attendee
|
from events.models.events import Event, Place, Attendee
|
||||||
|
|
||||||
|
@ -93,3 +93,35 @@ def edit_event(request, event_id):
|
||||||
else:
|
else:
|
||||||
return redirect('home')
|
return redirect('home')
|
||||||
|
|
||||||
|
def delete_event(request, event_id):
|
||||||
|
event = Event.objects.get(id=event_id)
|
||||||
|
if not request.user.profile.can_edit_event(event):
|
||||||
|
messages.add_message(request, messages.WARNING, message=_('You can not make changes to this event.'))
|
||||||
|
return redirect(event.get_absolute_url())
|
||||||
|
|
||||||
|
if request.method == 'GET':
|
||||||
|
form = DeleteEventForm()
|
||||||
|
|
||||||
|
context = {
|
||||||
|
'team': event.team,
|
||||||
|
'event': event,
|
||||||
|
'delete_form': form,
|
||||||
|
}
|
||||||
|
return render(request, 'get_together/events/delete_event.html', context)
|
||||||
|
elif request.method == 'POST':
|
||||||
|
form = DeleteEventForm(request.POST)
|
||||||
|
if form.is_valid() and form.cleaned_data['confirm']:
|
||||||
|
team_id = event.team_id
|
||||||
|
event.delete()
|
||||||
|
return redirect('show-team', team_id)
|
||||||
|
else:
|
||||||
|
context = {
|
||||||
|
'team': event.team,
|
||||||
|
'event': event,
|
||||||
|
'delete_form': form,
|
||||||
|
}
|
||||||
|
return render(request, 'get_together/events/delete_event.html', context)
|
||||||
|
else:
|
||||||
|
return redirect('home')
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@ from django.shortcuts import render, redirect
|
||||||
from django.http import HttpResponse, JsonResponse
|
from django.http import HttpResponse, JsonResponse
|
||||||
|
|
||||||
from events.models.profiles import Team, UserProfile, Member
|
from events.models.profiles import Team, UserProfile, Member
|
||||||
from events.forms import TeamForm, NewTeamForm, TeamEventForm, NewTeamEventForm, NewPlaceForm
|
from events.forms import TeamForm, NewTeamForm, DeleteTeamForm
|
||||||
|
|
||||||
from events.models.events import Event, Place, Attendee
|
from events.models.events import Event, Place, Attendee
|
||||||
|
|
||||||
|
@ -90,3 +90,32 @@ def edit_team(request, team_id):
|
||||||
else:
|
else:
|
||||||
return redirect('home')
|
return redirect('home')
|
||||||
|
|
||||||
|
def delete_team(request, team_id):
|
||||||
|
team = Team.objects.get(id=team_id)
|
||||||
|
if not request.user.profile.can_edit_team(team):
|
||||||
|
messages.add_message(request, messages.WARNING, message=_('You can not make changes to this team.'))
|
||||||
|
return redirect('show-team', team_id)
|
||||||
|
|
||||||
|
if request.method == 'GET':
|
||||||
|
form = DeleteTeamForm()
|
||||||
|
|
||||||
|
context = {
|
||||||
|
'team': team,
|
||||||
|
'delete_form': form,
|
||||||
|
}
|
||||||
|
return render(request, 'get_together/teams/delete_team.html', context)
|
||||||
|
elif request.method == 'POST':
|
||||||
|
form = DeleteTeamForm(request.POST)
|
||||||
|
if form.is_valid() and form.cleaned_data['confirm']:
|
||||||
|
team.delete()
|
||||||
|
return redirect('teams')
|
||||||
|
else:
|
||||||
|
context = {
|
||||||
|
'team': team,
|
||||||
|
'delete_form': form,
|
||||||
|
}
|
||||||
|
return render(request, 'get_together/teams/delete_team.html', context)
|
||||||
|
else:
|
||||||
|
return redirect('home')
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue