From 6260ae70151bc1be4c2dade27163d0790e79867b Mon Sep 17 00:00:00 2001 From: I am Clinton Date: Thu, 21 May 2015 10:07:38 -0500 Subject: [PATCH] [1.8.x] Cosmetic edits and minor fixes to docs/ref/contrib/admin/index.txt Backport of 32f0c8f79697391e7067f1479045aa910ffa2c4e from master --- docs/ref/contrib/admin/index.txt | 62 +++++++++++++++++--------------- 1 file changed, 33 insertions(+), 29 deletions(-) diff --git a/docs/ref/contrib/admin/index.txt b/docs/ref/contrib/admin/index.txt index 6ae67a27fc..06615a01d6 100644 --- a/docs/ref/contrib/admin/index.txt +++ b/docs/ref/contrib/admin/index.txt @@ -255,12 +255,10 @@ subclass:: .. attribute:: ModelAdmin.fields - If you need to achieve simple changes in the layout of fields in the forms - of the "add" and "change" pages like only showing a subset of the available - fields, modifying their order or grouping them in rows you can use the - ``fields`` option (for more complex layout needs see the - :attr:`~ModelAdmin.fieldsets` option described in the next section). For - example, you could define a simpler version of the admin form for the + Use the ``fields`` option to make simple layout changes in the forms on + the "add" and "change" pages such as showing only a subset of available + fields, modifying their order, or grouping them into rows. For example, you + could define a simpler version of the admin form for the :class:`django.contrib.flatpages.models.FlatPage` model as follows:: class FlatPageAdmin(admin.ModelAdmin): @@ -271,6 +269,8 @@ subclass:: values defined in :attr:`ModelAdmin.readonly_fields` to be displayed as read-only. + For more complex layout needs, see the :attr:`~ModelAdmin.fieldsets` option. + The ``fields`` option, unlike :attr:`~ModelAdmin.list_display`, may only contain names of fields on the model or the form specified by :attr:`~ModelAdmin.form`. It may contain callables only if they are listed @@ -278,7 +278,7 @@ subclass:: To display multiple fields on the same line, wrap those fields in their own tuple. In this example, the ``url`` and ``title`` fields will display on the - same line and the ``content`` field will be displayed below them in its + same line and the ``content`` field will be displayed below them on its own line:: class FlatPageAdmin(admin.ModelAdmin): @@ -362,7 +362,7 @@ subclass:: listed in :attr:`~ModelAdmin.readonly_fields`. * ``classes`` - A list containing extra CSS classes to apply to the fieldset. + A list or tuple containing extra CSS classes to apply to the fieldset. Example:: @@ -1107,7 +1107,7 @@ subclass:: search_fields = ['foreign_key__related_fieldname'] For example, if you have a blog entry with an author, the following - definition would enable search blog entries by the email address of the + definition would enable searching blog entries by the email address of the author:: search_fields = ['user__email'] @@ -1126,8 +1126,9 @@ subclass:: with an operator: ``^`` - Matches the beginning of the field. For example, if ``search_fields`` - is set to ``['^first_name', '^last_name']`` and a user searches for + Use the '^' operator to match starting at the beginning of the + field. For example, if ``search_fields`` is set to + ``['^first_name', '^last_name']`` and a user searches for ``john lennon``, Django will do the equivalent of this SQL ``WHERE`` clause:: @@ -1141,10 +1142,11 @@ subclass:: index for this query, even though it's a ``LIKE`` query. ``=`` - Matches exactly, case-insensitive. For example, if - ``search_fields`` is set to ``['=first_name', '=last_name']`` and - a user searches for ``john lennon``, Django will do the equivalent - of this SQL ``WHERE`` clause:: + Use the '=' operator for case-insensitive exact matching. For + example, if ``search_fields`` is set to + ``['=first_name', '=last_name']`` and a user searches for + ``john lennon``, Django will do the equivalent of this SQL + ``WHERE`` clause:: WHERE (first_name ILIKE 'john' OR last_name ILIKE 'john') AND (first_name ILIKE 'lennon' OR last_name ILIKE 'lennon') @@ -1154,8 +1156,9 @@ subclass:: ``first_name`` is exactly ``'john winston'`` (containing a space). ``@`` - Performs a full-text match. This is like the default search method but - uses an index. Currently this is only available for MySQL. + Using the '@' operator to perform a full text match. This is like the + default search method but uses an index. Currently this is only + available for MySQL. If you need to customize search you can use :meth:`ModelAdmin.get_search_results` to provide additional or alternate @@ -1308,8 +1311,8 @@ templates used by the :class:`ModelAdmin` views: .. method:: ModelAdmin.get_search_results(request, queryset, search_term) - The ``get_search_results`` method modifies the list of objects displayed in - to those that match the provided search term. It accepts the request, a + The ``get_search_results`` method modifies the list of objects displayed + into those that match the provided search term. It accepts the request, a queryset that applies the current filters, and the user-provided search term. It returns a tuple containing a queryset modified to implement the search, and a boolean indicating if the results may contain duplicates. @@ -1617,9 +1620,9 @@ templates used by the :class:`ModelAdmin` views: .. admonition:: Note - Any ``choices`` attribute set on the formfield will limited to the form - field only. If the corresponding field on the model has choices set, - the choices provided to the form must be a valid subset of those + Any ``choices`` attribute set on the formfield will be limited to the + form field only. If the corresponding field on the model has choices + set, the choices provided to the form must be a valid subset of those choices, otherwise the form submission will fail with a :exc:`~django.core.exceptions.ValidationError` when the model itself is validated before saving. @@ -2070,7 +2073,7 @@ The ``InlineModelAdmin`` class adds: overhead of having to select all the related instances to display in the drop-down. - ``raw_id_fields`` is a list of fields you would like to change into a + ``raw_id_fields`` is a list of fields you would like to change into an ``Input`` widget for either a ``ForeignKey`` or ``ManyToManyField``:: class BookInline(admin.TabularInline): @@ -2320,14 +2323,15 @@ you have the following models:: class Product(models.Model): name = models.CharField(max_length=100) -If you want to allow editing and creating ``Image`` instance on the ``Product`` -add/change views you can use :class:`~django.contrib.contenttypes.admin.GenericTabularInline` +If you want to allow editing and creating an ``Image`` instance on the +``Product``, add/change views you can use +:class:`~django.contrib.contenttypes.admin.GenericTabularInline` or :class:`~django.contrib.contenttypes.admin.GenericStackedInline` (both subclasses of :class:`~django.contrib.contenttypes.admin.GenericInlineModelAdmin`) -provided by :mod:`~django.contrib.contenttypes.admin`, they implement tabular and -stacked visual layouts for the forms representing the inline objects -respectively just like their non-generic counterparts and behave just like any -other inline. In your ``admin.py`` for this example app:: +provided by :mod:`~django.contrib.contenttypes.admin`. They implement tabular +and stacked visual layouts for the forms representing the inline objects, +respectively, just like their non-generic counterparts. They behave just like +any other inline. In your ``admin.py`` for this example app:: from django.contrib import admin from django.contrib.contenttypes.admin import GenericTabularInline