Wollte Carl Meyers Antwort erweitern, die bis heute perfekt funktioniert.
Ich verwende immer TextField
anstelle von CharField
(mit oder ohne Auswahlmöglichkeiten) und lege Zeichenbeschränkungen eher auf der UI / API-Seite als auf DB-Ebene fest. Damit dies dynamisch funktioniert:
from django import forms
from django.contrib import admin
class BaseAdmin(admin.ModelAdmin):
"""
Base admin capable of forcing widget conversion
"""
def formfield_for_dbfield(self, db_field, **kwargs):
formfield = super(BaseAdmin, self).formfield_for_dbfield(
db_field, **kwargs)
display_as_charfield = getattr(self, 'display_as_charfield', [])
display_as_choicefield = getattr(self, 'display_as_choicefield', [])
if db_field.name in display_as_charfield:
formfield.widget = forms.TextInput(attrs=formfield.widget.attrs)
elif db_field.name in display_as_choicefield:
formfield.widget = forms.Select(choices=formfield.choices,
attrs=formfield.widget.attrs)
return formfield
Ich habe einen Modellnamen , Post
wo title
, slug
und state
sind TextField
s und state
hat Entscheidungen. Die Admin-Definition sieht folgendermaßen aus:
@admin.register(Post)
class PostAdmin(BaseAdmin):
list_display = ('pk', 'title', 'author', 'org', 'state', 'created',)
search_fields = [
'title',
'author__username',
]
display_as_charfield = ['title', 'slug']
display_as_choicefield = ['state']
Dachte, andere, die nach Antworten suchen, könnten dies nützlich finden.