Removes deplicate progress code form reading views
This commit is contained in:
parent
1231d40e80
commit
b5d0a9e0b4
|
@ -316,9 +316,19 @@ urlpatterns = [
|
||||||
re_path(r"^create-readthrough/?$", views.create_readthrough),
|
re_path(r"^create-readthrough/?$", views.create_readthrough),
|
||||||
re_path(r"^delete-progressupdate/?$", views.delete_progressupdate),
|
re_path(r"^delete-progressupdate/?$", views.delete_progressupdate),
|
||||||
# shelve actions
|
# shelve actions
|
||||||
re_path(r"^to-read/(?P<book_id>\d+)/?$", views.WantToRead.as_view(), name="to-read"),
|
re_path(
|
||||||
re_path(r"^start-reading/(?P<book_id>\d+)/?$", views.StartReading.as_view(), name="start-reading"),
|
r"^to-read/(?P<book_id>\d+)/?$", views.WantToRead.as_view(), name="to-read"
|
||||||
re_path(r"^finish-reading/(?P<book_id>\d+)/?$", views.FinishReading.as_view(), name="finish-reading"),
|
),
|
||||||
|
re_path(
|
||||||
|
r"^start-reading/(?P<book_id>\d+)/?$",
|
||||||
|
views.StartReading.as_view(),
|
||||||
|
name="start-reading",
|
||||||
|
),
|
||||||
|
re_path(
|
||||||
|
r"^finish-reading/(?P<book_id>\d+)/?$",
|
||||||
|
views.FinishReading.as_view(),
|
||||||
|
name="finish-reading",
|
||||||
|
),
|
||||||
# following
|
# following
|
||||||
re_path(r"^follow/?$", views.follow, name="follow"),
|
re_path(r"^follow/?$", views.follow, name="follow"),
|
||||||
re_path(r"^unfollow/?$", views.unfollow, name="unfollow"),
|
re_path(r"^unfollow/?$", views.unfollow, name="unfollow"),
|
||||||
|
|
|
@ -13,7 +13,6 @@ from django.views.decorators.http import require_POST
|
||||||
|
|
||||||
from bookwyrm import models
|
from bookwyrm import models
|
||||||
from .helpers import get_edition, handle_reading_status
|
from .helpers import get_edition, handle_reading_status
|
||||||
from .shelf import handle_unshelve
|
|
||||||
|
|
||||||
|
|
||||||
@method_decorator(login_required, name="dispatch")
|
@method_decorator(login_required, name="dispatch")
|
||||||
|
@ -23,36 +22,10 @@ class WantToRead(View):
|
||||||
|
|
||||||
def post(self, request, book_id):
|
def post(self, request, book_id):
|
||||||
"""desire a book"""
|
"""desire a book"""
|
||||||
book = get_edition(book_id)
|
|
||||||
desired_shelf = models.Shelf.objects.filter(
|
desired_shelf = models.Shelf.objects.filter(
|
||||||
identifier=models.Shelf.TO_READ, user=request.user
|
identifier=models.Shelf.TO_READ, user=request.user
|
||||||
).first()
|
).first()
|
||||||
|
return handle_shelve(request, book_id, desired_shelf)
|
||||||
current_status_shelfbook = (
|
|
||||||
models.ShelfBook.objects.select_related("shelf")
|
|
||||||
.filter(
|
|
||||||
shelf__identifier__in=models.Shelf.READ_STATUS_IDENTIFIERS,
|
|
||||||
user=request.user,
|
|
||||||
book=book,
|
|
||||||
)
|
|
||||||
.first()
|
|
||||||
)
|
|
||||||
if current_status_shelfbook is not None:
|
|
||||||
if current_status_shelfbook.shelf.identifier != models.Shelf.READING:
|
|
||||||
handle_unshelve(book, current_status_shelfbook.shelf)
|
|
||||||
else: # It already was on the shelf
|
|
||||||
return redirect(request.headers.get("Referer", "/"))
|
|
||||||
|
|
||||||
models.ShelfBook.objects.create(
|
|
||||||
book=book, shelf=desired_shelf, user=request.user
|
|
||||||
)
|
|
||||||
|
|
||||||
# post about it (if you want)
|
|
||||||
if request.POST.get("post-status"):
|
|
||||||
privacy = request.POST.get("privacy")
|
|
||||||
handle_reading_status(request.user, desired_shelf, book, privacy)
|
|
||||||
|
|
||||||
return redirect(request.headers.get("Referer", "/"))
|
|
||||||
|
|
||||||
|
|
||||||
@method_decorator(login_required, name="dispatch")
|
@method_decorator(login_required, name="dispatch")
|
||||||
|
@ -62,44 +35,10 @@ class StartReading(View):
|
||||||
|
|
||||||
def post(self, request, book_id):
|
def post(self, request, book_id):
|
||||||
"""begin reading a book"""
|
"""begin reading a book"""
|
||||||
book = get_edition(book_id)
|
|
||||||
desired_shelf = models.Shelf.objects.filter(
|
desired_shelf = models.Shelf.objects.filter(
|
||||||
identifier=models.Shelf.READING, user=request.user
|
identifier=models.Shelf.READING, user=request.user
|
||||||
).first()
|
).first()
|
||||||
|
return handle_shelve(request, book_id, desired_shelf)
|
||||||
# create a readthrough
|
|
||||||
readthrough = update_readthrough(request, book=book)
|
|
||||||
if readthrough:
|
|
||||||
readthrough.save()
|
|
||||||
|
|
||||||
# create a progress update if we have a page
|
|
||||||
readthrough.create_update()
|
|
||||||
|
|
||||||
current_status_shelfbook = (
|
|
||||||
models.ShelfBook.objects.select_related("shelf")
|
|
||||||
.filter(
|
|
||||||
shelf__identifier__in=models.Shelf.READ_STATUS_IDENTIFIERS,
|
|
||||||
user=request.user,
|
|
||||||
book=book,
|
|
||||||
)
|
|
||||||
.first()
|
|
||||||
)
|
|
||||||
if current_status_shelfbook is not None:
|
|
||||||
if current_status_shelfbook.shelf.identifier != models.Shelf.READING:
|
|
||||||
handle_unshelve(book, current_status_shelfbook.shelf)
|
|
||||||
else: # It already was on the shelf
|
|
||||||
return redirect(request.headers.get("Referer", "/"))
|
|
||||||
|
|
||||||
models.ShelfBook.objects.create(
|
|
||||||
book=book, shelf=desired_shelf, user=request.user
|
|
||||||
)
|
|
||||||
|
|
||||||
# post about it (if you want)
|
|
||||||
if request.POST.get("post-status"):
|
|
||||||
privacy = request.POST.get("privacy")
|
|
||||||
handle_reading_status(request.user, desired_shelf, book, privacy)
|
|
||||||
|
|
||||||
return redirect(request.headers.get("Referer", "/"))
|
|
||||||
|
|
||||||
|
|
||||||
@method_decorator(login_required, name="dispatch")
|
@method_decorator(login_required, name="dispatch")
|
||||||
|
@ -109,35 +48,24 @@ class FinishReading(View):
|
||||||
|
|
||||||
def post(self, request, book_id):
|
def post(self, request, book_id):
|
||||||
"""a user completed a book, yay"""
|
"""a user completed a book, yay"""
|
||||||
book = get_edition(book_id)
|
|
||||||
desired_shelf = models.Shelf.objects.filter(
|
desired_shelf = models.Shelf.objects.filter(
|
||||||
identifier=models.Shelf.READ_FINISHED, user=request.user
|
identifier=models.Shelf.READ_FINISHED, user=request.user
|
||||||
).first()
|
).first()
|
||||||
|
return handle_shelve(request, book_id, desired_shelf)
|
||||||
|
|
||||||
|
|
||||||
|
def handle_shelve(request, book_id, desired_shelf):
|
||||||
|
"""these are all basically the same"""
|
||||||
|
book = get_edition(book_id)
|
||||||
|
|
||||||
|
reshelve_book(request.user, book, desired_shelf)
|
||||||
|
|
||||||
|
if desired_shelf.identifier != models.Shelf.TO_READ:
|
||||||
# update or create a readthrough
|
# update or create a readthrough
|
||||||
readthrough = update_readthrough(request, book=book)
|
readthrough = update_readthrough(request, book=book)
|
||||||
if readthrough:
|
if readthrough:
|
||||||
readthrough.save()
|
readthrough.save()
|
||||||
|
|
||||||
current_status_shelfbook = (
|
|
||||||
models.ShelfBook.objects.select_related("shelf")
|
|
||||||
.filter(
|
|
||||||
shelf__identifier__in=models.Shelf.READ_STATUS_IDENTIFIERS,
|
|
||||||
user=request.user,
|
|
||||||
book=book,
|
|
||||||
)
|
|
||||||
.first()
|
|
||||||
)
|
|
||||||
if current_status_shelfbook is not None:
|
|
||||||
if current_status_shelfbook.shelf.identifier != models.Shelf.READ_FINISHED:
|
|
||||||
handle_unshelve(book, current_status_shelfbook.shelf)
|
|
||||||
else: # It already was on the shelf
|
|
||||||
return redirect(request.headers.get("Referer", "/"))
|
|
||||||
|
|
||||||
models.ShelfBook.objects.create(
|
|
||||||
book=book, shelf=desired_shelf, user=request.user
|
|
||||||
)
|
|
||||||
|
|
||||||
# post about it (if you want)
|
# post about it (if you want)
|
||||||
if request.POST.get("post-status"):
|
if request.POST.get("post-status"):
|
||||||
privacy = request.POST.get("privacy")
|
privacy = request.POST.get("privacy")
|
||||||
|
@ -146,6 +74,26 @@ class FinishReading(View):
|
||||||
return redirect(request.headers.get("Referer", "/"))
|
return redirect(request.headers.get("Referer", "/"))
|
||||||
|
|
||||||
|
|
||||||
|
def reshelve_book(user, book, desired_shelf):
|
||||||
|
"""move a book to a new shelf"""
|
||||||
|
current_status_shelfbook = (
|
||||||
|
models.ShelfBook.objects.select_related("shelf")
|
||||||
|
.filter(
|
||||||
|
shelf__identifier__in=models.Shelf.READ_STATUS_IDENTIFIERS,
|
||||||
|
user=user,
|
||||||
|
book=book,
|
||||||
|
)
|
||||||
|
.first()
|
||||||
|
)
|
||||||
|
if current_status_shelfbook is not None:
|
||||||
|
if current_status_shelfbook.shelf.identifier != desired_shelf.identifier:
|
||||||
|
current_status_shelfbook.delete()
|
||||||
|
else: # It already was on the shelf
|
||||||
|
return
|
||||||
|
|
||||||
|
models.ShelfBook.objects.create(book=book, shelf=desired_shelf, user=user)
|
||||||
|
|
||||||
|
|
||||||
@login_required
|
@login_required
|
||||||
@require_POST
|
@require_POST
|
||||||
def edit_readthrough(request):
|
def edit_readthrough(request):
|
||||||
|
|
|
@ -201,7 +201,6 @@ def unshelve(request):
|
||||||
return redirect(request.headers.get("Referer", "/"))
|
return redirect(request.headers.get("Referer", "/"))
|
||||||
|
|
||||||
|
|
||||||
# pylint: disable=unused-argument
|
|
||||||
def handle_unshelve(book, shelf):
|
def handle_unshelve(book, shelf):
|
||||||
"""unshelve a book"""
|
"""unshelve a book"""
|
||||||
row = models.ShelfBook.objects.get(book=book, shelf=shelf)
|
row = models.ShelfBook.objects.get(book=book, shelf=shelf)
|
||||||
|
|
Loading…
Reference in New Issue