forked from mirrors/bookwyrm
Fixes html form for editing lists
This commit is contained in:
parent
3770713e07
commit
8e89d02093
3 changed files with 83 additions and 33 deletions
|
@ -54,13 +54,13 @@
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<input type="hidden" name="item" value="{{ item.id }}">
|
<input type="hidden" name="item" value="{{ item.id }}">
|
||||||
<input type="hidden" name="approved" value="true">
|
<input type="hidden" name="approved" value="true">
|
||||||
<button class="button">{% trans "Approve" %}</button>
|
<button type="submit" class="button">{% trans "Approve" %}</button>
|
||||||
</form>
|
</form>
|
||||||
<form class="control" method="POST" action="{% url 'list-curate' list.id %}">
|
<form class="control" method="POST" action="{% url 'list-curate' list.id %}">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<input type="hidden" name="item" value="{{ item.id }}">
|
<input type="hidden" name="item" value="{{ item.id }}">
|
||||||
<input type="hidden" name="approved" value="false">
|
<input type="hidden" name="approved" value="false">
|
||||||
<button class="button is-danger is-light">{% trans "Discard" %}</button>
|
<button type="submit" class="button is-danger is-light">{% trans "Discard" %}</button>
|
||||||
</form>
|
</form>
|
||||||
</dd>
|
</dd>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -18,24 +18,73 @@
|
||||||
<fieldset class="field">
|
<fieldset class="field">
|
||||||
<legend class="label">{% trans "List curation:" %}</legend>
|
<legend class="label">{% trans "List curation:" %}</legend>
|
||||||
|
|
||||||
<label class="field" data-hides="list_group_selector">
|
<div class="field" data-hides="list_group_selector">
|
||||||
<input type="radio" name="curation" value="closed"{% if not list or list.curation == 'closed' %} checked{% endif %}> {% trans "Closed" %}
|
<input
|
||||||
<p class="help mb-2">{% trans "Only you can add and remove books to this list" %}</p>
|
type="radio"
|
||||||
</label>
|
name="curation"
|
||||||
|
value="closed"
|
||||||
|
aria-described-by="id_curation_closed_help"
|
||||||
|
id="id_curation_closed"
|
||||||
|
{% if not list or list.curation == 'closed' %} checked{% endif %}
|
||||||
|
>
|
||||||
|
<label for="id_curation_closed">
|
||||||
|
{% trans "Closed" %}
|
||||||
|
</label>
|
||||||
|
<p class="help mb-2" id="id_curation_closed_help">
|
||||||
|
{% trans "Only you can add and remove books to this list" %}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
<label class="field" data-hides="list_group_selector">
|
<div class="field" data-hides="list_group_selector">
|
||||||
<input type="radio" name="curation" value="curated"{% if list.curation == 'curated' %} checked{% endif %}> {% trans "Curated" %}
|
<input
|
||||||
<p class="help mb-2">{% trans "Anyone can suggest books, subject to your approval" %}</p>
|
type="radio"
|
||||||
</label>
|
name="curation"
|
||||||
|
value="curated"
|
||||||
|
aria-described-by="id_curation_curated_help"
|
||||||
|
id="id_curation_curated"
|
||||||
|
{% if list.curation == 'curated' %} checked{% endif %}
|
||||||
|
>
|
||||||
|
<label for="id_curation_curated">
|
||||||
|
{% trans "Curated" %}
|
||||||
|
</label>
|
||||||
|
<p class="help mb-2" id="id_curation_curated_help">
|
||||||
|
{% trans "Anyone can suggest books, subject to your approval" %}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
<label class="field" data-hides="list_group_selector">
|
<div class="field" data-hides="list_group_selector">
|
||||||
<input type="radio" name="curation" value="open"{% if list.curation == 'open' %} checked{% endif %}> {% trans "Open" context "curation type" %}
|
<input
|
||||||
<p class="help mb-2">{% trans "Anyone can add books to this list" %}</p>
|
type="radio"
|
||||||
</label>
|
name="curation"
|
||||||
|
value="open"
|
||||||
|
aria-described-by="id_curation_open_help"
|
||||||
|
id="id_curation_open"
|
||||||
|
{% if list.curation == 'open' %} checked{% endif %}
|
||||||
|
>
|
||||||
|
<label for="id_curation_open">
|
||||||
|
{% trans "Open" context "curation type" %}
|
||||||
|
</label>
|
||||||
|
<p class="help mb-2" id="id_curation_open_help">
|
||||||
|
{% trans "Anyone can add books to this list" %}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="field hidden-form">
|
||||||
|
<input
|
||||||
|
type="radio"
|
||||||
|
name="curation"
|
||||||
|
value="group"
|
||||||
|
aria-described-by="id_curation_group_help"
|
||||||
|
id="id_curation_group"
|
||||||
|
{% if list.curation == 'group' %}checked{% endif %}
|
||||||
|
>
|
||||||
|
<label for="id_curation_group">
|
||||||
|
{% trans "Group" %}
|
||||||
|
</label>
|
||||||
|
<p class="help mb-2" id="id_curation_group_help">
|
||||||
|
{% trans "Group members can add to and remove from this list" %}
|
||||||
|
</p>
|
||||||
|
|
||||||
<label class="field hidden-form">
|
|
||||||
<input type="radio" name="curation" value="group"{% if list.curation == 'group' %} checked{% endif %} > {% trans "Group" %}
|
|
||||||
<p class="help mb-2">{% trans "Group members can add to and remove from this list" %}</p>
|
|
||||||
<fieldset class="{% if list.curation != 'group' %}is-hidden{% endif %}" id="list_group_selector">
|
<fieldset class="{% if list.curation != 'group' %}is-hidden{% endif %}" id="list_group_selector">
|
||||||
{% if user.memberships.exists %}
|
{% if user.memberships.exists %}
|
||||||
<label class="label" for="id_group" id="group">{% trans "Select Group" %}</label>
|
<label class="label" for="id_group" id="group">{% trans "Select Group" %}</label>
|
||||||
|
@ -61,7 +110,7 @@
|
||||||
{% endwith %}
|
{% endwith %}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</fieldset>
|
</fieldset>
|
||||||
</label>
|
</div>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -10,6 +10,7 @@ from django.test.client import RequestFactory
|
||||||
|
|
||||||
from bookwyrm import models, views
|
from bookwyrm import models, views
|
||||||
from bookwyrm.activitypub import ActivitypubResponse
|
from bookwyrm.activitypub import ActivitypubResponse
|
||||||
|
from bookwyrm.tests.validate_html import validate_html
|
||||||
|
|
||||||
# pylint: disable=unused-argument
|
# pylint: disable=unused-argument
|
||||||
class ListViews(TestCase):
|
class ListViews(TestCase):
|
||||||
|
@ -84,14 +85,14 @@ class ListViews(TestCase):
|
||||||
|
|
||||||
result = view(request)
|
result = view(request)
|
||||||
self.assertIsInstance(result, TemplateResponse)
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
result.render()
|
validate_html(result.render())
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
request.user = self.anonymous_user
|
request.user = self.anonymous_user
|
||||||
|
|
||||||
result = view(request)
|
result = view(request)
|
||||||
self.assertIsInstance(result, TemplateResponse)
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
result.render()
|
validate_html(result.render())
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
def test_saved_lists_page(self):
|
def test_saved_lists_page(self):
|
||||||
|
@ -110,7 +111,7 @@ class ListViews(TestCase):
|
||||||
|
|
||||||
result = view(request)
|
result = view(request)
|
||||||
self.assertIsInstance(result, TemplateResponse)
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
result.render()
|
validate_html(result.render())
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
self.assertEqual(result.context_data["lists"].object_list, [booklist])
|
self.assertEqual(result.context_data["lists"].object_list, [booklist])
|
||||||
|
|
||||||
|
@ -127,7 +128,7 @@ class ListViews(TestCase):
|
||||||
|
|
||||||
result = view(request)
|
result = view(request)
|
||||||
self.assertIsInstance(result, TemplateResponse)
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
result.render()
|
validate_html(result.render())
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
self.assertEqual(len(result.context_data["lists"].object_list), 0)
|
self.assertEqual(len(result.context_data["lists"].object_list), 0)
|
||||||
|
|
||||||
|
@ -188,7 +189,7 @@ class ListViews(TestCase):
|
||||||
is_api.return_value = False
|
is_api.return_value = False
|
||||||
result = view(request, self.list.id)
|
result = view(request, self.list.id)
|
||||||
self.assertIsInstance(result, TemplateResponse)
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
result.render()
|
validate_html(result.render())
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
def test_list_page_sorted(self):
|
def test_list_page_sorted(self):
|
||||||
|
@ -210,7 +211,7 @@ class ListViews(TestCase):
|
||||||
is_api.return_value = False
|
is_api.return_value = False
|
||||||
result = view(request, self.list.id)
|
result = view(request, self.list.id)
|
||||||
self.assertIsInstance(result, TemplateResponse)
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
result.render()
|
validate_html(result.render())
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
request = self.factory.get("/?sort_by=title")
|
request = self.factory.get("/?sort_by=title")
|
||||||
|
@ -219,7 +220,7 @@ class ListViews(TestCase):
|
||||||
is_api.return_value = False
|
is_api.return_value = False
|
||||||
result = view(request, self.list.id)
|
result = view(request, self.list.id)
|
||||||
self.assertIsInstance(result, TemplateResponse)
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
result.render()
|
validate_html(result.render())
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
request = self.factory.get("/?sort_by=rating")
|
request = self.factory.get("/?sort_by=rating")
|
||||||
|
@ -228,7 +229,7 @@ class ListViews(TestCase):
|
||||||
is_api.return_value = False
|
is_api.return_value = False
|
||||||
result = view(request, self.list.id)
|
result = view(request, self.list.id)
|
||||||
self.assertIsInstance(result, TemplateResponse)
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
result.render()
|
validate_html(result.render())
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
request = self.factory.get("/?sort_by=sdkfh")
|
request = self.factory.get("/?sort_by=sdkfh")
|
||||||
|
@ -237,7 +238,7 @@ class ListViews(TestCase):
|
||||||
is_api.return_value = False
|
is_api.return_value = False
|
||||||
result = view(request, self.list.id)
|
result = view(request, self.list.id)
|
||||||
self.assertIsInstance(result, TemplateResponse)
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
result.render()
|
validate_html(result.render())
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
def test_list_page_empty(self):
|
def test_list_page_empty(self):
|
||||||
|
@ -250,7 +251,7 @@ class ListViews(TestCase):
|
||||||
is_api.return_value = False
|
is_api.return_value = False
|
||||||
result = view(request, self.list.id)
|
result = view(request, self.list.id)
|
||||||
self.assertIsInstance(result, TemplateResponse)
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
result.render()
|
validate_html(result.render())
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
def test_list_page_logged_out(self):
|
def test_list_page_logged_out(self):
|
||||||
|
@ -271,7 +272,7 @@ class ListViews(TestCase):
|
||||||
is_api.return_value = False
|
is_api.return_value = False
|
||||||
result = view(request, self.list.id)
|
result = view(request, self.list.id)
|
||||||
self.assertIsInstance(result, TemplateResponse)
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
result.render()
|
validate_html(result.render())
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
def test_list_page_json_view(self):
|
def test_list_page_json_view(self):
|
||||||
|
@ -355,7 +356,7 @@ class ListViews(TestCase):
|
||||||
|
|
||||||
result = view(request, self.list.id)
|
result = view(request, self.list.id)
|
||||||
self.assertIsInstance(result, TemplateResponse)
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
result.render()
|
validate_html(result.render())
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
request.user = self.anonymous_user
|
request.user = self.anonymous_user
|
||||||
|
@ -375,7 +376,7 @@ class ListViews(TestCase):
|
||||||
|
|
||||||
result = view(request, self.local_user.localname)
|
result = view(request, self.local_user.localname)
|
||||||
self.assertIsInstance(result, TemplateResponse)
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
result.render()
|
validate_html(result.render())
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
||||||
def test_user_lists_page_logged_out(self):
|
def test_user_lists_page_logged_out(self):
|
||||||
|
@ -404,7 +405,7 @@ class ListViews(TestCase):
|
||||||
with patch("bookwyrm.views.list.is_api_request") as is_api:
|
with patch("bookwyrm.views.list.is_api_request") as is_api:
|
||||||
is_api.return_value = False
|
is_api.return_value = False
|
||||||
with self.assertRaises(Http404):
|
with self.assertRaises(Http404):
|
||||||
result = view(request, self.list.id, "")
|
view(request, self.list.id, "")
|
||||||
|
|
||||||
def test_embed_call_with_key(self):
|
def test_embed_call_with_key(self):
|
||||||
"""there are so many views, this just makes sure it LOADS"""
|
"""there are so many views, this just makes sure it LOADS"""
|
||||||
|
@ -427,5 +428,5 @@ class ListViews(TestCase):
|
||||||
result = view(request, self.list.id, embed_key)
|
result = view(request, self.list.id, embed_key)
|
||||||
|
|
||||||
self.assertIsInstance(result, TemplateResponse)
|
self.assertIsInstance(result, TemplateResponse)
|
||||||
result.render()
|
validate_html(result.render())
|
||||||
self.assertEqual(result.status_code, 200)
|
self.assertEqual(result.status_code, 200)
|
||||||
|
|
Loading…
Reference in a new issue