Merge pull request #2199 from bookwyrm-social/user-admin-deleted

Move deleted users to separate tab in admin panel
This commit is contained in:
Mouse Reeve 2022-07-08 09:38:27 -07:00 committed by GitHub
commit 4af0095237
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 22 additions and 11 deletions

View file

@ -56,7 +56,7 @@
<dt class="is-pulled-left mr-5">{% trans "Users:" %}</dt> <dt class="is-pulled-left mr-5">{% trans "Users:" %}</dt>
<dd> <dd>
{{ users.count }} {{ users.count }}
{% if server.user_set.count %}(<a href="{% url 'settings-users' %}?server={{ server.server_name }}">{% trans "View all" %}</a>){% endif %} {% if server.user_set.count %}(<a href="{% url 'settings-users' status="federated" %}?server={{ server.server_name }}">{% trans "View all" %}</a>){% endif %}
</dd> </dd>
<dt class="is-pulled-left mr-5">{% trans "Reports:" %}</dt> <dt class="is-pulled-left mr-5">{% trans "Reports:" %}</dt>

View file

@ -24,6 +24,10 @@
<li {% if request.path in url %}class="is-active" aria-current="page"{% endif %}> <li {% if request.path in url %}class="is-active" aria-current="page"{% endif %}>
<a href="{{ url }}">{% trans "Local users" %}</a> <a href="{{ url }}">{% trans "Local users" %}</a>
</li> </li>
{% url 'settings-users' status="deleted" as url %}
<li {% if url in request.path %}class="is-active" aria-current="page"{% endif %}>
<a href="{{ url }}">{% trans "Deleted users" %}</a>
</li>
{% url 'settings-users' status="federated" as url %} {% url 'settings-users' status="federated" as url %}
<li {% if url in request.path %}class="is-active" aria-current="page"{% endif %}> <li {% if url in request.path %}class="is-active" aria-current="page"{% endif %}>
<a href="{{ url }}">{% trans "Federated community" %}</a> <a href="{{ url }}">{% trans "Federated community" %}</a>
@ -36,7 +40,7 @@
<table class="table is-striped is-fullwidth"> <table class="table is-striped is-fullwidth">
<tr> <tr>
{% url 'settings-users' as url %} {% url 'settings-users' as url %}
<th> <th colspan="2">
{% trans "Username" as text %} {% trans "Username" as text %}
{% include 'snippets/table-sort-header.html' with field="username" sort=sort text=text %} {% include 'snippets/table-sort-header.html' with field="username" sort=sort text=text %}
</th> </th>
@ -52,7 +56,7 @@
{% trans "Status" as text %} {% trans "Status" as text %}
{% include 'snippets/table-sort-header.html' with field="is_active" sort=sort text=text %} {% include 'snippets/table-sort-header.html' with field="is_active" sort=sort text=text %}
</th> </th>
{% if status != "local" %} {% if status == "federated" %}
<th> <th>
{% trans "Remote instance" as text %} {% trans "Remote instance" as text %}
{% include 'snippets/table-sort-header.html' with field="federated_server__server_name" sort=sort text=text %} {% include 'snippets/table-sort-header.html' with field="federated_server__server_name" sort=sort text=text %}
@ -61,7 +65,10 @@
</tr> </tr>
{% for user in users %} {% for user in users %}
<tr> <tr>
<td class="overflow-wrap-anywhere"> <td class="pr-0">
{% include 'snippets/avatar.html' with user=user %}
</td>
<td class="overflow-wrap-anywhere pl-1">
<a href="{% url 'settings-user' user.id %}">{{ user|username }}</a> <a href="{% url 'settings-user' user.id %}">{{ user|username }}</a>
</td> </td>
<td>{{ user.created_date }}</td> <td>{{ user.created_date }}</td>
@ -86,7 +93,7 @@
<span class="help">({{ user.get_deactivation_reason_display }})</span> <span class="help">({{ user.get_deactivation_reason_display }})</span>
{% endif %} {% endif %}
</td> </td>
{% if status != "local" %} {% if status == "federated" %}
<td> <td>
{% if user.federated_server %} {% if user.federated_server %}
<a href="{% url 'settings-federated-server' user.federated_server.id %}">{{ user.federated_server.server_name }}</a> <a href="{% url 'settings-federated-server' user.federated_server.id %}">{{ user.federated_server.server_name }}</a>

View file

@ -126,7 +126,7 @@ urlpatterns = [
r"^settings/users/?$", views.UserAdminList.as_view(), name="settings-users" r"^settings/users/?$", views.UserAdminList.as_view(), name="settings-users"
), ),
re_path( re_path(
r"^settings/users/(?P<status>(local|federated))\/?$", r"^settings/users/(?P<status>(local|federated|deleted))\/?$",
views.UserAdminList.as_view(), views.UserAdminList.as_view(),
name="settings-users", name="settings-users",
), ),

View file

@ -22,21 +22,25 @@ class UserAdminList(View):
def get(self, request, status="local"): def get(self, request, status="local"):
"""list of users""" """list of users"""
filters = {} filters = {}
exclusions = {}
if server := request.GET.get("server"): if server := request.GET.get("server"):
server = models.FederatedServer.objects.filter(server_name=server).first() server = models.FederatedServer.objects.filter(server_name=server).first()
filters["federated_server"] = server filters["federated_server"] = server
filters["federated_server__isnull"] = False filters["federated_server__isnull"] = False
if username := request.GET.get("username"): if username := request.GET.get("username"):
filters["username__icontains"] = username filters["username__icontains"] = username
scope = request.GET.get("scope")
if scope and scope == "local":
filters["local"] = True
if email := request.GET.get("email"): if email := request.GET.get("email"):
filters["email__endswith"] = email filters["email__endswith"] = email
filters["local"] = status == "local" filters["local"] = status in ["local", "deleted"]
if status == "deleted":
filters["deactivation_reason__icontains"] = "deletion"
else:
exclusions["deactivation_reason__icontains"] = "deletion"
users = models.User.objects.filter(**filters) users = models.User.objects.filter(**filters).exclude(**exclusions)
sort = request.GET.get("sort", "-created_date") sort = request.GET.get("sort", "-created_date")
sort_fields = [ sort_fields = [