Я решил эту проблему с поддержкой 'all'.
в models.py:
STATUSES_CHOICE = (
('0', 'Active'),
('1', 'Deactive'),
('2', 'Suspended'),
)
class Client(models.Model):
...
status = models.IntegerField(verbose_name=_('Status'),
default=0,
db_index=True)
в admin.py:
class StatusAdminFilter(SimpleListFilter):
title = _('Status')
parameter_name = 'status'
all_param_value = 'all'
def lookups(self, request, model_admin):
return STATUSES_CHOICE
def queryset(self, request, queryset):
status = self.value()
try:
return (queryset if status == self.all_param_value else
queryset.filter(status=int(status)))
except ValueError:
raise Http404
def choices(self, cl):
yield {'selected': self.value() == self.all_param_value,
'query_string': cl.get_query_string(
{self.parameter_name: self.all_param_value},
[self.parameter_name]),
'display': _('All')}
for lookup, title in self.lookup_choices:
yield {'selected': self.value() == lookup,
'query_string': cl.get_query_string(
{self.parameter_name: lookup}, []),
'display': title}
class ClientAdmin(admin.ModelAdmin):
list_filter = (StatusAdminFilter,)
def changelist_view(self, request, extra_context=None):
if not request.GET.has_key('status'):
q = request.GET.copy()
q['status'] = '0' # default value for status
request.GET = q
request.META['QUERY_STRING'] = request.GET.urlencode()
return super(ClientAdmin, self).changelist_view(
request, extra_context=extra_context)