Fixed #17090 -- Made the API specification for `ModelAdmin.get_list_display()` more consistent with that of `ModelAdmin.list_display` by separating out the admin action check boxes business. This is backwards-incompatible for those who have been using the still-unreleased `get_list_display()` method. Thanks to Ramiro Morales for the review.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@17035 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
4d79083453
commit
600c576ac5
|
@ -342,13 +342,6 @@ class ModelAdmin(BaseModelAdmin):
|
||||||
self.model = model
|
self.model = model
|
||||||
self.opts = model._meta
|
self.opts = model._meta
|
||||||
self.admin_site = admin_site
|
self.admin_site = admin_site
|
||||||
if 'action_checkbox' not in self.list_display and self.actions is not None:
|
|
||||||
self.list_display = ['action_checkbox'] + list(self.list_display)
|
|
||||||
if not self.list_display_links:
|
|
||||||
for name in self.list_display:
|
|
||||||
if name != 'action_checkbox':
|
|
||||||
self.list_display_links = [name]
|
|
||||||
break
|
|
||||||
super(ModelAdmin, self).__init__()
|
super(ModelAdmin, self).__init__()
|
||||||
|
|
||||||
def get_inline_instances(self, request):
|
def get_inline_instances(self, request):
|
||||||
|
@ -1104,19 +1097,23 @@ class ModelAdmin(BaseModelAdmin):
|
||||||
# Check actions to see if any are available on this changelist
|
# Check actions to see if any are available on this changelist
|
||||||
actions = self.get_actions(request)
|
actions = self.get_actions(request)
|
||||||
|
|
||||||
# Remove action checkboxes if there aren't any actions available.
|
list_display = self.get_list_display(request)
|
||||||
list_display = list(self.get_list_display(request))
|
|
||||||
if not actions:
|
list_display_links = self.list_display_links
|
||||||
try:
|
if not self.list_display_links and list_display:
|
||||||
list_display.remove('action_checkbox')
|
list_display_links = list(list_display)[:1]
|
||||||
except ValueError:
|
|
||||||
pass
|
if actions:
|
||||||
|
# Add the action checkboxes if there are any actions available.
|
||||||
|
list_display = ['action_checkbox'] + list(list_display)
|
||||||
|
|
||||||
ChangeList = self.get_changelist(request)
|
ChangeList = self.get_changelist(request)
|
||||||
try:
|
try:
|
||||||
cl = ChangeList(request, self.model, list_display, self.list_display_links,
|
cl = ChangeList(request, self.model, list_display,
|
||||||
self.list_filter, self.date_hierarchy, self.search_fields,
|
list_display_links, self.list_filter, self.date_hierarchy,
|
||||||
self.list_select_related, self.list_per_page, self.list_max_show_all, self.list_editable, self)
|
self.search_fields, self.list_select_related,
|
||||||
|
self.list_per_page, self.list_max_show_all, self.list_editable,
|
||||||
|
self)
|
||||||
except IncorrectLookupParameters:
|
except IncorrectLookupParameters:
|
||||||
# Wacky lookup parameters were given, so redirect to the main
|
# Wacky lookup parameters were given, so redirect to the main
|
||||||
# changelist page, without parameters, and pass an 'invalid=1'
|
# changelist page, without parameters, and pass an 'invalid=1'
|
||||||
|
|
|
@ -48,7 +48,7 @@ class ChangeListTests(TestCase):
|
||||||
template = Template('{% load admin_list %}{% spaceless %}{% result_list cl %}{% endspaceless %}')
|
template = Template('{% load admin_list %}{% spaceless %}{% result_list cl %}{% endspaceless %}')
|
||||||
context = Context({'cl': cl})
|
context = Context({'cl': cl})
|
||||||
table_output = template.render(context)
|
table_output = template.render(context)
|
||||||
row_html = '<tbody><tr class="row1"><td class="action-checkbox"><input type="checkbox" class="action-select" value="%d" name="_selected_action" /></td><th><a href="%d/">name</a></th><td class="nowrap">(None)</td></tr></tbody>' % (new_child.id, new_child.id)
|
row_html = '<tbody><tr class="row1"><th><a href="%d/">name</a></th><td class="nowrap">(None)</td></tr></tbody>' % new_child.id
|
||||||
self.assertFalse(table_output.find(row_html) == -1,
|
self.assertFalse(table_output.find(row_html) == -1,
|
||||||
'Failed to find expected row element: %s' % table_output)
|
'Failed to find expected row element: %s' % table_output)
|
||||||
|
|
||||||
|
@ -68,7 +68,7 @@ class ChangeListTests(TestCase):
|
||||||
template = Template('{% load admin_list %}{% spaceless %}{% result_list cl %}{% endspaceless %}')
|
template = Template('{% load admin_list %}{% spaceless %}{% result_list cl %}{% endspaceless %}')
|
||||||
context = Context({'cl': cl})
|
context = Context({'cl': cl})
|
||||||
table_output = template.render(context)
|
table_output = template.render(context)
|
||||||
row_html = '<tbody><tr class="row1"><td class="action-checkbox"><input type="checkbox" class="action-select" value="%d" name="_selected_action" /></td><th><a href="%d/">name</a></th><td class="nowrap">Parent object</td></tr></tbody>' % (new_child.id, new_child.id)
|
row_html = '<tbody><tr class="row1"><th><a href="%d/">name</a></th><td class="nowrap">Parent object</td></tr></tbody>' % new_child.id
|
||||||
self.assertFalse(table_output.find(row_html) == -1,
|
self.assertFalse(table_output.find(row_html) == -1,
|
||||||
'Failed to find expected row element: %s' % table_output)
|
'Failed to find expected row element: %s' % table_output)
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,7 @@ class TestRegistration(TestCase):
|
||||||
search_fields=["name"], list_display=['__str__'])
|
search_fields=["name"], list_display=['__str__'])
|
||||||
self.assertEqual(self.site._registry[Person].search_fields, ['name'])
|
self.assertEqual(self.site._registry[Person].search_fields, ['name'])
|
||||||
self.assertEqual(self.site._registry[Person].list_display,
|
self.assertEqual(self.site._registry[Person].list_display,
|
||||||
['action_checkbox', '__str__'])
|
['__str__'])
|
||||||
self.assertTrue(self.site._registry[Person].save_on_top)
|
self.assertTrue(self.site._registry[Person].save_on_top)
|
||||||
|
|
||||||
def test_iterable_registration(self):
|
def test_iterable_registration(self):
|
||||||
|
|
Loading…
Reference in New Issue