mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #10776 -- Added metadata targets for the contrib.admin docs, and used one of those targets to clarify the SlugField docs. Thanks to ernop for the suggestion, and timo for the patch.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@10564 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -7,6 +7,8 @@ The Django admin site | |||||||
| .. module:: django.contrib.admin | .. module:: django.contrib.admin | ||||||
|    :synopsis: Django's admin site. |    :synopsis: Django's admin site. | ||||||
|  |  | ||||||
|  | .. currentmodule:: django.contrib.admin | ||||||
|  |  | ||||||
| One of the most powerful parts of Django is the automatic admin interface. It | One of the most powerful parts of Django is the automatic admin interface. It | ||||||
| reads metadata in your model to provide a powerful and production-ready | reads metadata in your model to provide a powerful and production-ready | ||||||
| interface that content producers can immediately use to start adding content to | interface that content producers can immediately use to start adding content to | ||||||
| @@ -46,7 +48,7 @@ Other topics | |||||||
|    :maxdepth: 1 |    :maxdepth: 1 | ||||||
|  |  | ||||||
|    actions |    actions | ||||||
|     |  | ||||||
| .. seealso:: | .. seealso:: | ||||||
|  |  | ||||||
|     For information about serving the media files (images, JavaScript, and CSS) |     For information about serving the media files (images, JavaScript, and CSS) | ||||||
| @@ -55,6 +57,8 @@ Other topics | |||||||
| ``ModelAdmin`` objects | ``ModelAdmin`` objects | ||||||
| ====================== | ====================== | ||||||
|  |  | ||||||
|  | .. class:: ModelAdmin | ||||||
|  |  | ||||||
| The ``ModelAdmin`` class is the representation of a model in the admin | The ``ModelAdmin`` class is the representation of a model in the admin | ||||||
| interface. These are stored in a file named ``admin.py`` in your application. | interface. These are stored in a file named ``admin.py`` in your application. | ||||||
| Let's take a look at a very simple example of the ``ModelAdmin``:: | Let's take a look at a very simple example of the ``ModelAdmin``:: | ||||||
| @@ -90,8 +94,7 @@ subclass:: | |||||||
|     class AuthorAdmin(admin.ModelAdmin): |     class AuthorAdmin(admin.ModelAdmin): | ||||||
|         date_hierarchy = 'pub_date' |         date_hierarchy = 'pub_date' | ||||||
|  |  | ||||||
| ``date_hierarchy`` | .. attribute:: ModelAdmin.date_hierarchy | ||||||
| ~~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Set ``date_hierarchy`` to the name of a ``DateField`` or ``DateTimeField`` in | Set ``date_hierarchy`` to the name of a ``DateField`` or ``DateTimeField`` in | ||||||
| your model, and the change list page will include a date-based drilldown | your model, and the change list page will include a date-based drilldown | ||||||
| @@ -101,8 +104,7 @@ Example:: | |||||||
|  |  | ||||||
|     date_hierarchy = 'pub_date' |     date_hierarchy = 'pub_date' | ||||||
|  |  | ||||||
| ``form`` | .. attribute:: ModelAdmin.form | ||||||
| ~~~~~~~~ |  | ||||||
|  |  | ||||||
| By default a ``ModelForm`` is dynamically created for your model. It is used | By default a ``ModelForm`` is dynamically created for your model. It is used | ||||||
| to create the form presented on both the add/change pages. You can easily | to create the form presented on both the add/change pages. You can easily | ||||||
| @@ -111,8 +113,7 @@ add/change pages. | |||||||
|  |  | ||||||
| For an example see the section `Adding custom validation to the admin`_. | For an example see the section `Adding custom validation to the admin`_. | ||||||
|  |  | ||||||
| ``fieldsets`` | .. attribute:: ModelAdmin.fieldsets | ||||||
| ~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Set ``fieldsets`` to control the layout of admin "add" and "change" pages. | Set ``fieldsets`` to control the layout of admin "add" and "change" pages. | ||||||
|  |  | ||||||
| @@ -191,8 +192,7 @@ The ``field_options`` dictionary can have the following keys: | |||||||
|         ``django.utils.html.escape()`` to escape any HTML special |         ``django.utils.html.escape()`` to escape any HTML special | ||||||
|         characters. |         characters. | ||||||
|  |  | ||||||
| ``fields`` | .. attribute:: ModelAdmin.fields | ||||||
| ~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Use this option as an alternative to ``fieldsets`` if the layout does not | Use this option as an alternative to ``fieldsets`` if the layout does not | ||||||
| matter and if you want to only show a subset of the available fields in the | matter and if you want to only show a subset of the available fields in the | ||||||
| @@ -211,8 +211,7 @@ displayed, sequentially, in the form. | |||||||
|     dictionary key that is within the ``fieldsets`` option, as described in |     dictionary key that is within the ``fieldsets`` option, as described in | ||||||
|     the previous section. |     the previous section. | ||||||
|  |  | ||||||
| ``exclude`` | .. attribute:: ModelAdmin.exclude | ||||||
| ~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| This attribute, if given, should be a list of field names to exclude from the | This attribute, if given, should be a list of field names to exclude from the | ||||||
| form. | form. | ||||||
| @@ -237,22 +236,19 @@ Since the Author model only has three fields, ``name``, ``title``, and | |||||||
| ``birth_date``, the forms resulting from the above declarations will contain | ``birth_date``, the forms resulting from the above declarations will contain | ||||||
| exactly the same fields. | exactly the same fields. | ||||||
|  |  | ||||||
| ``filter_horizontal`` | .. attribute:: ModelAdmin.filter_horizontal | ||||||
| ~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Use a nifty unobtrusive JavaScript "filter" interface instead of the | Use a nifty unobtrusive JavaScript "filter" interface instead of the | ||||||
| usability-challenged ``<select multiple>`` in the admin form. The value is a | usability-challenged ``<select multiple>`` in the admin form. The value is a | ||||||
| list of fields that should be displayed as a horizontal filter interface. See | list of fields that should be displayed as a horizontal filter interface. See | ||||||
| ``filter_vertical`` to use a vertical interface. | ``filter_vertical`` to use a vertical interface. | ||||||
|  |  | ||||||
| ``filter_vertical`` | .. attribute:: ModelAdmin.filter_vertical | ||||||
| ~~~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Same as ``filter_horizontal``, but is a vertical display of the filter | Same as ``filter_horizontal``, but is a vertical display of the filter | ||||||
| interface. | interface. | ||||||
|  |  | ||||||
| ``list_display`` | .. attribute:: ModelAdmin.list_display | ||||||
| ~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Set ``list_display`` to control which fields are displayed on the change list | Set ``list_display`` to control which fields are displayed on the change list | ||||||
| page of the admin. | page of the admin. | ||||||
| @@ -389,8 +385,7 @@ A few special cases to note about ``list_display``: | |||||||
|       The above will tell Django to order by the ``first_name`` field when |       The above will tell Django to order by the ``first_name`` field when | ||||||
|       trying to sort by ``colored_first_name`` in the admin. |       trying to sort by ``colored_first_name`` in the admin. | ||||||
|  |  | ||||||
| ``list_display_links`` | .. attribute:: ModelAdmin.list_display_links | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Set ``list_display_links`` to control which fields in ``list_display`` should | Set ``list_display_links`` to control which fields in ``list_display`` should | ||||||
| be linked to the "change" page for an object. | be linked to the "change" page for an object. | ||||||
| @@ -415,8 +410,7 @@ the change list page:: | |||||||
|  |  | ||||||
| .. _admin-list-editable: | .. _admin-list-editable: | ||||||
|  |  | ||||||
| ``list_editable`` | .. attribute:: ModelAdmin.list_editable | ||||||
| ~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| .. versionadded:: 1.1 | .. versionadded:: 1.1 | ||||||
|  |  | ||||||
| @@ -441,8 +435,7 @@ edit and save multiple rows at once. | |||||||
|  |  | ||||||
|     You'll get a validation error if any of these rules are broken. |     You'll get a validation error if any of these rules are broken. | ||||||
|  |  | ||||||
| ``list_filter`` | .. attribute:: ModelAdmin.list_filter | ||||||
| ~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Set ``list_filter`` to activate filters in the right sidebar of the change list | Set ``list_filter`` to activate filters in the right sidebar of the change list | ||||||
| page of the admin. This should be a list of field names, and each specified | page of the admin. This should be a list of field names, and each specified | ||||||
| @@ -462,14 +455,12 @@ The above code results in an admin change list page that looks like this: | |||||||
|  |  | ||||||
| (This example also has ``search_fields`` defined. See below.) | (This example also has ``search_fields`` defined. See below.) | ||||||
|  |  | ||||||
| ``list_per_page`` | .. attribute:: ModelAdmin.list_per_page | ||||||
| ~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Set ``list_per_page`` to control how many items appear on each paginated admin | Set ``list_per_page`` to control how many items appear on each paginated admin | ||||||
| change list page. By default, this is set to ``100``. | change list page. By default, this is set to ``100``. | ||||||
|  |  | ||||||
| ``list_select_related`` | .. attribute:: ModelAdmin.list_select_related | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Set ``list_select_related`` to tell Django to use ``select_related()`` in | Set ``list_select_related`` to tell Django to use ``select_related()`` in | ||||||
| retrieving the list of objects on the admin change list page. This can save you | retrieving the list of objects on the admin change list page. This can save you | ||||||
| @@ -483,13 +474,11 @@ if one of the ``list_display`` fields is a ``ForeignKey``. | |||||||
| For more on ``select_related()``, see | For more on ``select_related()``, see | ||||||
| :ref:`the select_related() docs <select-related>`. | :ref:`the select_related() docs <select-related>`. | ||||||
|  |  | ||||||
| ``inlines`` | .. attribute:: ModelAdmin.inlines | ||||||
| ~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| See ``InlineModelAdmin`` objects below. | See ``InlineModelAdmin`` objects below. | ||||||
|  |  | ||||||
| ``ordering`` | .. attribute:: ModelAdmin.ordering | ||||||
| ~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Set ``ordering`` to specify how objects on the admin change list page should be | Set ``ordering`` to specify how objects on the admin change list page should be | ||||||
| ordered. This should be a list or tuple in the same format as a model's | ordered. This should be a list or tuple in the same format as a model's | ||||||
| @@ -502,8 +491,7 @@ If this isn't provided, the Django admin will use the model's default ordering. | |||||||
|     Django will only honor the first element in the list/tuple; any others |     Django will only honor the first element in the list/tuple; any others | ||||||
|     will be ignored. |     will be ignored. | ||||||
|  |  | ||||||
| ``prepopulated_fields`` | .. attribute:: ModelAdmin.prepopulated_fields | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Set ``prepopulated_fields`` to a dictionary mapping field names to the fields | Set ``prepopulated_fields`` to a dictionary mapping field names to the fields | ||||||
| it should prepopulate from:: | it should prepopulate from:: | ||||||
| @@ -521,8 +509,7 @@ dashes for spaces). | |||||||
| ``prepopulated_fields`` doesn't accept ``DateTimeField``, ``ForeignKey``, nor | ``prepopulated_fields`` doesn't accept ``DateTimeField``, ``ForeignKey``, nor | ||||||
| ``ManyToManyField`` fields. | ``ManyToManyField`` fields. | ||||||
|  |  | ||||||
| ``radio_fields`` | .. attribute:: ModelAdmin.radio_fields | ||||||
| ~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| By default, Django's admin uses a select-box interface (<select>) for | By default, Django's admin uses a select-box interface (<select>) for | ||||||
| fields that are ``ForeignKey`` or have ``choices`` set. If a field is present | fields that are ``ForeignKey`` or have ``choices`` set. If a field is present | ||||||
| @@ -538,8 +525,7 @@ You have the choice of using ``HORIZONTAL`` or ``VERTICAL`` from the | |||||||
| Don't include a field in ``radio_fields`` unless it's a ``ForeignKey`` or has | Don't include a field in ``radio_fields`` unless it's a ``ForeignKey`` or has | ||||||
| ``choices`` set. | ``choices`` set. | ||||||
|  |  | ||||||
| ``raw_id_fields`` | .. attribute:: ModelAdmin.raw_id_fields | ||||||
| ~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| By default, Django's admin uses a select-box interface (<select>) for | By default, Django's admin uses a select-box interface (<select>) for | ||||||
| fields that are ``ForeignKey``. Sometimes you don't want to incur the | fields that are ``ForeignKey``. Sometimes you don't want to incur the | ||||||
| @@ -552,8 +538,7 @@ into a ``Input`` widget for either a ``ForeignKey`` or ``ManyToManyField``:: | |||||||
|     class ArticleAdmin(admin.ModelAdmin): |     class ArticleAdmin(admin.ModelAdmin): | ||||||
|         raw_id_fields = ("newspaper",) |         raw_id_fields = ("newspaper",) | ||||||
|  |  | ||||||
| ``save_as`` | .. attribute:: ModelAdmin.save_as | ||||||
| ~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Set ``save_as`` to enable a "save as" feature on admin change forms. | Set ``save_as`` to enable a "save as" feature on admin change forms. | ||||||
|  |  | ||||||
| @@ -566,8 +551,7 @@ rather than the old object. | |||||||
|  |  | ||||||
| By default, ``save_as`` is set to ``False``. | By default, ``save_as`` is set to ``False``. | ||||||
|  |  | ||||||
| ``save_on_top`` | .. attribute:: ModelAdmin.save_on_top | ||||||
| ~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Set ``save_on_top`` to add save buttons across the top of your admin change | Set ``save_on_top`` to add save buttons across the top of your admin change | ||||||
| forms. | forms. | ||||||
| @@ -577,8 +561,7 @@ Normally, the save buttons appear only at the bottom of the forms. If you set | |||||||
|  |  | ||||||
| By default, ``save_on_top`` is set to ``False``. | By default, ``save_on_top`` is set to ``False``. | ||||||
|  |  | ||||||
| ``search_fields`` | .. attribute:: ModelAdmin.search_fields | ||||||
| ~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| Set ``search_fields`` to enable a search box on the admin change list page. | Set ``search_fields`` to enable a search box on the admin change list page. | ||||||
| This should be set to a list of field names that will be searched whenever | This should be set to a list of field names that will be searched whenever | ||||||
| @@ -635,8 +618,7 @@ with an operator: | |||||||
|     Performs a full-text match. This is like the default search method but uses |     Performs a full-text match. This is like the default search method but uses | ||||||
|     an index. Currently this is only available for MySQL. |     an index. Currently this is only available for MySQL. | ||||||
|  |  | ||||||
| ``formfield_overrides`` | .. attribute:: ModelAdmin.formfield_overrides | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| This provides a quick-and-dirty way to override some of the | This provides a quick-and-dirty way to override some of the | ||||||
| :class:`~django.forms.Field` options for use in the admin. | :class:`~django.forms.Field` options for use in the admin. | ||||||
| @@ -676,14 +658,13 @@ The value is another dictionary; these arguments will be passed to | |||||||
|     that have ``raw_id_fields`` or ``radio_fields`` set. That's because |     that have ``raw_id_fields`` or ``radio_fields`` set. That's because | ||||||
|     ``raw_id_fields`` and ``radio_fields`` imply custom widgets of their own. |     ``raw_id_fields`` and ``radio_fields`` imply custom widgets of their own. | ||||||
|  |  | ||||||
| ``actions`` | .. attribute:: ModelAdmin.actions | ||||||
| ~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| A list of actions to make available on the change list page. See | A list of actions to make available on the change list page. See | ||||||
| :ref:`ref-contrib-admin-actions` for details. | :ref:`ref-contrib-admin-actions` for details. | ||||||
|  |  | ||||||
| ``actions_on_top``, ``actions_on_bottom`` | .. attribute:: ModelAdmin.actions_on_top | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | .. attribute:: ModelAdmin.actions_on_bottom | ||||||
|  |  | ||||||
| Controls where on the page the actions bar appears. By default, the admin | Controls where on the page the actions bar appears. By default, the admin | ||||||
| changelist displays actions at the top of the page (``actions_on_top = True; | changelist displays actions at the top of the page (``actions_on_top = True; | ||||||
| @@ -692,8 +673,7 @@ actions_on_bottom = False``). | |||||||
| ``ModelAdmin`` methods | ``ModelAdmin`` methods | ||||||
| ---------------------- | ---------------------- | ||||||
|  |  | ||||||
| ``save_model(self, request, obj, form, change)`` | .. method:: ModelAdmin.save_model(self, request, obj, form, change) | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| The ``save_model`` method is given the ``HttpRequest``, a model instance, | The ``save_model`` method is given the ``HttpRequest``, a model instance, | ||||||
| a ``ModelForm`` instance and a boolean value based on whether it is adding or | a ``ModelForm`` instance and a boolean value based on whether it is adding or | ||||||
| @@ -706,8 +686,7 @@ For example to attach ``request.user`` to the object prior to saving:: | |||||||
|             obj.user = request.user |             obj.user = request.user | ||||||
|             obj.save() |             obj.save() | ||||||
|  |  | ||||||
| ``save_formset(self, request, form, formset, change)`` | .. method:: ModelAdmin.save_formset(self, request, form, formset, change) | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| The ``save_formset`` method is given the ``HttpRequest``, the parent | The ``save_formset`` method is given the ``HttpRequest``, the parent | ||||||
| ``ModelForm`` instance and a boolean value based on whether it is adding or | ``ModelForm`` instance and a boolean value based on whether it is adding or | ||||||
| @@ -724,8 +703,7 @@ model instance:: | |||||||
|                 instance.save() |                 instance.save() | ||||||
|             formset.save_m2m() |             formset.save_m2m() | ||||||
|  |  | ||||||
| ``get_urls(self)`` | .. method:: ModelAdmin.get_urls(self) | ||||||
| ~~~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| .. versionadded:: 1.1 | .. versionadded:: 1.1 | ||||||
|  |  | ||||||
| @@ -769,8 +747,7 @@ Notice the wrapped view in the fifth line above:: | |||||||
|  |  | ||||||
| This wrapping will protect ``self.my_view`` from unauthorized access. | This wrapping will protect ``self.my_view`` from unauthorized access. | ||||||
|  |  | ||||||
| ``formfield_for_foreignkey(self, db_field, request, **kwargs)`` | .. method:: ModelAdmin.formfield_for_foreignkey(self, db_field, request, **kwargs) | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
|  |  | ||||||
| .. versionadded:: 1.1 | .. versionadded:: 1.1 | ||||||
|  |  | ||||||
| @@ -846,7 +823,7 @@ parent model. These are called inlines. Suppose you have these two models:: | |||||||
|         author = models.ForeignKey(Author) |         author = models.ForeignKey(Author) | ||||||
|         title = models.CharField(max_length=100) |         title = models.CharField(max_length=100) | ||||||
|  |  | ||||||
| You can edit the books authored by an author on the author page. You add  | You can edit the books authored by an author on the author page. You add | ||||||
| inlines to a model by specifying them in a ``ModelAdmin.inlines``:: | inlines to a model by specifying them in a ``ModelAdmin.inlines``:: | ||||||
|  |  | ||||||
|     class BookInline(admin.TabularInline): |     class BookInline(admin.TabularInline): | ||||||
| @@ -1167,7 +1144,7 @@ Linking to admin views | |||||||
|  |  | ||||||
| All the admin views use :ref:`named URL patterns <naming-url-patterns>` so it's | All the admin views use :ref:`named URL patterns <naming-url-patterns>` so it's | ||||||
| easy to link to admin views with ``urlresolvers.reverse`` or the :ttag:`url` | easy to link to admin views with ``urlresolvers.reverse`` or the :ttag:`url` | ||||||
| template tag.  | template tag. | ||||||
|  |  | ||||||
| Each model gets its own set of views and its own name using the model's app name | Each model gets its own set of views and its own name using the model's app name | ||||||
| and model name. For example, the "add" view for a ``Choice`` model in a | and model name. For example, the "add" view for a ``Choice`` model in a | ||||||
| @@ -1274,8 +1251,9 @@ Adding views to admin sites | |||||||
|  |  | ||||||
| .. versionadded:: 1.1 | .. versionadded:: 1.1 | ||||||
|  |  | ||||||
| It possible to add additional views to the admin site in the same way one can | Just like ``ModelAdmin``, ``AdminSite`` provides a | ||||||
| add them to ``ModelAdmins``.  This by using the ``get_urls()`` method on an | :meth:`~django.contrib.admin.ModelAdmin.get_urls()` method | ||||||
| AdminSite in the same way as `described above`__ | that can be overridden to define additional views for the site. To add | ||||||
|  | a new view to your admin site, extend the base | ||||||
| __ `get_urls(self)`_ | :meth:`~django.contrib.admin.ModelAdmin.get_urls()` method to include | ||||||
|  | a pattern for your new view. | ||||||
|   | |||||||
| @@ -689,6 +689,10 @@ default length of 50. | |||||||
|  |  | ||||||
| Implies setting :attr:`Field.db_index` to ``True``. | Implies setting :attr:`Field.db_index` to ``True``. | ||||||
|  |  | ||||||
|  | It is often useful to automatically prepopulate a SlugField based on the value | ||||||
|  | of some other value.  You can do this automatically in the admin using | ||||||
|  | :attr:`~django.contrib.admin.ModelAdmin.prepopulated_fields`. | ||||||
|  |  | ||||||
| ``SmallIntegerField`` | ``SmallIntegerField`` | ||||||
| --------------------- | --------------------- | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user