aboutsummaryrefslogtreecommitdiffstats
path: root/mediagoblin/moderation/views.py
diff options
context:
space:
mode:
authortilly-Q <nattilypigeonfowl@gmail.com>2013-09-03 11:57:10 -0400
committertilly-Q <nattilypigeonfowl@gmail.com>2013-09-03 11:57:10 -0400
commitdc31cd1b658067d25cda470795020d3c377feae0 (patch)
tree4a9d270bb90dbf699b035c62ffa4216dcb153d61 /mediagoblin/moderation/views.py
parent1bb367f6136ae4cbcdf6dd86af65eb613913dbd8 (diff)
downloadmediagoblin-dc31cd1b658067d25cda470795020d3c377feae0.tar.lz
mediagoblin-dc31cd1b658067d25cda470795020d3c377feae0.tar.xz
mediagoblin-dc31cd1b658067d25cda470795020d3c377feae0.zip
I've moved on to one of the last phases of my work! Now I'm just checking off
items from my last to-do list. The biggest change in this commit is that I made the moderation reports panel sortable via get request. I also added in page nu- mbers so that more than 10 reports can be viewed. I'm hoping to go from here to make a search page. Aside from that, there were only a few other changes I made this time. I fixed two bugs in my code. I copy-ed and pasted function mediagoblin.user_pages.views:media_preview_comment which I must've deleted ear- -lier in a merge. And I moved some of the javascript I was using in the modera- -tion templates into it's own seperate .js file. =============================================================================== Made the moderation reports panel view sortable =============================================================================== --\ mediagoblin/moderation/forms.py --\ mediagoblin/moderation/views.py --\ mediagoblin/templates/mediagoblin/moderation/report_panel.html --\ mediagoblin/templates/mediagoblin/moderation/user.html --| Made `<user> report history` into a link that automatically shows all open | and closed reports on <user>. =============================================================================== Grabbed some code from master that I accidentally deleted in a merge =============================================================================== --\ mediagoblin/user_pages/views.py =============================================================================== Moved javascript away from templates into its own file =============================================================================== --\ mediagoblin/static/js/setup_report_forms.js --\ mediagoblin/templates/mediagoblin/moderation/report.html --\ mediagoblin/templates/mediagoblin/moderation/user.html =============================================================================== Cleared trailing white space =============================================================================== --\ mediagoblin/templates/mediagoblin/moderation/media_panel.html --\ mediagoblin/moderation/tools.py --\ mediagoblin/templates/mediagoblin/meta/terms_of_service.html --\ mediagoblin/templates/mediagoblin/moderation/report_panel.html --\ mediagoblin/templates/mediagoblin/user_pages/media.html --\ mediagoblin/tests/test_modelmethods.py =============================================================================== Small fixes =============================================================================== --\ mediagoblin/templates/mediagoblin/moderation/report.html --| Fixed a link so that it points to the correct user page --\ mediagoblin/templates/mediagoblin/user_pages/media.html --| Fixed a bug that crashed this page when a guest visitted it (because | request.user is None)
Diffstat (limited to 'mediagoblin/moderation/views.py')
-rw-r--r--mediagoblin/moderation/views.py43
1 files changed, 36 insertions, 7 deletions
diff --git a/mediagoblin/moderation/views.py b/mediagoblin/moderation/views.py
index 869b7b8a..35c586ea 100644
--- a/mediagoblin/moderation/views.py
+++ b/mediagoblin/moderation/views.py
@@ -26,6 +26,7 @@ from mediagoblin.moderation import forms as moderation_forms
from mediagoblin.moderation.tools import (take_punitive_actions, \
take_away_privileges, give_privileges, ban_user, unban_user)
from datetime import datetime
+from math import ceil
@require_admin_or_moderator_login
def moderation_media_processing_panel(request):
@@ -91,19 +92,47 @@ def moderation_reports_panel(request):
Show the global panel for monitoring reports filed against comments or
media entries for this instance.
'''
- report_list = ReportBase.query.filter(
- ReportBase.discriminator!="archived_report").order_by(
- ReportBase.created.desc()).limit(10)
- closed_report_list = ReportBase.query.filter(
- ReportBase.discriminator=="archived_report").order_by(
- ReportBase.created.desc()).limit(10)
+ form = moderation_forms.ReportPanelSortingForm(request.args)
+ active_settings = {'start_page':1, 'filters':{}}
+ closed_settings = {'start_page':1, 'filters':{}}
+ if form.validate():
+ active_settings['start_page'] = form.active_p.data or 1
+ active_settings['filters']['reported_user_id'] = form.active_reported_user.data
+ active_settings['filters']['reporter_id'] = form.active_reporter.data
+ closed_settings['start_page'] = form.closed_p.data or 1
+ closed_settings['filters']['reported_user_id'] = form.closed_reported_user.data
+ closed_settings['filters']['reporter_id'] = form.closed_reporter.data
+
+ active_settings['filters']=dict((k, v) for k, v in active_settings['filters'].iteritems() if v)
+ closed_settings['filters']=dict((k, v) for k, v in closed_settings['filters'].iteritems() if v)
+ active_filter = [
+ getattr(ReportBase,key)==val \
+for key,val in active_settings['filters'].viewitems()]
+ closed_filter = [
+ getattr(ReportBase,key)==val \
+for key,val in active_settings['filters'].viewitems()]
+
+ all_active = ReportBase.query.filter(
+ ReportBase.discriminator!="archived_report").filter(
+ *active_filter)
+ all_closed = ReportBase.query.filter(
+ ReportBase.discriminator=="archived_report").filter(
+ *closed_filter)
+ report_list = all_active.order_by(
+ ReportBase.created.desc()).offset((active_settings['start_page']-1)*10).limit(10)
+ closed_report_list = all_closed.order_by(
+ ReportBase.created.desc()).offset((closed_settings['start_page']-1)*10).limit(10)
+ active_settings['last_page'] = int(ceil(all_active.count()/10.))
+ closed_settings['last_page'] = int(ceil(all_closed.count()/10.))
# Render to response
return render_to_response(
request,
'mediagoblin/moderation/report_panel.html',
{'report_list':report_list,
- 'closed_report_list':closed_report_list})
+ 'closed_report_list':closed_report_list,
+ 'active_settings':active_settings,
+ 'closed_settings':closed_settings})
@require_admin_or_moderator_login
def moderation_reports_detail(request):