summaryrefslogtreecommitdiffstats
path: root/views.py
diff options
context:
space:
mode:
authorAlexander Sulfrian <alex@spline.inf.fu-berlin.de>2014-11-19 01:34:46 +0100
committerAlexander Sulfrian <alex@spline.inf.fu-berlin.de>2014-11-19 02:15:56 +0100
commit641c6e4e397641b4de3aa15e674241e2b7b7f7f6 (patch)
treecbfe61e3311af72b994abd76d8cd0873e274cfdd /views.py
parentf73be7e78824088aeec8a7afda981a3006a935d5 (diff)
downloadpadlite-teams-641c6e4e397641b4de3aa15e674241e2b7b7f7f6.tar.gz
padlite-teams-641c6e4e397641b4de3aa15e674241e2b7b7f7f6.tar.bz2
padlite-teams-641c6e4e397641b4de3aa15e674241e2b7b7f7f6.zip
forms: generalize DeleteGroup for generic confirmation
Group deletion is now done with an extra confirmation step on a new page. There is a simple confirmation form that only contains a hidden field and the csrf magic. This commit also removes the direct deletion form on the group page and replace is with a simple button to the new confirmation page.
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'])