I want to add a filter in an admin changelist by a property of a foreign key, e.g.
class Address(model.Models): street = models.CharField(max_length=25) city = models.CharField(max_length=25) country = models.CharField(max_length=25) class Customer(models.Model): name = models.CharField(max_length=25) address = models.ForeignKey(Address)
Let's say in the Customer admin changelist I want to show a filter by city and country (so show me all customers in a particular country or city).
But the standard list_filter() functionality seems to only allow filtering by fields directly on the model and not on any of its foreign key. I've tried:
list_filter = ("address__country",)
or
list_filter = ("address.country",)
but I always get the same type of error:
'address__country' is not a callable or an attribute
Any suggestions would be welcome. Is there some special naming convention/syntax to allow filtering on FK properties?
See https://code.djangoproject.com/ticket/3400 . It works ok in django 1.3 :)
class Room(models.Model): house = models.ForeignKey(House) def __unicode__(self): return self.house.town.name class Booking(models.Model): room = models.ForeignKey(Room) def __unicode__(self): return self.room.house.town.name class BookingOpts(admin.ModelAdmin): list_filter = ('room__house__town',) raw_id_admin = ('room', ) admin.site.register(Town) admin.site.register(House) admin.site.register(Room) admin.site.register(Booking, BookingOpts)
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With