Add ability to edit teams and events
This commit is contained in:
parent
dd9a836a66
commit
54adf71434
10 changed files with 181 additions and 7 deletions
|
@ -38,7 +38,6 @@ class Lookup(TextInput):
|
||||||
self.source = source
|
self.source = source
|
||||||
self.key = key
|
self.key = key
|
||||||
self.label = label
|
self.label = label
|
||||||
self.name = 'place'
|
|
||||||
|
|
||||||
def get_context(self, name, value, attrs):
|
def get_context(self, name, value, attrs):
|
||||||
context = super().get_context(name, value, attrs)
|
context = super().get_context(name, value, attrs)
|
||||||
|
@ -47,8 +46,14 @@ class Lookup(TextInput):
|
||||||
context['widget']['label'] = self.label
|
context['widget']['label'] = self.label
|
||||||
return context
|
return context
|
||||||
|
|
||||||
|
def format_value(self, value):
|
||||||
|
if value is not None:
|
||||||
|
return mark_safe('<option value="%s">%s</option>' % (value, _('No change')))
|
||||||
|
else:
|
||||||
|
return mark_safe('<option value="">--------</option>')
|
||||||
|
|
||||||
class DateWidget(DateInput):
|
class DateWidget(DateInput):
|
||||||
"""A more-friendly date widget with a pop-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'
|
||||||
def __init__(self, attrs=None):
|
def __init__(self, attrs=None):
|
||||||
|
@ -144,7 +149,13 @@ class DateTimeWidget(SplitDateTimeWidget):
|
||||||
class TeamForm(ModelForm):
|
class TeamForm(ModelForm):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Team
|
model = Team
|
||||||
fields = '__all__'
|
fields = ['name', 'country', 'spr', 'city', 'web_url', 'tz']
|
||||||
|
widgets = {
|
||||||
|
'country': Lookup(source='/api/country/', label='name'),
|
||||||
|
'spr': Lookup(source='/api/spr/', label='name'),
|
||||||
|
'city': Lookup(source='/api/cities/', label='name'),
|
||||||
|
}
|
||||||
|
raw_id_fields = ('country','spr','city')
|
||||||
|
|
||||||
class NewTeamForm(ModelForm):
|
class NewTeamForm(ModelForm):
|
||||||
class Meta:
|
class Meta:
|
||||||
|
@ -162,9 +173,9 @@ class TeamEventForm(ModelForm):
|
||||||
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']
|
||||||
widgets = {
|
widgets = {
|
||||||
'country': Lookup(source='/api/country/', label='name'),
|
'place': Lookup(source='/api/places/', label='name'),
|
||||||
'spr': Lookup(source='/api/spr/', label='name'),
|
'start_time': DateTimeWidget,
|
||||||
'city': Lookup(source='/api/cities/', label='name'),
|
'end_time': DateTimeWidget
|
||||||
}
|
}
|
||||||
|
|
||||||
class NewTeamEventForm(ModelForm):
|
class NewTeamEventForm(ModelForm):
|
||||||
|
|
|
@ -4,6 +4,9 @@
|
||||||
<td><b>Time:</b></td><td>{{ event.start_time }} - {{ event.end_time }}</td>
|
<td><b>Time:</b></td><td>{{ event.start_time }} - {{ event.end_time }}</td>
|
||||||
</tr><tr>
|
</tr><tr>
|
||||||
<td><b>Place:</b></td><td>{{ event.place }}</td>
|
<td><b>Place:</b></td><td>{{ event.place }}</td>
|
||||||
|
<tr>
|
||||||
|
<td><b>Host:</b></td><td>{{ event.created_by }}</td>
|
||||||
|
</tr><tr>
|
||||||
{% if event.web_url %}
|
{% if event.web_url %}
|
||||||
</tr><tr>
|
</tr><tr>
|
||||||
<td><b>Website:</b></td><td><a href="{{ event.web_url }}" target="_blank">{{ event.web_url }}</a></td>
|
<td><b>Website:</b></td><td><a href="{{ event.web_url }}" target="_blank">{{ event.web_url }}</a></td>
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<select autocomplete="false" id="{{ widget.name }}_select" name="{{ widget.name }}"{% include "django/forms/widgets/attrs.html" %} style="width: 300px">
|
<select autocomplete="false" id="{{ widget.name }}_select" name="{{ widget.name }}"{% include "django/forms/widgets/attrs.html" %} style="width: 300px">
|
||||||
<option value="">--------</option>
|
{{ widget.value }}
|
||||||
</select>
|
</select>
|
||||||
<input autocomplete="false" id="{{ widget.name }}_search" name="{{ widget.name }}_search" />
|
<input autocomplete="false" id="{{ widget.name }}_search" name="{{ widget.name }}_search" />
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,9 @@ body {
|
||||||
.starter-template {
|
.starter-template {
|
||||||
padding: 3rem 1.5rem;
|
padding: 3rem 1.5rem;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
|
}
|
||||||
|
form {
|
||||||
|
display: inline;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
|
|
43
get_together/templates/get_together/edit_event.html
Normal file
43
get_together/templates/get_together/edit_event.html
Normal file
|
@ -0,0 +1,43 @@
|
||||||
|
{% extends "get_together/base.html" %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<h2>Updating {{event.name}}</h2>
|
||||||
|
<form action="{% url "edit-event" event.id%}" method="post">
|
||||||
|
{% csrf_token %}
|
||||||
|
<div class="form-group">
|
||||||
|
{% include "events/event_form.html" %}
|
||||||
|
<br />
|
||||||
|
<button type="submit" class="btn btn-primary">Save</button>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% block javascript %}
|
||||||
|
<script type="text/javascript">
|
||||||
|
$(document).ready(function(){
|
||||||
|
{% with event_form.fields.place.widget as widget %}
|
||||||
|
$("#{{ widget.name }}_search").keyup(function() {
|
||||||
|
var searchText = this.value;
|
||||||
|
$.getJSON("{{ widget.source }}?q="+searchText, function(data) {
|
||||||
|
var selectField = $("#{{ widget.name }}_select");
|
||||||
|
selectField.empty();
|
||||||
|
$.each(data, function(){
|
||||||
|
selectField.append('<option value="'+ this.{{ widget.key }} +'">'+ this.name+' '+this.city + '</option>')
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
{% endwith %}
|
||||||
|
|
||||||
|
$.datepicker.setDefaults({
|
||||||
|
showOn: 'focus',
|
||||||
|
dateFormat: 'yy-mm-dd',
|
||||||
|
});
|
||||||
|
|
||||||
|
$("#id_start_time_0").datepicker({altField: "#id_end_time_0", altFormat: "yy-mm-dd"});
|
||||||
|
|
||||||
|
$("#id_end_time_0").datepicker();
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
</script>
|
||||||
|
{% endblock %}
|
51
get_together/templates/get_together/edit_team.html
Normal file
51
get_together/templates/get_together/edit_team.html
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
{% extends "get_together/base.html" %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<h2>Update {{team.name}}</h2>
|
||||||
|
<form action="{% url "create-team" %}" method="post">
|
||||||
|
{% csrf_token %}
|
||||||
|
{% include "events/team_form.html" %}
|
||||||
|
<br />
|
||||||
|
<button type="submit" class="btn btn-primary">Save</button>
|
||||||
|
</form>
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% block javascript %}
|
||||||
|
<script type="text/javascript">
|
||||||
|
$(document).ready(function(){
|
||||||
|
$("#country_search").keyup(function() {
|
||||||
|
var searchText = this.value;
|
||||||
|
$.getJSON("/api/countries/?q="+searchText, function(data) {
|
||||||
|
var selectField = $("#country_select");
|
||||||
|
selectField.empty();
|
||||||
|
$.each(data, function(){
|
||||||
|
selectField.append('<option value="'+ this.id +'">'+ this.name + '</option>')
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
$("#spr_search").keyup(function() {
|
||||||
|
var searchText = this.value;
|
||||||
|
var country_id = $("#country_select")[0].selectedOptions[0].value;
|
||||||
|
$.getJSON("/api/spr/?q="+searchText+"&country="+country_id, function(data) {
|
||||||
|
var selectField = $("#spr_select");
|
||||||
|
selectField.empty();
|
||||||
|
$.each(data, function(){
|
||||||
|
selectField.append('<option value="'+ this.id +'">'+ this.name + '</option>')
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
$("#city_search").keyup(function() {
|
||||||
|
var searchText = this.value;
|
||||||
|
var spr_id = $("#spr_select")[0].selectedOptions[0].value;
|
||||||
|
$.getJSON("/api/cities/?q="+searchText+"&spr="+spr_id, function(data) {
|
||||||
|
var selectField = $("#city_select");
|
||||||
|
selectField.empty();
|
||||||
|
$.each(data, function(){
|
||||||
|
selectField.append('<option value="'+ this.id +'">'+ this.name + '</option>')
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
{% endblock %}
|
|
@ -6,5 +6,10 @@
|
||||||
<h4>Hosted by <a href="{% url "show-team" team.id %}">{{ team.name }}</a></h4>
|
<h4>Hosted by <a href="{% url "show-team" team.id %}">{{ team.name }}</a></h4>
|
||||||
{% include "events/event_details.html" %}
|
{% include "events/event_details.html" %}
|
||||||
|
|
||||||
|
{% if request.user.profile == event.created_by %}
|
||||||
|
<form action="{% url 'edit-event' event.id %}" method="get">
|
||||||
|
<button type="submit" class="btn btn-secondary">Edit Event</button>
|
||||||
|
</form>
|
||||||
|
{% endif %}
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,10 @@
|
||||||
<form action="{% url 'create-event' team.id %}" method="get">
|
<form action="{% url 'create-event' team.id %}" method="get">
|
||||||
<button type="submit" class="btn btn-primary">Plan a Get Together</button>
|
<button type="submit" class="btn btn-primary">Plan a Get Together</button>
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
|
<form action="{% url 'edit-team' team.id %}" method="get">
|
||||||
|
<button type="submit" class="btn btn-secondary">Edit Team</button>
|
||||||
|
</form>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,9 @@ urlpatterns = [
|
||||||
path('create-team/', views.create_team, name='create-team'),
|
path('create-team/', views.create_team, name='create-team'),
|
||||||
path('teams/', views.teams_list, name='teams'),
|
path('teams/', views.teams_list, name='teams'),
|
||||||
path('team/<int:team_id>/', views.show_team, name='show-team'),
|
path('team/<int:team_id>/', views.show_team, name='show-team'),
|
||||||
|
path('team/<int:team_id>/edit/', views.edit_team, name='edit-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>/<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'),
|
||||||
|
|
|
@ -51,6 +51,32 @@ def create_team(request, *args, **kwargs):
|
||||||
else:
|
else:
|
||||||
return redirect('home')
|
return redirect('home')
|
||||||
|
|
||||||
|
def edit_team(request, team_id):
|
||||||
|
team = Team.objects.get(id=team_id)
|
||||||
|
if request.method == 'GET':
|
||||||
|
form = TeamForm(instance=team)
|
||||||
|
|
||||||
|
context = {
|
||||||
|
'team': team,
|
||||||
|
'team_form': form,
|
||||||
|
}
|
||||||
|
return render(request, 'get_together/edit_team.html', context)
|
||||||
|
elif request.method == 'POST':
|
||||||
|
form = TeamForm(request.POST, instance=team)
|
||||||
|
if form.is_valid:
|
||||||
|
new_team = form.save()
|
||||||
|
new_team.owner_profile = request.user.profile
|
||||||
|
new_team.save()
|
||||||
|
return redirect('show-team', team_id=new_team.pk)
|
||||||
|
else:
|
||||||
|
context = {
|
||||||
|
'team': team,
|
||||||
|
'team_form': form,
|
||||||
|
}
|
||||||
|
return render(request, 'get_together/edit_team.html', context)
|
||||||
|
else:
|
||||||
|
return redirect('home')
|
||||||
|
|
||||||
def teams_list(request, *args, **kwargs):
|
def teams_list(request, *args, **kwargs):
|
||||||
teams = Team.objects.all()
|
teams = Team.objects.all()
|
||||||
context = {
|
context = {
|
||||||
|
@ -69,6 +95,32 @@ def show_team(request, team_id, *args, **kwargs):
|
||||||
}
|
}
|
||||||
return render(request, 'get_together/show_team.html', context)
|
return render(request, 'get_together/show_team.html', context)
|
||||||
|
|
||||||
|
def edit_event(request, event_id):
|
||||||
|
event = Event.objects.get(id=event_id)
|
||||||
|
if request.method == 'GET':
|
||||||
|
form = TeamEventForm(instance=event)
|
||||||
|
|
||||||
|
context = {
|
||||||
|
'team': event.team,
|
||||||
|
'event': event,
|
||||||
|
'event_form': form,
|
||||||
|
}
|
||||||
|
return render(request, 'get_together/edit_event.html', context)
|
||||||
|
elif request.method == 'POST':
|
||||||
|
form = TeamEventForm(request.POST,instance=event)
|
||||||
|
if form.is_valid:
|
||||||
|
new_event = form.save()
|
||||||
|
return redirect(new_event.get_absolute_url())
|
||||||
|
else:
|
||||||
|
context = {
|
||||||
|
'team': event.team,
|
||||||
|
'event': event,
|
||||||
|
'event_form': form,
|
||||||
|
}
|
||||||
|
return render(request, 'get_together/edit_event.html', context)
|
||||||
|
else:
|
||||||
|
return redirect('home')
|
||||||
|
|
||||||
def create_event(request, team_id):
|
def create_event(request, team_id):
|
||||||
team = Team.objects.get(id=team_id)
|
team = Team.objects.get(id=team_id)
|
||||||
if request.method == 'GET':
|
if request.method == 'GET':
|
||||||
|
|
Loading…
Reference in a new issue