diff --git a/django/contrib/admin/helpers.py b/django/contrib/admin/helpers.py index 50d089255bd..bf80ac5d48e 100644 --- a/django/contrib/admin/helpers.py +++ b/django/contrib/admin/helpers.py @@ -7,7 +7,7 @@ from django.contrib.admin.templatetags.admin_static import static from django.core.exceptions import ObjectDoesNotExist from django.db.models.fields.related import ManyToManyRel from django.forms.utils import flatatt -from django.template.defaultfilters import capfirst +from django.template.defaultfilters import capfirst, linebreaksbr from django.utils.encoding import force_text, smart_text from django.utils.html import conditional_escape, format_html from django.utils.safestring import mark_safe @@ -182,6 +182,8 @@ class AdminReadonlyField(object): result_repr = smart_text(value) if getattr(attr, "allow_tags", False): result_repr = mark_safe(result_repr) + else: + result_repr = linebreaksbr(result_repr) else: if isinstance(f.rel, ManyToManyRel) and value is not None: result_repr = ", ".join(map(six.text_type, value.all())) diff --git a/django/contrib/admin/templates/admin/edit_inline/tabular.html b/django/contrib/admin/templates/admin/edit_inline/tabular.html index 2a3463280d5..9ef6e8f1d59 100644 --- a/django/contrib/admin/templates/admin/edit_inline/tabular.html +++ b/django/contrib/admin/templates/admin/edit_inline/tabular.html @@ -47,7 +47,7 @@ {% if not field.field.is_hidden %} {% if field.is_readonly %} -

{{ field.contents|linebreaksbr }}

+

{{ field.contents }}

{% else %} {{ field.field.errors.as_ul }} {{ field.field }} diff --git a/django/contrib/admin/templates/admin/includes/fieldset.html b/django/contrib/admin/templates/admin/includes/fieldset.html index f38564c5af6..c45e731fafe 100644 --- a/django/contrib/admin/templates/admin/includes/fieldset.html +++ b/django/contrib/admin/templates/admin/includes/fieldset.html @@ -14,7 +14,7 @@ {% else %} {{ field.label_tag }} {% if field.is_readonly %} -

{{ field.contents|linebreaksbr }}

+

{{ field.contents }}

{% else %} {{ field.field }} {% endif %} diff --git a/tests/admin_views/admin.py b/tests/admin_views/admin.py index e9c6d4dc4c4..a392daf2938 100644 --- a/tests/admin_views/admin.py +++ b/tests/admin_views/admin.py @@ -15,6 +15,7 @@ from django.conf.urls import patterns, url from django.forms.models import BaseModelFormSet from django.http import HttpResponse, StreamingHttpResponse from django.contrib.admin import BooleanFieldListFilter +from django.utils.safestring import mark_safe from django.utils.six import StringIO from .models import (Article, Chapter, Child, Parent, Picture, Widget, @@ -407,8 +408,8 @@ class PrePopulatedPostAdmin(admin.ModelAdmin): class PostAdmin(admin.ModelAdmin): list_display = ['title', 'public'] readonly_fields = ( - 'posted', 'awesomeness_level', 'coolness', 'value', 'multiline', - lambda obj: "foo" + 'posted', 'awesomeness_level', 'coolness', 'value', + 'multiline', 'multiline_html', lambda obj: "foo" ) inlines = [ @@ -427,6 +428,10 @@ class PostAdmin(admin.ModelAdmin): def multiline(self, instance): return "Multiline\ntest\nstring" + def multiline_html(self, instance): + return mark_safe("Multiline
\nhtml
\ncontent") + multiline_html.allow_tags = True + value.short_description = 'Value in $US' diff --git a/tests/admin_views/tests.py b/tests/admin_views/tests.py index c39e99aa1b1..a88117fa6f8 100644 --- a/tests/admin_views/tests.py +++ b/tests/admin_views/tests.py @@ -3622,6 +3622,7 @@ class ReadonlyTest(TestCase): # Checks that multiline text in a readonly field gets
tags self.assertContains(response, "Multiline
test
string") + self.assertContains(response, "

Multiline
html
content

", html=True) self.assertContains(response, "InlineMultiline
test
string") self.assertContains(response,