forked from mirrors/bookwyrm
Fixes list sorting by rating
This commit is contained in:
parent
6dae4ebd6f
commit
92e2c70baf
2 changed files with 59 additions and 18 deletions
|
@ -138,6 +138,55 @@ class ListViews(TestCase):
|
||||||
result.render()
|
result.render()
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
|
def test_list_page_sorted(self):
|
||||||
|
"""there are so many views, this just makes sure it LOADS"""
|
||||||
|
view = views.List.as_view()
|
||||||
|
with patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay"):
|
||||||
|
for (i, book) in enumerate([self.book, self.book_two, self.book_three]):
|
||||||
|
models.ListItem.objects.create(
|
||||||
|
book_list=self.list,
|
||||||
|
user=self.local_user,
|
||||||
|
book=book,
|
||||||
|
approved=True,
|
||||||
|
order=i + 1,
|
||||||
|
)
|
||||||
|
|
||||||
|
request = self.factory.get("/?sort_by=order")
|
||||||
|
request.user = self.local_user
|
||||||
|
with patch("bookwyrm.views.list.is_api_request") as is_api:
|
||||||
|
is_api.return_value = False
|
||||||
|
result = view(request, self.list.id)
|
||||||
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
|
result.render()
|
||||||
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
|
request = self.factory.get("/?sort_by=title")
|
||||||
|
request.user = self.local_user
|
||||||
|
with patch("bookwyrm.views.list.is_api_request") as is_api:
|
||||||
|
is_api.return_value = False
|
||||||
|
result = view(request, self.list.id)
|
||||||
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
|
result.render()
|
||||||
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
|
request = self.factory.get("/?sort_by=rating")
|
||||||
|
request.user = self.local_user
|
||||||
|
with patch("bookwyrm.views.list.is_api_request") as is_api:
|
||||||
|
is_api.return_value = False
|
||||||
|
result = view(request, self.list.id)
|
||||||
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
|
result.render()
|
||||||
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
|
request = self.factory.get("/?sort_by=sdkfh")
|
||||||
|
request.user = self.local_user
|
||||||
|
with patch("bookwyrm.views.list.is_api_request") as is_api:
|
||||||
|
is_api.return_value = False
|
||||||
|
result = view(request, self.list.id)
|
||||||
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
|
result.render()
|
||||||
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
def test_list_page_empty(self):
|
def test_list_page_empty(self):
|
||||||
"""there are so many views, this just makes sure it LOADS"""
|
"""there are so many views, this just makes sure it LOADS"""
|
||||||
view = views.List.as_view()
|
view = views.List.as_view()
|
||||||
|
|
|
@ -5,7 +5,7 @@ from urllib.parse import urlencode
|
||||||
from django.contrib.auth.decorators import login_required
|
from django.contrib.auth.decorators import login_required
|
||||||
from django.core.paginator import Paginator
|
from django.core.paginator import Paginator
|
||||||
from django.db import IntegrityError, transaction
|
from django.db import IntegrityError, transaction
|
||||||
from django.db.models import Avg, Count, Q, Max
|
from django.db.models import Avg, Count, DecimalField, Q, Max
|
||||||
from django.db.models.functions import Coalesce
|
from django.db.models.functions import Coalesce
|
||||||
from django.http import HttpResponseNotFound, HttpResponseBadRequest, HttpResponse
|
from django.http import HttpResponseNotFound, HttpResponseBadRequest, HttpResponse
|
||||||
from django.shortcuts import get_object_or_404, redirect
|
from django.shortcuts import get_object_or_404, redirect
|
||||||
|
@ -108,31 +108,23 @@ class List(View):
|
||||||
if direction not in ("ascending", "descending"):
|
if direction not in ("ascending", "descending"):
|
||||||
direction = "ascending"
|
direction = "ascending"
|
||||||
|
|
||||||
internal_sort_by = {
|
directional_sort_by = {
|
||||||
"order": "order",
|
"order": "order",
|
||||||
"title": "book__title",
|
"title": "book__title",
|
||||||
"rating": "average_rating",
|
"rating": "average_rating",
|
||||||
}
|
}[sort_by]
|
||||||
directional_sort_by = internal_sort_by[sort_by]
|
|
||||||
if direction == "descending":
|
if direction == "descending":
|
||||||
directional_sort_by = "-" + directional_sort_by
|
directional_sort_by = "-" + directional_sort_by
|
||||||
|
|
||||||
if sort_by == "order":
|
items = book_list.listitem_set
|
||||||
items = book_list.listitem_set.filter(approved=True).order_by(
|
if sort_by == "rating":
|
||||||
directional_sort_by
|
items = items.annotate(
|
||||||
)
|
average_rating=Avg(
|
||||||
elif sort_by == "title":
|
Coalesce("book__review__rating", 0.0),
|
||||||
items = book_list.listitem_set.filter(approved=True).order_by(
|
output_field=DecimalField(),
|
||||||
directional_sort_by
|
|
||||||
)
|
|
||||||
elif sort_by == "rating":
|
|
||||||
items = (
|
|
||||||
book_list.listitem_set.annotate(
|
|
||||||
average_rating=Avg(Coalesce("book__review__rating", 0))
|
|
||||||
)
|
)
|
||||||
.filter(approved=True)
|
|
||||||
.order_by(directional_sort_by)
|
|
||||||
)
|
)
|
||||||
|
items = items.filter(approved=True).order_by(directional_sort_by)
|
||||||
|
|
||||||
paginated = Paginator(items, PAGE_LENGTH)
|
paginated = Paginator(items, PAGE_LENGTH)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue