1
0
Fork 1
mirror of https://github.com/bookwyrm-social/bookwyrm.git synced 2025-01-11 17:55:37 +00:00

Merge pull request from cthulahoops/not_logged_in

Book & books while not logged in
This commit is contained in:
Mouse Reeve 2020-03-27 08:56:16 -07:00 committed by GitHub
commit 448e874851
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 52 additions and 33 deletions

View file

@ -25,6 +25,7 @@
</div> </div>
</div> </div>
{% if request.user.is_authenticated %}
<div class="content-container"> <div class="content-container">
<h2>Leave a review</h2> <h2>Leave a review</h2>
<form class="review-form" name="review" action="/review/" method="post"> <form class="review-form" name="review" action="/review/" method="post">
@ -38,6 +39,7 @@
<div class="content-container tabs"> <div class="content-container tabs">
{% include 'snippets/tabs.html' with tabs=feed_tabs active_tab=active_tab path=path %} {% include 'snippets/tabs.html' with tabs=feed_tabs active_tab=active_tab path=path %}
</div> </div>
{% endif %}
{% if not reviews %} {% if not reviews %}
<div class="content-container"> <div class="content-container">

View file

@ -26,7 +26,9 @@
<div id="branding"><a href="/"><img id="logo" src="/static/images/logo-small.png" alt="BookWyrm"></img></a></div> <div id="branding"><a href="/"><img id="logo" src="/static/images/logo-small.png" alt="BookWyrm"></img></a></div>
<ul class="menu"> <ul class="menu">
{% if request.user.is_authenticated %}
<li><a href="/user/{{request.user.localname}}/shelves">Your shelves</a></li> <li><a href="/user/{{request.user.localname}}/shelves">Your shelves</a></li>
{% endif %}
<li><a href="/#feed">Updates</a></li> <li><a href="/#feed">Updates</a></li>
<li><a href="/books">Discover Books</a></li> <li><a href="/books">Discover Books</a></li>
</ul> </ul>

View file

@ -1,4 +1,5 @@
{% load fr_display %} {% load fr_display %}
{% if request.user.is_authenticated %}
{% if not pulldown %} {% if not pulldown %}
<form name="shelve" action="/shelve/" method="post"> <form name="shelve" action="/shelve/" method="post">
@ -25,3 +26,4 @@
</form> </form>
{% endif %} {% endif %}
{% endif %}

View file

@ -98,11 +98,11 @@ def home_tab(request, tab):
def books_page(request): def books_page(request):
''' discover books ''' ''' discover books '''
recent_books = models.Book.objects.filter( recent_books = models.Book.objects
~Q(shelfbook__shelf__user=request.user) if request.user.is_authenticated:
).order_by( recent_books = recent_books.filter(~Q(shelfbook__shelf__user=request.user))
'-created_date' recent_books = recent_books.order_by('-created_date')[:50]
)[:50]
data = { data = {
'books': recent_books, 'books': recent_books,
} }
@ -306,32 +306,48 @@ def book_page(request, book_identifier, tab='friends'):
else: else:
book_reviews = models.Review.objects.filter(book=book) book_reviews = models.Review.objects.filter(book=book)
user_reviews = book_reviews.filter( if request.user.is_authenticated:
user=request.user, user_reviews = book_reviews.filter(
).all() user=request.user,
).all()
if tab == 'friends': if tab == 'friends':
reviews = book_reviews.filter( reviews = book_reviews.filter(
Q(user__followers=request.user, privacy='public') | \ Q(user__followers=request.user, privacy='public') | \
Q(user=request.user) | \ Q(user=request.user) | \
Q(mention_users=request.user), Q(mention_users=request.user),
) )
elif tab == 'local': elif tab == 'local':
reviews = book_reviews.filter( reviews = book_reviews.filter(
Q(privacy='public') | \ Q(privacy='public') | \
Q(mention_users=request.user), Q(mention_users=request.user),
user__local=True, user__local=True,
) )
else:
reviews = book_reviews.filter(
Q(privacy='public') | \
Q(mention_users=request.user),
)
try:
shelf = models.Shelf.objects.get(user=request.user, book=book)
except models.Shelf.DoesNotExist:
shelf = None
user_tags = models.Tag.objects.filter(
book=book, user=request.user
).all()
user_tag_names = user_tags.values_list('identifier', flat=True)
user_rating = user_reviews.aggregate(Avg('rating')),
else: else:
reviews = book_reviews.filter( tab = 'public'
Q(privacy='public') | \ reviews = book_reviews.filter(privacy='public')
Q(mention_users=request.user),
)
try:
shelf = models.Shelf.objects.get(user=request.user, book=book)
except models.Shelf.DoesNotExist:
shelf = None shelf = None
user_reviews = []
user_rating = None
user_tags = []
user_tag_names = []
rating = reviews.aggregate(Avg('rating')) rating = reviews.aggregate(Avg('rating'))
tags = models.Tag.objects.filter( tags = models.Tag.objects.filter(
@ -339,9 +355,6 @@ def book_page(request, book_identifier, tab='friends'):
).values( ).values(
'book', 'name', 'identifier' 'book', 'name', 'identifier'
).distinct().all() ).distinct().all()
user_tags = models.Tag.objects.filter(
book=book, user=request.user
).all()
review_form = forms.ReviewForm() review_form = forms.ReviewForm()
tag_form = forms.TagForm() tag_form = forms.TagForm()
@ -349,12 +362,12 @@ def book_page(request, book_identifier, tab='friends'):
'book': book, 'book': book,
'shelf': shelf, 'shelf': shelf,
'user_reviews': user_reviews, 'user_reviews': user_reviews,
'user_rating': user_reviews.aggregate(Avg('rating')), 'user_rating': user_rating,
'reviews': reviews.distinct(), 'reviews': reviews.distinct(),
'rating': rating['rating__avg'], 'rating': rating['rating__avg'],
'tags': tags, 'tags': tags,
'user_tags': user_tags, 'user_tags': user_tags,
'user_tag_names': user_tags.values_list('identifier', flat=True), 'user_tag_names': user_tag_names,
'review_form': review_form, 'review_form': review_form,
'tag_form': tag_form, 'tag_form': tag_form,
'feed_tabs': [ 'feed_tabs': [