diff options
| author | Shreya Bamne <shreya.bamne@gmail.com> | 2021-12-08 15:24:55 +0100 |
|---|---|---|
| committer | Carlton Gibson <carlton.gibson@noumenal.es> | 2021-12-08 15:25:52 +0100 |
| commit | 8a4e5067605e608c3fcbb5ca11e0019eac8b40aa (patch) | |
| tree | 96d96bf001919d322c6f84f562f35b722a2c06fc /docs/ref | |
| parent | 2b76f457494414f96d3848a5591909cbb48239e9 (diff) | |
Fixed #19721 -- Allowed admin filters to customize the list separator.
Diffstat (limited to 'docs/ref')
| -rw-r--r-- | docs/ref/contrib/admin/filters.txt | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/docs/ref/contrib/admin/filters.txt b/docs/ref/contrib/admin/filters.txt index f78005936d..0dc119af3f 100644 --- a/docs/ref/contrib/admin/filters.txt +++ b/docs/ref/contrib/admin/filters.txt @@ -176,6 +176,25 @@ allows to store:: ('title', admin.EmptyFieldListFilter), ) +By defining a filter using the ``__in`` lookup, it is possible to filter for +any of a group of values. You need to override the ``expected_parameters`` +method, and the specify the ``lookup_kwargs`` attribute with the appropriate +field name. By default, multiple values in the query string will be separated +with commas, but this can be customized via the ``list_separator`` attribute. +The following example shows such a filter using the vertical-pipe character as +the separator:: + + class FilterWithCustomSeparator(admin.FieldListFilter): + # custom list separator that should be used to separate values. + list_separator = '|' + + def __init__(self, field, request, params, model, model_admin, field_path): + self.lookup_kwarg = '%s__in' % field_path + super().__init__(field, request, params, model, model_admin, field_path) + + def expected_parameters(self): + return [self.lookup_kwarg] + .. note:: The :class:`~django.contrib.contenttypes.fields.GenericForeignKey` field is |
