mirror of
https://github.com/bookwyrm-social/bookwyrm.git
synced 2025-01-11 09:45:27 +00:00
Add multiple authors
This commit is contained in:
parent
965d84f86f
commit
c1976dbd62
2 changed files with 61 additions and 41 deletions
|
@ -39,29 +39,37 @@
|
||||||
<div class="box">
|
<div class="box">
|
||||||
<h2 class="title is-4">{% trans "Confirm Book Info" %}</h2>
|
<h2 class="title is-4">{% trans "Confirm Book Info" %}</h2>
|
||||||
<div class="columns">
|
<div class="columns">
|
||||||
{% if author_matches.exists %}
|
{% if author_matches %}
|
||||||
<fieldset class="column is-half">
|
<div class="column is-half">
|
||||||
<legend class="label">{% blocktrans with name=add_author %}Is "{{ name }}" an existing author?{% endblocktrans %}</legend>
|
{% for author in author_matches %}
|
||||||
{% for match in author_matches %}
|
<fieldset class="mb-4">
|
||||||
<label><input type="radio" name="author_match" value="{{ match.id }}" required> {{ match.name }}</label>
|
<legend class="title is-5 mb-1">{% blocktrans with name=author.name %}Is "{{ name }}" an existing author?{% endblocktrans %}</legend>
|
||||||
<p class="help">
|
{% with forloop.counter as counter %}
|
||||||
<a href="{{ author.local_path }}" target="_blank">{% blocktrans with book_title=match.book_set.first.title %}Author of <em>{{ book_title }}</em>{% endblocktrans %}</a>
|
{% for match in author.matches %}
|
||||||
</p>
|
<label><input type="radio" name="author_match-{{ counter }}" value="{{ match.id }}" required> {{ match.name }}</label>
|
||||||
|
<p class="help">
|
||||||
|
<a href="{{ author.local_path }}" target="_blank">{% blocktrans with book_title=match.book_set.first.title %}Author of <em>{{ book_title }}</em>{% endblocktrans %}</a>
|
||||||
|
</p>
|
||||||
|
{% endfor %}
|
||||||
|
<label><input type="radio" name="author_match-{{ counter }}" value="0" required> {% trans "This is a new author" %}</label>
|
||||||
|
{% endwith %}
|
||||||
|
</fieldset>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
<label><input type="radio" name="author_match"> {% trans "This is a new author" %}</label>
|
</div>
|
||||||
</fieldset>
|
|
||||||
{% else %}
|
{% else %}
|
||||||
<p class="column is-half">{% blocktrans with name=add_author %}Creating a new author: {{ name }}{% endblocktrans %}</p>
|
<p class="column is-half">{% blocktrans with name=add_author %}Creating a new author: {{ name }}{% endblocktrans %}</p>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
{% if not book %}
|
{% if not book %}
|
||||||
<fieldset class="column is-half">
|
<div class="column is-half">
|
||||||
<legend class="title is-5">{% trans "Is this an editions of an existing work?" %}</legend>
|
<fieldset>
|
||||||
{% for match in book_matches %}
|
<legend class="title is-5 mb-1">{% trans "Is this an edition of an existing work?" %}</legend>
|
||||||
<label class="label"><input type="radio" name="parent_work" value="{{ match.parent_work.id }}"> {{ match.parent_work.title }}</label>
|
{% for match in book_matches %}
|
||||||
{% endfor %}
|
<label class="label"><input type="radio" name="parent_work" value="{{ match.parent_work.id }}"> {{ match.parent_work.title }}</label>
|
||||||
<label><input type="radio" name="parent_work" value="0"> this is a new work</label>
|
{% endfor %}
|
||||||
</fieldset>
|
<label><input type="radio" name="parent_work" value="0" required> {% trans "This is a new work" %}</label>
|
||||||
|
</fieldset>
|
||||||
|
</div>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -109,16 +117,19 @@
|
||||||
|
|
||||||
<section class="block">
|
<section class="block">
|
||||||
<h2 class="title is-4">{% trans "Authors" %}</h2>
|
<h2 class="title is-4">{% trans "Authors" %}</h2>
|
||||||
|
{% if book.authors.exists %}
|
||||||
<fieldset>
|
<fieldset>
|
||||||
{% for author in book.authors.all %}
|
{% for author in book.authors.all %}
|
||||||
<p><a href="{{ author.local_path }}">{{ author.name }}</a>
|
<label class="label mb-2">
|
||||||
<label class="label">
|
<input type="checkbox" name="remove_authors" value="{{ author.id }}" {% if author.id|stringformat:"i" in remove_authors %}checked{% endif %}>
|
||||||
<input type="checkbox" name="remove_authors" value="{{ author.id }}"> {% trans "Remove this author" %}
|
{% blocktrans with name=author.name path=author.local_path %}Remove <a href="{{ path }}">{{ name }}</a>{% endblocktrans %}
|
||||||
</label>
|
</label>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</fieldset>
|
</fieldset>
|
||||||
<label class="label" for="id_add_author">{% trans "Add Author:" %}</label>
|
{% endif %}
|
||||||
<input class="input" type="text" name="add_author" id="id_add_author" placeholder="{% trans 'John Doe' %}" value="{{ add_author }}">
|
<label class="label" for="id_add_author">{% trans "Add Authors:" %}</label>
|
||||||
|
<p class="help">Separate multiple author names with commas.</p>
|
||||||
|
<input class="input" type="text" name="add_author" id="id_add_author" placeholder="{% trans 'John Doe, Jane Smith' %}" value="{{ add_author }}">
|
||||||
</section>
|
</section>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
|
@ -131,17 +131,22 @@ class EditBook(View):
|
||||||
# we're adding an author through a free text field
|
# we're adding an author through a free text field
|
||||||
if add_author:
|
if add_author:
|
||||||
data["add_author"] = add_author
|
data["add_author"] = add_author
|
||||||
# check for existing authors
|
data['author_matches'] = []
|
||||||
vector = SearchVector("name", weight="A") + SearchVector(
|
for author in add_author.split(','):
|
||||||
"aliases", weight="B"
|
# check for existing authors
|
||||||
)
|
vector = SearchVector("name", weight="A") + SearchVector(
|
||||||
|
"aliases", weight="B"
|
||||||
|
)
|
||||||
|
|
||||||
data["author_matches"] = (
|
data["author_matches"].append({
|
||||||
models.Author.objects.annotate(search=vector)
|
'name': author.strip(),
|
||||||
.annotate(rank=SearchRank(vector, add_author))
|
'matches': (
|
||||||
.filter(rank__gt=0.4)
|
models.Author.objects.annotate(search=vector)
|
||||||
.order_by("-rank")[:5]
|
.annotate(rank=SearchRank(vector, add_author))
|
||||||
)
|
.filter(rank__gt=0.4)
|
||||||
|
.order_by("-rank")[:5]
|
||||||
|
)
|
||||||
|
})
|
||||||
|
|
||||||
# we're creating a new book
|
# we're creating a new book
|
||||||
if not book:
|
if not book:
|
||||||
|
@ -157,6 +162,8 @@ class EditBook(View):
|
||||||
if add_author or not book:
|
if add_author or not book:
|
||||||
# creting a book or adding an author to a book needs another step
|
# creting a book or adding an author to a book needs another step
|
||||||
data["confirm_mode"] = True
|
data["confirm_mode"] = True
|
||||||
|
# this isn't preserved because it isn't part of the form obj
|
||||||
|
data["remove_authors"] = request.POST.getlist("remove_authors")
|
||||||
return TemplateResponse(request, "edit_book.html", data)
|
return TemplateResponse(request, "edit_book.html", data)
|
||||||
|
|
||||||
remove_authors = request.POST.getlist("remove_authors")
|
remove_authors = request.POST.getlist("remove_authors")
|
||||||
|
@ -190,15 +197,17 @@ class ConfirmEditBook(View):
|
||||||
|
|
||||||
# get or create author as needed
|
# get or create author as needed
|
||||||
if request.POST.get("add_author"):
|
if request.POST.get("add_author"):
|
||||||
if request.POST.get("author_match"):
|
for (i, author) in enumerate(request.POST.get("add_author").split(',')):
|
||||||
author = get_object_or_404(
|
match = request.POST.get("author_match-%d" % i)
|
||||||
models.Author, id=request.POST["author_match"]
|
if match and match != "0":
|
||||||
)
|
author = get_object_or_404(
|
||||||
else:
|
models.Author, id=request.POST["author_match-%d" % i]
|
||||||
author = models.Author.objects.create(
|
)
|
||||||
name=request.POST.get("add_author")
|
else:
|
||||||
)
|
author = models.Author.objects.create(
|
||||||
book.authors.add(author)
|
name=author.strip()
|
||||||
|
)
|
||||||
|
book.authors.add(author)
|
||||||
|
|
||||||
# create work, if needed
|
# create work, if needed
|
||||||
if not book_id:
|
if not book_id:
|
||||||
|
|
Loading…
Reference in a new issue