Merge pull request #1917 from bookwyrm-social/list-page-error

Fixes errors in how lists with notes display
This commit is contained in:
Mouse Reeve 2022-02-04 15:44:49 -08:00 committed by GitHub
commit 70bd6b9a65
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 31 additions and 7 deletions

View file

@ -0,0 +1,21 @@
# Generated by Django 3.2.11 on 2022-02-04 20:06
import bookwyrm.models.fields
from django.db import migrations
class Migration(migrations.Migration):
dependencies = [
("bookwyrm", "0132_alter_user_preferred_language"),
]
operations = [
migrations.AlterField(
model_name="listitem",
name="notes",
field=bookwyrm.models.fields.HtmlField(
blank=True, max_length=300, null=True
),
),
]

View file

@ -142,7 +142,7 @@ class ListItem(CollectionItemMixin, BookWyrmModel):
user = fields.ForeignKey( user = fields.ForeignKey(
"User", on_delete=models.PROTECT, activitypub_field="actor" "User", on_delete=models.PROTECT, activitypub_field="actor"
) )
notes = fields.TextField(blank=True, null=True, max_length=300) notes = fields.HtmlField(blank=True, null=True, max_length=300)
approved = models.BooleanField(default=True) approved = models.BooleanField(default=True)
order = fields.IntegerField() order = fields.IntegerField()
endorsement = models.ManyToManyField("User", related_name="endorsers") endorsement = models.ManyToManyField("User", related_name="endorsers")

View file

@ -79,14 +79,12 @@
<div class="media-content"> <div class="media-content">
<div class="content"> <div class="content">
<header> <header>
{% url 'user-feed' user|username as user_path %} {% url 'user-feed' item.user|username as user_path %}
{% blocktrans trimmed with username=user.display_name %} {% blocktrans trimmed with username=user.display_name %}
<a href="{{ user_path }}">{{ username }}</a> says: <a href="{{ user_path }}">{{ username }}</a> says:
{% endblocktrans %} {% endblocktrans %}
</header> </header>
<p>
{{ item.notes|to_markdown|safe }} {{ item.notes|to_markdown|safe }}
</p>
</div> </div>
{% if item.user == request.user %} {% if item.user == request.user %}
<div> <div>

View file

@ -85,6 +85,7 @@ class ListViews(TestCase):
user=self.local_user, user=self.local_user,
book=self.book, book=self.book,
approved=True, approved=True,
notes="hello",
order=1, order=1,
) )
@ -178,6 +179,7 @@ class ListViews(TestCase):
book_list=self.list, book_list=self.list,
user=self.local_user, user=self.local_user,
book=self.book, book=self.book,
notes="hi hello",
approved=True, approved=True,
order=1, order=1,
) )

View file

@ -67,4 +67,4 @@ class ListItemViews(TestCase):
self.assertEqual(mock.call_count, 1) self.assertEqual(mock.call_count, 1)
item.refresh_from_db() item.refresh_from_db()
self.assertEqual(item.notes, "beep boop") self.assertEqual(item.notes, "<p>beep boop</p>")

View file

@ -5,6 +5,7 @@ from django.utils.decorators import method_decorator
from django.views import View from django.views import View
from bookwyrm import forms, models from bookwyrm import forms, models
from bookwyrm.views.status import to_markdown
# pylint: disable=no-self-use # pylint: disable=no-self-use
@ -18,7 +19,9 @@ class ListItem(View):
list_item.raise_not_editable(request.user) list_item.raise_not_editable(request.user)
form = forms.ListItemForm(request.POST, instance=list_item) form = forms.ListItemForm(request.POST, instance=list_item)
if form.is_valid(): if form.is_valid():
form.save() item = form.save(commit=False)
item.notes = to_markdown(item.notes)
item.save()
else: else:
raise Exception(form.errors) raise Exception(form.errors)
return redirect("list", list_item.book_list.id) return redirect("list", list_item.book_list.id)