2009-01-11 6 views
10

Esto es fácil para no en línea. Sólo anular el siguiente en los AdminOptions sus admin.py:¿Cómo agrego un widget de administración en línea personalizado en 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) 

no puedo encontrar la manera de adaptar este a trabajar para inline.

Respuesta

8

Funciona exactamente de la misma manera. Las clases TabularInline y StackedInline también tienen un método formfield_for_dbfield, y lo reemplaza de la misma manera en su subclase.

+0

Doh! Estaba complicando las cosas y jugueteando con InlineFormsetFactory y cosas por el estilo. –

1

Edit: Nevermind. Esto fue solo un estúpido error de mi parte.

¿Podría proporcionar un pequeño fragmento de este trabajo en línea? Cuando pruebo el código a continuación, estoy obteniendo un keyerror extraño.

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

Desde Django 1.1, formfield_overrides también está trabajando

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

El problema es que parece querer agregar un nuevo campo cuando default = está establecido en algo en línea. –

Cuestiones relacionadas