2009-01-11 7 views
10

Ceci est facile pour les non-inlines. Il suffit de passer outre les éléments suivants dans les admin.py vos AdminOptions:Comment ajouter un widget d'administration inline personnalisé dans Django?

def formfield_for_dbfield(self, db_field, **kwargs): 
    if db_field.name == 'photo': 
     kwargs['widget'] = AdminImageWidget() 
     return db_field.formfield(**kwargs) 
    return super(NewsOptions,self).formfield_for_dbfield(db_field,**kwargs) 

Je ne peux pas trouver comment adapter cela fonctionne pour inline.

Répondre

8

Cela fonctionne exactement de la même manière. Les classes TabularInline et StackedInline ont également une méthode formfield_for_dbfield, et vous la remplacez de la même manière dans votre sous-classe.

+0

Doh! Je compliquais trop les choses et tripotais InlineFormsetFactory et autres! –

1

Modifier: Nevermind. C'était juste une erreur stupide de ma part. Pourriez-vous éventuellement fournir un petit extrait de ce travail dans les lignes? Quand j'essaye le code ci-dessous, je reçois juste un peu de keyerror bizarre.

class PictureInline(admin.StackedInline): 
    model = Picture_Gallery 
    extra = 3 
    def formfield_for_dbfield(self, db_field, **kwargs): 
     if db_field.name == 'name': 
      kwargs['widget'] = MyWidget() 
     return super(PictureInline,self).formfield_for_dbfield(db_field,**kwargs) 
6

Depuis Django 1.1, formfield_overrides travaille également

formfield_overrides = { 
    models.ImageField: {'widget': AdminImageWidget}, 
} 
+0

Le problème est qu'il semble vouloir ajouter un nouveau champ lorsque default = est défini sur quelque chose sur l'inline. –

Questions connexes