summaryrefslogtreecommitdiffstats
path: root/views.py
diff options
context:
space:
mode:
Diffstat (limited to 'views.py')
-rw-r--r--views.py24
1 files changed, 15 insertions, 9 deletions
diff --git a/views.py b/views.py
index d881d21..30bab96 100644
--- a/views.py
+++ b/views.py
@@ -3,7 +3,7 @@ from auth import auth
from flask import g, request, redirect, render_template, url_for
from flask_peewee.utils import get_object_or_404
from models import Group, Member
-from forms import CreateGroup, DeleteGroup, ChangeGroup
+from forms import CreateGroup, DeleteForm, ChangeGroup
from utils import templated
from filters import *
@@ -30,17 +30,23 @@ def index():
@auth.login_required
def group(group_name):
group = get_group_or_404(Group.name == group_name)
- form = DeleteGroup(request.form)
+ return {'group': group, 'members': group.members}
+
+
+@app.route('/<group_name>/_delete/', methods=['GET', 'POST'])
+@templated('group_delete.html')
+@auth.login_required
+def group_delete(group_name):
+ group = get_group_or_404(Group.name == group_name, Member.admin == True)
+ form = DeleteForm(request.form)
if form.validate_on_submit():
if form.sure.data == 'yes':
group.delete_instance(recursive=True)
- return redirect(url_for('index'))
- else:
- form.sure.data = 'yes'
- return render_template('group_delete.html', group=group, delete_form=form)
- else:
- form.id.data = group.id
- return {'group': group, 'members': group.members, 'delete_form': form}
+ return redirect(url_for('index'))
+ return {'group': group,
+ 'delete_form': form,
+ 'breadcrumbs': [{'href': url_for('group', group_name=group.name), 'text': group},
+ {'text': 'Delete group'}]}
@app.route('/<group_name>/_change/', methods=['GET', 'POST'])