summaryrefslogtreecommitdiff
path: root/django
diff options
context:
space:
mode:
Diffstat (limited to 'django')
-rw-r--r--django/contrib/admin/filters.py6
-rw-r--r--django/db/models/fields/__init__.py4
-rw-r--r--django/db/models/fields/reverse_related.py4
3 files changed, 9 insertions, 5 deletions
diff --git a/django/contrib/admin/filters.py b/django/contrib/admin/filters.py
index 7cf75bcd0d..d65e01d5e2 100644
--- a/django/contrib/admin/filters.py
+++ b/django/contrib/admin/filters.py
@@ -194,7 +194,11 @@ class RelatedFieldListFilter(FieldListFilter):
return [self.lookup_kwarg, self.lookup_kwarg_isnull]
def field_choices(self, field, request, model_admin):
- return field.get_choices(include_blank=False)
+ ordering = ()
+ related_admin = model_admin.admin_site._registry.get(field.remote_field.model)
+ if related_admin is not None:
+ ordering = related_admin.get_ordering(request)
+ return field.get_choices(include_blank=False, ordering=ordering)
def choices(self, changelist):
yield {
diff --git a/django/db/models/fields/__init__.py b/django/db/models/fields/__init__.py
index 04c7f002bc..fc4966c8b7 100644
--- a/django/db/models/fields/__init__.py
+++ b/django/db/models/fields/__init__.py
@@ -807,7 +807,7 @@ class Field(RegisterLookupMixin):
return return_None
return str # return empty string
- def get_choices(self, include_blank=True, blank_choice=BLANK_CHOICE_DASH, limit_choices_to=None):
+ def get_choices(self, include_blank=True, blank_choice=BLANK_CHOICE_DASH, limit_choices_to=None, ordering=()):
"""
Return choices with a default blank choices included, for use
as <select> choices for this field.
@@ -828,7 +828,7 @@ class Field(RegisterLookupMixin):
)
return (blank_choice if include_blank else []) + [
(choice_func(x), str(x))
- for x in rel_model._default_manager.complex_filter(limit_choices_to)
+ for x in rel_model._default_manager.complex_filter(limit_choices_to).order_by(*ordering)
]
def value_to_string(self, obj):
diff --git a/django/db/models/fields/reverse_related.py b/django/db/models/fields/reverse_related.py
index 828d79d6ac..eb6b934259 100644
--- a/django/db/models/fields/reverse_related.py
+++ b/django/db/models/fields/reverse_related.py
@@ -114,7 +114,7 @@ class ForeignObjectRel(FieldCacheMixin):
self.related_model._meta.model_name,
)
- def get_choices(self, include_blank=True, blank_choice=BLANK_CHOICE_DASH):
+ def get_choices(self, include_blank=True, blank_choice=BLANK_CHOICE_DASH, ordering=()):
"""
Return choices with a default blank choices included, for use
as <select> choices for this field.
@@ -123,7 +123,7 @@ class ForeignObjectRel(FieldCacheMixin):
initially for utilization by RelatedFieldListFilter.
"""
return (blank_choice if include_blank else []) + [
- (x.pk, str(x)) for x in self.related_model._default_manager.all()
+ (x.pk, str(x)) for x in self.related_model._default_manager.order_by(*ordering)
]
def is_hidden(self):