Agregando html en admin model list Django

Hace un tiempo necesité 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.

¡Y eso es todo! Este post ha sido rápido, pero me pareció algo que puede ser útil frecuentemente y era rápido de explicar.

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

Saludos!

Alberto.