forked from mirrors/bookwyrm
commit
c08be903b1
14 changed files with 55 additions and 94 deletions
|
@ -28,7 +28,7 @@
|
||||||
|
|
||||||
{% if request.user.is_authenticated and not book.cover %}
|
{% if request.user.is_authenticated and not book.cover %}
|
||||||
<div class="box p-2">
|
<div class="box p-2">
|
||||||
<form name="add-cover" method="POST" action="/upload_cover/{{ book.id }}" enctype="multipart/form-data">
|
<form name="add-cover" method="POST" action="/upload-cover/{{ book.id }}" enctype="multipart/form-data">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<div class="field">
|
<div class="field">
|
||||||
<label class="label" for="id_cover">Cover:</label>
|
<label class="label" for="id_cover">Cover:</label>
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<form class="block" name="edit-book" action="/edit_book/{{ book.id }}" method="post" enctype="multipart/form-data">
|
<form class="block" name="edit-book" action="/edit-book/{{ book.id }}" method="post" enctype="multipart/form-data">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<div class="block">
|
<div class="block">
|
||||||
<h2 class="title is-4">Data sync
|
<h2 class="title is-4">Data sync
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
{% if form.non_field_errors %}
|
{% if form.non_field_errors %}
|
||||||
<p class="notification is-danger">{{ form.non_field_errors }}</p>
|
<p class="notification is-danger">{{ form.non_field_errors }}</p>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<form name="edit-profile" action="/edit_profile/" method="post" enctype="multipart/form-data">
|
<form name="edit-profile" action="/edit-profile/" method="post" enctype="multipart/form-data">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<p class="block">
|
<p class="block">
|
||||||
<label class="label" for="id_avatar">Avatar:</label>
|
<label class="label" for="id_avatar">Avatar:</label>
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
{% block content %}
|
{% block content %}
|
||||||
<div class="block">
|
<div class="block">
|
||||||
<h1 class="title">Import Books from GoodReads</h1>
|
<h1 class="title">Import Books from GoodReads</h1>
|
||||||
<form name="import" action="/import_data/" method="post" enctype="multipart/form-data">
|
<form name="import" action="/import-data/" method="post" enctype="multipart/form-data">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<div class="field">
|
<div class="field">
|
||||||
{{ import_form.as_p }}
|
{{ import_form.as_p }}
|
||||||
|
@ -31,7 +31,7 @@
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<ul>
|
<ul>
|
||||||
{% for job in jobs %}
|
{% for job in jobs %}
|
||||||
<li><a href="/import_status/{{ job.id }}">{{ job.created_date | naturaltime }}</a></li>
|
<li><a href="/import-status/{{ job.id }}">{{ job.created_date | naturaltime }}</a></li>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
<div class="block">
|
<div class="block">
|
||||||
<h2 class="title is-4">Generate New Invite</h2>
|
<h2 class="title is-4">Generate New Invite</h2>
|
||||||
|
|
||||||
<form name="invite" action="/create_invite/" method="post">
|
<form name="invite" action="/create-invite/" method="post">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<div class="field is-grouped">
|
<div class="field is-grouped">
|
||||||
<div class="control">
|
<div class="control">
|
||||||
|
|
|
@ -44,7 +44,7 @@
|
||||||
boosted your <a href="{{ notification.related_status.remote_id}}">status</a>
|
boosted your <a href="{{ notification.related_status.remote_id}}">status</a>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% else %}
|
{% else %}
|
||||||
your <a href="/import_status/{{ notification.related_import.id }}">import</a> completed.
|
your <a href="/import-status/{{ notification.related_import.id }}">import</a> completed.
|
||||||
|
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</p>
|
</p>
|
||||||
|
|
|
@ -47,7 +47,7 @@
|
||||||
<ul>
|
<ul>
|
||||||
{% for result in result_set.results %}
|
{% for result in result_set.results %}
|
||||||
<li class="pb-4">
|
<li class="pb-4">
|
||||||
<form action="/resolve_book" method="POST">
|
<form action="/resolve-book" method="POST">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<input type="hidden" name="remote_id" value="{{ result.key }}">
|
<input type="hidden" name="remote_id" value="{{ result.key }}">
|
||||||
<div>{% include 'snippets/search_result_text.html' with result=result link=False %}</div>
|
<div>{% include 'snippets/search_result_text.html' with result=result link=False %}</div>
|
||||||
|
|
|
@ -9,10 +9,9 @@
|
||||||
<label class="delete" for="finish-reading-{{ uuid }}" aria-label="close" role="button"></label>
|
<label class="delete" for="finish-reading-{{ uuid }}" aria-label="close" role="button"></label>
|
||||||
</header>
|
</header>
|
||||||
{% active_read_through book user as readthrough %}
|
{% active_read_through book user as readthrough %}
|
||||||
<form name="finish-reading" action="/finish-reading" method="post">
|
<form name="finish-reading" action="/finish-reading/{{ book.id }}" method="post">
|
||||||
<section class="modal-card-body">
|
<section class="modal-card-body">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<input type="hidden" name="book" value="{{ book.id }}">
|
|
||||||
<input type="hidden" name="id" value="{{ readthrough.id }}">
|
<input type="hidden" name="id" value="{{ readthrough.id }}">
|
||||||
<div class="field">
|
<div class="field">
|
||||||
<label class="label">
|
<label class="label">
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
{% load fr_display %}
|
{% load fr_display %}
|
||||||
{% if request.user|follow_request_exists:user %}
|
{% if request.user|follow_request_exists:user %}
|
||||||
<form action="/accept_follow_request/" method="POST">
|
<form action="/accept-follow-request/" method="POST">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<input type="hidden" name="user" value="{{ user.username }}">
|
<input type="hidden" name="user" value="{{ user.username }}">
|
||||||
<button class="button is-primary is-small" type="submit">Accept</button>
|
<button class="button is-primary is-small" type="submit">Accept</button>
|
||||||
</form>
|
</form>
|
||||||
<form action="/delete_follow_request/" method="POST">
|
<form action="/delete-follow-request/" method="POST">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<input type="hidden" name="user" value="{{ user.username }}">
|
<input type="hidden" name="user" value="{{ user.username }}">
|
||||||
<button class="button is-danger is-light is-small" type="submit" class="warning">Delete</button>
|
<button class="button is-danger is-light is-small" type="submit" class="warning">Delete</button>
|
||||||
|
|
|
@ -7,10 +7,9 @@
|
||||||
<p class="modal-card-title">Start "{{ book.title }}"</p>
|
<p class="modal-card-title">Start "{{ book.title }}"</p>
|
||||||
<label class="delete" for="start-reading-{{ uuid }}" aria-label="close" role="button" tabindex="0"></label>
|
<label class="delete" for="start-reading-{{ uuid }}" aria-label="close" role="button" tabindex="0"></label>
|
||||||
</header>
|
</header>
|
||||||
<form name="start-reading" action="/start-reading" method="post">
|
<form name="start-reading" action="/start-reading/{{ book.id }}" method="post">
|
||||||
<section class="modal-card-body">
|
<section class="modal-card-body">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<input type="hidden" name="book" value="{{ book.id }}">
|
|
||||||
<div class="field">
|
<div class="field">
|
||||||
<label class="label">
|
<label class="label">
|
||||||
Started reading
|
Started reading
|
||||||
|
|
|
@ -82,9 +82,8 @@
|
||||||
<div class="toggle-content hidden card-footer">
|
<div class="toggle-content hidden card-footer">
|
||||||
{% if status.user == request.user %}
|
{% if status.user == request.user %}
|
||||||
<div class="card-footer-item">
|
<div class="card-footer-item">
|
||||||
<form name="delete-{{status.id}}" action="/delete-status" method="post">
|
<form name="delete-{{status.id}}" action="/delete-status/{{ status.id }}" method="post">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<input type="hidden" name="status" value="{{ status.id }}">
|
|
||||||
<button class="button is-danger is-light" type="submit">
|
<button class="button is-danger is-light" type="submit">
|
||||||
Delete post
|
Delete post
|
||||||
</button>
|
</button>
|
||||||
|
|
|
@ -55,7 +55,7 @@ urlpatterns = [
|
||||||
re_path(r'^(?P<tab>home|local|federated)/?$', views.home_tab),
|
re_path(r'^(?P<tab>home|local|federated)/?$', views.home_tab),
|
||||||
re_path(r'^notifications/?', views.notifications_page),
|
re_path(r'^notifications/?', views.notifications_page),
|
||||||
re_path(r'import/?$', views.import_page),
|
re_path(r'import/?$', views.import_page),
|
||||||
re_path(r'import_status/(\d+)/?$', views.import_status),
|
re_path(r'import-status/(\d+)/?$', views.import_status),
|
||||||
re_path(r'user-edit/?$', views.edit_profile_page),
|
re_path(r'user-edit/?$', views.edit_profile_page),
|
||||||
|
|
||||||
# should return a ui view or activitypub json blob as requested
|
# should return a ui view or activitypub json blob as requested
|
||||||
|
@ -78,7 +78,7 @@ urlpatterns = [
|
||||||
re_path(r'%s/editions(.json)?/?$' % book_path, views.editions_page),
|
re_path(r'%s/editions(.json)?/?$' % book_path, views.editions_page),
|
||||||
|
|
||||||
re_path(r'^author/(?P<author_id>[\w\-]+)(.json)?/?$', views.author_page),
|
re_path(r'^author/(?P<author_id>[\w\-]+)(.json)?/?$', views.author_page),
|
||||||
# TODO: tag needs a .json path
|
re_path(r'^tag/(?P<tag_id>.+)\.json/?$', views.tag_page),
|
||||||
re_path(r'^tag/(?P<tag_id>.+)/?$', views.tag_page),
|
re_path(r'^tag/(?P<tag_id>.+)/?$', views.tag_page),
|
||||||
re_path(r'^%s/shelf/(?P<shelf_identifier>[\w-]+)(.json)?/?$' % \
|
re_path(r'^%s/shelf/(?P<shelf_identifier>[\w-]+)(.json)?/?$' % \
|
||||||
user_path, views.shelf_page),
|
user_path, views.shelf_page),
|
||||||
|
@ -95,12 +95,12 @@ urlpatterns = [
|
||||||
re_path(r'^reset-password/?$', actions.password_reset),
|
re_path(r'^reset-password/?$', actions.password_reset),
|
||||||
re_path(r'^change-password/?$', actions.password_change),
|
re_path(r'^change-password/?$', actions.password_change),
|
||||||
|
|
||||||
re_path(r'^edit_profile/?$', actions.edit_profile),
|
re_path(r'^edit-profile/?$', actions.edit_profile),
|
||||||
|
|
||||||
re_path(r'^import_data/?', actions.import_data),
|
re_path(r'^import-data/?', actions.import_data),
|
||||||
re_path(r'^resolve_book/?', actions.resolve_book),
|
re_path(r'^resolve-book/?', actions.resolve_book),
|
||||||
re_path(r'^edit_book/(?P<book_id>\d+)/?', actions.edit_book),
|
re_path(r'^edit-book/(?P<book_id>\d+)/?', actions.edit_book),
|
||||||
re_path(r'^upload_cover/(?P<book_id>\d+)/?', actions.upload_cover),
|
re_path(r'^upload-cover/(?P<book_id>\d+)/?', actions.upload_cover),
|
||||||
|
|
||||||
re_path(r'^edit-readthrough/?', actions.edit_readthrough),
|
re_path(r'^edit-readthrough/?', actions.edit_readthrough),
|
||||||
re_path(r'^delete-readthrough/?', actions.delete_readthrough),
|
re_path(r'^delete-readthrough/?', actions.delete_readthrough),
|
||||||
|
@ -118,23 +118,23 @@ urlpatterns = [
|
||||||
re_path(r'^boost/(?P<status_id>\d+)/?$', actions.boost),
|
re_path(r'^boost/(?P<status_id>\d+)/?$', actions.boost),
|
||||||
re_path(r'^unboost/(?P<status_id>\d+)/?$', actions.unboost),
|
re_path(r'^unboost/(?P<status_id>\d+)/?$', actions.unboost),
|
||||||
|
|
||||||
re_path(r'^delete-status/?$', actions.delete_status),
|
re_path(r'^delete-status/(?P<status_id>\d+)/?$', actions.delete_status),
|
||||||
|
|
||||||
re_path(r'^create-shelf/?$', actions.create_shelf),
|
re_path(r'^create-shelf/?$', actions.create_shelf),
|
||||||
re_path(r'^edit-shelf/(?P<shelf_id>\d+)?$', actions.edit_shelf),
|
re_path(r'^edit-shelf/(?P<shelf_id>\d+)?$', actions.edit_shelf),
|
||||||
re_path(r'^delete-shelf/(?P<shelf_id>\d+)?$', actions.delete_shelf),
|
re_path(r'^delete-shelf/(?P<shelf_id>\d+)?$', actions.delete_shelf),
|
||||||
re_path(r'^shelve/?$', actions.shelve),
|
re_path(r'^shelve/?$', actions.shelve),
|
||||||
re_path(r'^unshelve/?$', actions.unshelve),
|
re_path(r'^unshelve/?$', actions.unshelve),
|
||||||
re_path(r'^start-reading/?$', actions.start_reading),
|
re_path(r'^start-reading/(?P<book_id>\d+)/?$', actions.start_reading),
|
||||||
re_path(r'^finish-reading/?$', actions.finish_reading),
|
re_path(r'^finish-reading/(?P<book_id>\d+)/?$', actions.finish_reading),
|
||||||
|
|
||||||
re_path(r'^follow/?$', actions.follow),
|
re_path(r'^follow/?$', actions.follow),
|
||||||
re_path(r'^unfollow/?$', actions.unfollow),
|
re_path(r'^unfollow/?$', actions.unfollow),
|
||||||
re_path(r'^accept_follow_request/?$', actions.accept_follow_request),
|
re_path(r'^accept-follow-request/?$', actions.accept_follow_request),
|
||||||
re_path(r'^delete_follow_request/?$', actions.delete_follow_request),
|
re_path(r'^delete-follow-request/?$', actions.delete_follow_request),
|
||||||
|
|
||||||
re_path(r'^clear-notifications/?$', actions.clear_notifications),
|
re_path(r'^clear-notifications/?$', actions.clear_notifications),
|
||||||
|
|
||||||
re_path(r'^create_invite/?$', actions.create_invite),
|
re_path(r'^create-invite/?$', actions.create_invite),
|
||||||
|
|
||||||
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
|
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
|
||||||
|
|
|
@ -61,10 +61,7 @@ def register(request):
|
||||||
if not invite_code:
|
if not invite_code:
|
||||||
raise PermissionDenied
|
raise PermissionDenied
|
||||||
|
|
||||||
try:
|
invite = get_object_or_404(models.SiteInvite, code=invite_code)
|
||||||
invite = models.SiteInvite.objects.get(code=invite_code)
|
|
||||||
except models.SiteInvite.DoesNotExist:
|
|
||||||
raise PermissionDenied
|
|
||||||
else:
|
else:
|
||||||
invite = None
|
invite = None
|
||||||
|
|
||||||
|
@ -234,10 +231,7 @@ def edit_book(request, book_id):
|
||||||
if not request.method == 'POST':
|
if not request.method == 'POST':
|
||||||
return redirect('/book/%s' % book_id)
|
return redirect('/book/%s' % book_id)
|
||||||
|
|
||||||
try:
|
book = get_object_or_404(models.Edition, id=book_id)
|
||||||
book = models.Edition.objects.get(id=book_id)
|
|
||||||
except models.Edition.DoesNotExist:
|
|
||||||
return HttpResponseNotFound()
|
|
||||||
|
|
||||||
form = forms.EditionForm(request.POST, request.FILES, instance=book)
|
form = forms.EditionForm(request.POST, request.FILES, instance=book)
|
||||||
if not form.is_valid():
|
if not form.is_valid():
|
||||||
|
@ -251,14 +245,10 @@ def edit_book(request, book_id):
|
||||||
@login_required
|
@login_required
|
||||||
def upload_cover(request, book_id):
|
def upload_cover(request, book_id):
|
||||||
''' upload a new cover '''
|
''' upload a new cover '''
|
||||||
# TODO: alternate covers?
|
|
||||||
if not request.method == 'POST':
|
if not request.method == 'POST':
|
||||||
return redirect('/book/%s' % request.user.localname)
|
return redirect('/book/%s' % request.user.localname)
|
||||||
|
|
||||||
try:
|
book = get_object_or_404(models.Edition, id=book_id)
|
||||||
book = models.Edition.objects.get(id=book_id)
|
|
||||||
except models.Edition.DoesNotExist:
|
|
||||||
return HttpResponseNotFound()
|
|
||||||
|
|
||||||
form = forms.CoverForm(request.POST, request.FILES, instance=book)
|
form = forms.CoverForm(request.POST, request.FILES, instance=book)
|
||||||
if not form.is_valid():
|
if not form.is_valid():
|
||||||
|
@ -355,9 +345,9 @@ def unshelve(request):
|
||||||
|
|
||||||
|
|
||||||
@login_required
|
@login_required
|
||||||
def start_reading(request):
|
def start_reading(request, book_id):
|
||||||
''' begin reading a book '''
|
''' begin reading a book '''
|
||||||
book = books_manager.get_edition(request.POST['book'])
|
book = books_manager.get_edition(book_id)
|
||||||
shelf = models.Shelf.objects.filter(
|
shelf = models.Shelf.objects.filter(
|
||||||
identifier='reading',
|
identifier='reading',
|
||||||
user=request.user
|
user=request.user
|
||||||
|
@ -390,9 +380,9 @@ def start_reading(request):
|
||||||
|
|
||||||
|
|
||||||
@login_required
|
@login_required
|
||||||
def finish_reading(request):
|
def finish_reading(request, book_id):
|
||||||
''' a user completed a book, yay '''
|
''' a user completed a book, yay '''
|
||||||
book = books_manager.get_edition(request.POST['book'])
|
book = books_manager.get_edition(book_id)
|
||||||
shelf = models.Shelf.objects.filter(
|
shelf = models.Shelf.objects.filter(
|
||||||
identifier='read',
|
identifier='read',
|
||||||
user=request.user
|
user=request.user
|
||||||
|
@ -442,10 +432,8 @@ def edit_readthrough(request):
|
||||||
@login_required
|
@login_required
|
||||||
def delete_readthrough(request):
|
def delete_readthrough(request):
|
||||||
''' remove a readthrough '''
|
''' remove a readthrough '''
|
||||||
try:
|
readthrough = get_object_or_404(
|
||||||
readthrough = models.ReadThrough.objects.get(id=request.POST.get('id'))
|
models.ReadThrough, id=request.POST.get('id'))
|
||||||
except models.ReadThrough.DoesNotExist:
|
|
||||||
return HttpResponseNotFound()
|
|
||||||
|
|
||||||
# don't let people edit other people's data
|
# don't let people edit other people's data
|
||||||
if request.user != readthrough.user:
|
if request.user != readthrough.user:
|
||||||
|
@ -506,10 +494,7 @@ def tag(request):
|
||||||
# field which doesn't validate
|
# field which doesn't validate
|
||||||
name = request.POST.get('name')
|
name = request.POST.get('name')
|
||||||
book_id = request.POST.get('book')
|
book_id = request.POST.get('book')
|
||||||
try:
|
book = get_object_or_404(models.Edition, id=book_id)
|
||||||
book = models.Edition.objects.get(id=book_id)
|
|
||||||
except models.Edition.DoesNotExist:
|
|
||||||
return HttpResponseNotFound()
|
|
||||||
tag_obj, created = models.Tag.objects.get_or_create(
|
tag_obj, created = models.Tag.objects.get_or_create(
|
||||||
name=name,
|
name=name,
|
||||||
book=book,
|
book=book,
|
||||||
|
@ -564,15 +549,9 @@ def unboost(request, status_id):
|
||||||
|
|
||||||
|
|
||||||
@login_required
|
@login_required
|
||||||
def delete_status(request):
|
def delete_status(request, status_id):
|
||||||
''' delete and tombstone a status '''
|
''' delete and tombstone a status '''
|
||||||
status_id = request.POST.get('status')
|
status = get_object_or_404(models.Status, id=status_id)
|
||||||
if not status_id:
|
|
||||||
return HttpResponseBadRequest()
|
|
||||||
try:
|
|
||||||
status = models.Status.objects.get(id=status_id)
|
|
||||||
except models.Status.DoesNotExist:
|
|
||||||
return HttpResponseBadRequest()
|
|
||||||
|
|
||||||
# don't let people delete other people's statuses
|
# don't let people delete other people's statuses
|
||||||
if status.user != request.user:
|
if status.user != request.user:
|
||||||
|
@ -683,7 +662,7 @@ def import_data(request):
|
||||||
except (UnicodeDecodeError, ValueError):
|
except (UnicodeDecodeError, ValueError):
|
||||||
return HttpResponseBadRequest('Not a valid csv file')
|
return HttpResponseBadRequest('Not a valid csv file')
|
||||||
goodreads_import.start_import(job)
|
goodreads_import.start_import(job)
|
||||||
return redirect('/import_status/%d' % (job.id,))
|
return redirect('/import-status/%d' % (job.id,))
|
||||||
return HttpResponseBadRequest()
|
return HttpResponseBadRequest()
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@ from django.db.models import Avg, Q
|
||||||
from django.http import HttpResponseBadRequest, HttpResponseNotFound,\
|
from django.http import HttpResponseBadRequest, HttpResponseNotFound,\
|
||||||
JsonResponse
|
JsonResponse
|
||||||
from django.core.exceptions import PermissionDenied
|
from django.core.exceptions import PermissionDenied
|
||||||
from django.shortcuts import redirect
|
from django.shortcuts import get_object_or_404, redirect
|
||||||
from django.template.response import TemplateResponse
|
from django.template.response import TemplateResponse
|
||||||
from django.views.decorators.csrf import csrf_exempt
|
from django.views.decorators.csrf import csrf_exempt
|
||||||
|
|
||||||
|
@ -74,10 +74,7 @@ def home_tab(request, tab):
|
||||||
'user': request.user,
|
'user': request.user,
|
||||||
'suggested_books': suggested_books,
|
'suggested_books': suggested_books,
|
||||||
'activities': activities,
|
'activities': activities,
|
||||||
'review_form': forms.ReviewForm(),
|
|
||||||
'quotation_form': forms.QuotationForm(),
|
|
||||||
'tab': tab,
|
'tab': tab,
|
||||||
'comment_form': forms.CommentForm(),
|
|
||||||
'next': next_page if activity_count > (page_size * page) else None,
|
'next': next_page if activity_count > (page_size * page) else None,
|
||||||
'prev': prev_page if page > 1 else None,
|
'prev': prev_page if page > 1 else None,
|
||||||
}
|
}
|
||||||
|
@ -168,7 +165,7 @@ def search(request):
|
||||||
book_results = books_manager.local_search(query)
|
book_results = books_manager.local_search(query)
|
||||||
return JsonResponse([r.__dict__ for r in book_results], safe=False)
|
return JsonResponse([r.__dict__ for r in book_results], safe=False)
|
||||||
|
|
||||||
# use webfinger looks like a mastodon style account@domain.com username
|
# use webfinger for mastodon style account@domain.com username
|
||||||
if re.match(regex.full_username, query):
|
if re.match(regex.full_username, query):
|
||||||
outgoing.handle_remote_webfinger(query)
|
outgoing.handle_remote_webfinger(query)
|
||||||
|
|
||||||
|
@ -176,7 +173,7 @@ def search(request):
|
||||||
user_results = models.User.objects.annotate(
|
user_results = models.User.objects.annotate(
|
||||||
similarity=TrigramSimilarity('username', query),
|
similarity=TrigramSimilarity('username', query),
|
||||||
).filter(
|
).filter(
|
||||||
similarity__gt=0.1,
|
similarity__gt=0.5,
|
||||||
).order_by('-similarity')[:10]
|
).order_by('-similarity')[:10]
|
||||||
|
|
||||||
book_results = books_manager.search(query)
|
book_results = books_manager.search(query)
|
||||||
|
@ -285,6 +282,7 @@ def invite_page(request, code):
|
||||||
}
|
}
|
||||||
return TemplateResponse(request, 'invite.html', data)
|
return TemplateResponse(request, 'invite.html', data)
|
||||||
|
|
||||||
|
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('bookwyrm.create_invites', raise_exception=True)
|
@permission_required('bookwyrm.create_invites', raise_exception=True)
|
||||||
def manage_invites(request):
|
def manage_invites(request):
|
||||||
|
@ -325,13 +323,6 @@ def user_page(request, username):
|
||||||
return JsonResponse(user.to_activity(), encoder=ActivityEncoder)
|
return JsonResponse(user.to_activity(), encoder=ActivityEncoder)
|
||||||
# otherwise we're at a UI view
|
# otherwise we're at a UI view
|
||||||
|
|
||||||
data = {
|
|
||||||
'title': user.name,
|
|
||||||
'user': user,
|
|
||||||
'is_self': request.user.id == user.id,
|
|
||||||
}
|
|
||||||
|
|
||||||
data['shelf_count'] = user.shelf_set.count()
|
|
||||||
shelves = []
|
shelves = []
|
||||||
for user_shelf in user.shelf_set.all():
|
for user_shelf in user.shelf_set.all():
|
||||||
if not user_shelf.books.count():
|
if not user_shelf.books.count():
|
||||||
|
@ -345,8 +336,15 @@ def user_page(request, username):
|
||||||
if len(shelves) > 2:
|
if len(shelves) > 2:
|
||||||
break
|
break
|
||||||
|
|
||||||
data['shelves'] = shelves
|
data = {
|
||||||
data['activities'] = get_activity_feed(user, 'self')[:15]
|
'title': user.name,
|
||||||
|
'user': user,
|
||||||
|
'is_self': request.user.id == user.id,
|
||||||
|
'shelves': shelves,
|
||||||
|
'shelf_count': user.shelf_set.count(),
|
||||||
|
'activities': get_activity_feed(user, 'self')[:15],
|
||||||
|
}
|
||||||
|
|
||||||
return TemplateResponse(request, 'user.html', data)
|
return TemplateResponse(request, 'user.html', data)
|
||||||
|
|
||||||
|
|
||||||
|
@ -431,6 +429,7 @@ def status_page(request, username, status_id):
|
||||||
}
|
}
|
||||||
return TemplateResponse(request, 'status.html', data)
|
return TemplateResponse(request, 'status.html', data)
|
||||||
|
|
||||||
|
|
||||||
def status_visible_to_user(viewer, status):
|
def status_visible_to_user(viewer, status):
|
||||||
''' is a user authorized to view a status? '''
|
''' is a user authorized to view a status? '''
|
||||||
if viewer == status.user or status.privacy in ['public', 'unlisted']:
|
if viewer == status.user or status.privacy in ['public', 'unlisted']:
|
||||||
|
@ -444,7 +443,6 @@ def status_visible_to_user(viewer, status):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
def replies_page(request, username, status_id):
|
def replies_page(request, username, status_id):
|
||||||
''' ordered collection of replies to a status '''
|
''' ordered collection of replies to a status '''
|
||||||
|
@ -525,13 +523,8 @@ def book_page(request, book_id):
|
||||||
'rating': rating['rating__avg'],
|
'rating': rating['rating__avg'],
|
||||||
'tags': tags,
|
'tags': tags,
|
||||||
'user_tags': user_tags,
|
'user_tags': user_tags,
|
||||||
'review_form': forms.ReviewForm(),
|
|
||||||
'quotation_form': forms.QuotationForm(),
|
|
||||||
'comment_form': forms.CommentForm(),
|
|
||||||
'readthroughs': readthroughs,
|
'readthroughs': readthroughs,
|
||||||
'tag_form': forms.TagForm(),
|
|
||||||
'path': '/book/%s' % book_id,
|
'path': '/book/%s' % book_id,
|
||||||
'cover_form': forms.CoverForm(instance=book),
|
|
||||||
'info_fields': [
|
'info_fields': [
|
||||||
{'name': 'ISBN', 'value': book.isbn_13},
|
{'name': 'ISBN', 'value': book.isbn_13},
|
||||||
{'name': 'OCLC number', 'value': book.oclc_number},
|
{'name': 'OCLC number', 'value': book.oclc_number},
|
||||||
|
@ -561,10 +554,7 @@ def edit_book_page(request, book_id):
|
||||||
|
|
||||||
def editions_page(request, book_id):
|
def editions_page(request, book_id):
|
||||||
''' list of editions of a book '''
|
''' list of editions of a book '''
|
||||||
try:
|
work = get_object_or_404(models.Work, id=book_id)
|
||||||
work = models.Work.objects.get(id=book_id)
|
|
||||||
except models.Work.DoesNotExist:
|
|
||||||
return HttpResponseNotFound()
|
|
||||||
|
|
||||||
if is_api_request(request):
|
if is_api_request(request):
|
||||||
return JsonResponse(
|
return JsonResponse(
|
||||||
|
@ -583,10 +573,7 @@ def editions_page(request, book_id):
|
||||||
|
|
||||||
def author_page(request, author_id):
|
def author_page(request, author_id):
|
||||||
''' landing page for an author '''
|
''' landing page for an author '''
|
||||||
try:
|
author = get_object_or_404(models.Author, id=author_id)
|
||||||
author = models.Author.objects.get(id=author_id)
|
|
||||||
except ValueError:
|
|
||||||
return HttpResponseNotFound()
|
|
||||||
|
|
||||||
if is_api_request(request):
|
if is_api_request(request):
|
||||||
return JsonResponse(author.to_activity(), encoder=ActivityEncoder)
|
return JsonResponse(author.to_activity(), encoder=ActivityEncoder)
|
||||||
|
@ -658,8 +645,6 @@ def shelf_page(request, username, shelf_identifier):
|
||||||
'is_self': is_self,
|
'is_self': is_self,
|
||||||
'shelves': shelves.all(),
|
'shelves': shelves.all(),
|
||||||
'shelf': shelf,
|
'shelf': shelf,
|
||||||
'create_form': forms.ShelfForm(),
|
|
||||||
'edit_form': forms.ShelfForm(shelf),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return TemplateResponse(request, 'shelf.html', data)
|
return TemplateResponse(request, 'shelf.html', data)
|
||||||
|
|
Loading…
Reference in a new issue