Opened 16 years ago

Closed 16 years ago

Last modified 14 years ago

#8220 closed Uncategorized (wontfix)

ForeignKey dropdown sorting in Admin

Reported by: Rob van der Linde Owned by: nobody
Component: contrib.admin Version: dev
Severity: Normal Keywords: ForeignKey sort ordering
Cc: Triage Stage: Unreviewed
Has patch: no Needs documentation: no
Needs tests: no Patch needs improvement: no
Easy pickings: no UI/UX: no

Description

I have a model with a unique ForeignKey field called "user" to the django.contrib.auth User model. When I edit the model in admin, the dropdown list shows users in the order they are in the database, not sorted.

I would like to be able to sort the users in the dropdown list alphabetically, but cannot see a way how I can do this currently.

Considering the User model already has an ordering field in the UserAdmin class (django.contrib.auth.admin), would it be possible to also use this field for sorting the data in a ForeignKey dropdown box?

Change History (8)

comment:1 by Jacob, 16 years ago

Resolution: wontfix
Status: newclosed

The object is sorted according to its ordering option.

comment:2 by eriks5, 16 years ago

Resolution: wontfix
Status: closedreopened

Setting the ordering option is not possible in this case since the User model is not under our control. In r7806 the default ordering of the User model was removed causing all select boxes in the admin interface for the User model to be sorted in database order instead of username order.

In my application there are thousands of users. It is impossible to find a user if the select box is not sorted by username.

In http://groups.google.com/group/django-users/browse_thread/thread/8526e0c37293d196 a solution to this problem is given, but this is really just a hack. In my application I have a dozen models with a ForeignKey on the User model and had to add that solution to each model. This is not the DRY principle as we're used with in Django.

comment:3 by Malcolm Tredinnick, 16 years ago

Resolution: wontfix
Status: reopenedclosed

The change in [7806] was made for good reasons (sorting thousands of entries every time, whether or not it is wanted is a big performance hit).

Saying that if you want custom admin behaviour you should modify the admin to customise it is "a hack" is a matter of opinion and not necessarily one that everybody agrees with.

In any case, reopening a ticket that has been closed as wontfix by a core developer is not the way things work (otherwise we end up with endless open-close-reopen cycles). If you are unhappy with the resolution, the next step is documented in the ticket lifecycle section of the contributing documentation. You may well have some genuinely new input that hasn't been considered, but at least follow the process so things work smoothly.

in reply to:  2 comment:4 by Julian Bez, 16 years ago

Replying to eriks5:

In my application there are thousands of users. It is impossible to find a user if the select box is not sorted by username.

You really need to start using the raw_id_fields admin option.

comment:5 by (none), 16 years ago

milestone: 1.0 maybe

Milestone 1.0 maybe deleted

comment:6 by SebastienWacquiez, 16 years ago

It's not because [7806] was a good patch that this ticket don't deserve any thinking.

It's right that for medium userbase the lost of defaut ordering *without* any "usable" way to restore the functionnality is a pain.

So if one of the "core developer" can take some time to think about it, and eventualy find/propose a clean way to restore what have been removed, I'm quite sure that I won't be the only one to be happy :)

comment:7 by Seth Gottlieb, 14 years ago

If anyone else was running into this, there is a fairly painless work around.

First, you want to create your own ModelForm that sorts the users how you want. Here is an example:

class EventRegistrationForm(ModelForm):
    def __init__(self, *args, **kwargs):
        super(EventRegistrationForm, self).__init__(*args, **kwargs)
        if self.instance:
            self.fields['user'].queryset = \
                User.objects.all().order_by('username')
    
    class Meta:
        model = EventRegistration

Then, you can wire in your admin to use that form rather than the default:

class RegistrantInline(admin.TabularInline):
	model = EventRegistration
	form = EventRegistrationForm

comment:8 by atkinsonr@…, 14 years ago

Easy pickings: unset
Severity: Normal
Type: Uncategorized
UI/UX: unset

Another workaround for people finding this on google is ModelAdmin.foreign_key_for_field [1] introduced on Django 1.1.

[1] https://docs.djangoproject.com/en/1.1/ref/contrib/admin/#django.contrib.admin.ModelAdmin.formfield_for_foreignkey

Note: See TracTickets for help on using tickets.
Back to Top