mirror of
https://github.com/bookwyrm-social/bookwyrm.git
synced 2025-01-25 16:38:09 +00:00
Merge pull request #844 from mouse-reeve/invite-sorting
Invite request sorting
This commit is contained in:
commit
7599d18799
2 changed files with 51 additions and 7 deletions
|
@ -26,11 +26,20 @@
|
||||||
{% endif %} ({{ count }})
|
{% endif %} ({{ count }})
|
||||||
</h2>
|
</h2>
|
||||||
|
|
||||||
|
{% include 'settings/invite_request_filters.html' %}
|
||||||
|
|
||||||
<table class="table is-striped">
|
<table class="table is-striped">
|
||||||
|
{% url 'settings-invite-requests' as url %}
|
||||||
<tr>
|
<tr>
|
||||||
<th>{% trans "Date" %}</th>
|
<th>
|
||||||
|
{% trans "Date" as text %}
|
||||||
|
{% include 'snippets/table-sort-header.html' with field="created_date" sort=sort text=text %}
|
||||||
|
</th>
|
||||||
<th>{% trans "Email" %}</th>
|
<th>{% trans "Email" %}</th>
|
||||||
<th>{% trans "Status" %}</th>
|
<th>
|
||||||
|
{% trans "Status" as text %}
|
||||||
|
{% include 'snippets/table-sort-header.html' with field="invite__times_used" sort=sort text=text %}
|
||||||
|
</th>
|
||||||
<th>{% trans "Action" %}</th>
|
<th>{% trans "Action" %}</th>
|
||||||
</tr>
|
</tr>
|
||||||
{% if not requests %}
|
{% if not requests %}
|
||||||
|
@ -50,7 +59,7 @@
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</td>
|
</td>
|
||||||
<td class="field is-grouped">
|
<td class="field is-grouped">
|
||||||
<form name="send-invite" method="post" action="{% url 'settings-invite-requests' %}">
|
<form name="send-invite" method="post">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<input type="hidden" name="invite-request" value="{{ req.id }}">
|
<input type="hidden" name="invite-request" value="{{ req.id }}">
|
||||||
{% if not req.invite %}
|
{% if not req.invite %}
|
||||||
|
|
|
@ -1,9 +1,15 @@
|
||||||
""" invites when registration is closed """
|
""" invites when registration is closed """
|
||||||
|
from functools import reduce
|
||||||
|
import operator
|
||||||
|
from urllib.parse import urlencode
|
||||||
|
|
||||||
from django.contrib.auth.decorators import login_required, permission_required
|
from django.contrib.auth.decorators import login_required, permission_required
|
||||||
from django.core.paginator import Paginator
|
from django.core.paginator import Paginator
|
||||||
|
from django.db.models import Q
|
||||||
from django.http import HttpResponseBadRequest
|
from django.http import HttpResponseBadRequest
|
||||||
from django.shortcuts import get_object_or_404, redirect
|
from django.shortcuts import get_object_or_404, redirect
|
||||||
from django.template.response import TemplateResponse
|
from django.template.response import TemplateResponse
|
||||||
|
from django.urls import reverse
|
||||||
from django.utils.decorators import method_decorator
|
from django.utils.decorators import method_decorator
|
||||||
from django.views import View
|
from django.views import View
|
||||||
from django.views.decorators.http import require_POST
|
from django.views.decorators.http import require_POST
|
||||||
|
@ -92,10 +98,34 @@ class ManageInviteRequests(View):
|
||||||
except ValueError:
|
except ValueError:
|
||||||
page = 1
|
page = 1
|
||||||
|
|
||||||
|
sort = request.GET.get("sort")
|
||||||
|
sort_fields = ["created_date", "invite__times_used"]
|
||||||
|
if not sort in sort_fields + ["-{:s}".format(f) for f in sort_fields]:
|
||||||
|
sort = "-created_date"
|
||||||
|
|
||||||
|
requests = models.InviteRequest.objects.filter(ignored=ignored).order_by(sort)
|
||||||
|
|
||||||
|
status_filters = [
|
||||||
|
s
|
||||||
|
for s in request.GET.getlist("status")
|
||||||
|
if s in ["requested", "sent", "accepted"]
|
||||||
|
]
|
||||||
|
|
||||||
|
filters = []
|
||||||
|
if "requested" in status_filters:
|
||||||
|
filters.append({"invite__isnull": True})
|
||||||
|
if "sent" in status_filters:
|
||||||
|
filters.append({"invite__isnull": False})
|
||||||
|
if "accepted" in status_filters:
|
||||||
|
filters.append({"invite__isnull": False, "invite__times_used__gte": 1})
|
||||||
|
|
||||||
|
if filters:
|
||||||
|
requests = requests.filter(
|
||||||
|
reduce(operator.or_, (Q(**f) for f in filters))
|
||||||
|
).distinct()
|
||||||
|
|
||||||
paginated = Paginator(
|
paginated = Paginator(
|
||||||
models.InviteRequest.objects.filter(ignored=ignored).order_by(
|
requests,
|
||||||
"-created_date"
|
|
||||||
),
|
|
||||||
PAGE_LENGTH,
|
PAGE_LENGTH,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -103,6 +133,7 @@ class ManageInviteRequests(View):
|
||||||
"ignored": ignored,
|
"ignored": ignored,
|
||||||
"count": paginated.count,
|
"count": paginated.count,
|
||||||
"requests": paginated.page(page),
|
"requests": paginated.page(page),
|
||||||
|
"sort": sort,
|
||||||
}
|
}
|
||||||
return TemplateResponse(request, "settings/manage_invite_requests.html", data)
|
return TemplateResponse(request, "settings/manage_invite_requests.html", data)
|
||||||
|
|
||||||
|
@ -119,7 +150,11 @@ class ManageInviteRequests(View):
|
||||||
)
|
)
|
||||||
invite_request.save()
|
invite_request.save()
|
||||||
emailing.invite_email(invite_request)
|
emailing.invite_email(invite_request)
|
||||||
return redirect("settings-invite-requests")
|
return redirect(
|
||||||
|
"{:s}?{:s}".format(
|
||||||
|
reverse("settings-invite-requests"), urlencode(request.GET.dict())
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class InviteRequest(View):
|
class InviteRequest(View):
|
||||||
|
|
Loading…
Reference in a new issue