Agregando html en admin model list Django

Hace un tiempo necesitamos modificar el listado de usuarios en un proyecto. Dando un garbeo por la red encontré que es realmente sencillo hacer esto en Django.

Por ejemplo, agregando un botón, en lugar de hacer su primarkey clicable para ver el detalle.

Puede ser útil por ejemplo también para las foreignKey, ya que puedes agregar un botón para enlazar al detalle de ese contenido asociado, desde este mismo listado. También para mostrar imágenes del perfil del usuario para saber quien es con un único rápido vistazo al listado, o cualquier otra cosa que se te ocurra y puedas hacer con código HTML.

Para hacer este tipo de cosas, únicamente hay que modificar el archivo admin.py en cuestión. Creando una función que genere este campo, y agregarlo al “list_display”.

Imaginad que tenemos un modelo “Consumer” que son los usuarios de nuestra plataforma y únicamente queremos agregar un botón para ver detalle.

from django.contrib import admin
from .models import Consumer
class ConsumerAdmin(admin.ModelAdmin):

def get_user_link(self, obj):
return <a href=”/admin/User/consumer/’+str(obj.userId)+’” class=”detail_user”>Ver usuario</a>’
get_user_link.short_description = ‘Usuario’
get_user_link.allow_tags = True
list_display = (‘get_user_link’, ‘nombre’, ‘apellidos’, ‘nacimiento’, ‘direccion’,)
admin.site.register(Consumer, ConsumerAdmin)

Con esto ya tenemos el HTML, ahora faltará que le deis forma con vuestra hoja de estilos.
El punto importante es “.allow_tags = True”, ya que sin esto, no nos renderizará el HTML en el listado.

PS: Efectivamente, la foto de portada nada tiene que ver con el contenido del post, simplemente me gustan los perros :D

Saludos!
Alberto.
Post original de: http://blog.algargar.com/2015/10/26/agregando-html-en-admin-model-list-django/

One clap, two clap, three clap, forty?

By clapping more or less, you can signal to us which stories really stand out.