From b7ba4fc408c43ecee385d2ca3582697ec54ac8a6 Mon Sep 17 00:00:00 2001 From: Diederik van der Boor Date: Sun, 24 Feb 2013 17:31:26 +0100 Subject: [PATCH] Add column- classes to the admin list This simplifies CSS styling to set column widths. --- django/contrib/admin/templatetags/admin_list.py | 6 +++--- docs/ref/contrib/admin/index.txt | 7 +++++++ docs/releases/1.6.txt | 3 +++ 3 files changed, 13 insertions(+), 3 deletions(-) diff --git a/django/contrib/admin/templatetags/admin_list.py b/django/contrib/admin/templatetags/admin_list.py index c5bcad342b..c08193d238 100644 --- a/django/contrib/admin/templatetags/admin_list.py +++ b/django/contrib/admin/templatetags/admin_list.py @@ -12,10 +12,9 @@ from django.db import models from django.utils import formats from django.utils.html import format_html from django.utils.safestring import mark_safe -from django.utils import six from django.utils.text import capfirst from django.utils.translation import ugettext as _ -from django.utils.encoding import smart_text, force_text +from django.utils.encoding import force_text from django.template import Library from django.template.loader import get_template from django.template.context import Context @@ -112,12 +111,13 @@ def result_headers(cl): # Not sortable yield { "text": text, + "class_attrib": format_html(' class="column-{0}"', field_name), "sortable": False, } continue # OK, it is sortable if we got this far - th_classes = ['sortable'] + th_classes = ['sortable', 'column-{0}'.format(field_name)] order_type = '' new_order_type = 'asc' sort_priority = 0 diff --git a/docs/ref/contrib/admin/index.txt b/docs/ref/contrib/admin/index.txt index 353c121cbc..67ed4231a2 100644 --- a/docs/ref/contrib/admin/index.txt +++ b/docs/ref/contrib/admin/index.txt @@ -543,6 +543,13 @@ subclass:: The above will tell Django to order by the ``first_name`` field when trying to sort by ``colored_first_name`` in the admin. + * .. versionadded:: 1.6 + + The field names in ``list_display`` will also appear as CSS classes in + the HTML output, in the form of ``column-`` on each ```` + element. This can be used to set column widths in a CSS file for example. + + .. attribute:: ModelAdmin.list_display_links Set ``list_display_links`` to control which fields in ``list_display`` diff --git a/docs/releases/1.6.txt b/docs/releases/1.6.txt index 4847f6b035..2022a46c08 100644 --- a/docs/releases/1.6.txt +++ b/docs/releases/1.6.txt @@ -101,6 +101,9 @@ Minor features context through to feed templates using a new `Feed.get_context_data()` callback. +* The admin list columns have a ``column-`` class in the HTML + so the columns header can be styled with CSS, e.g. to set a column width. + Backwards incompatible changes in 1.6 =====================================