SlideShare a Scribd company logo
1 of 63
Download to read offline
Customizing the Django Admin
     When the Django Admin fails
     and what you can do to fix it


            Peter Baumgartner
               Founder, Lincoln Loop


              Michael Trythall
       User Experience Director, Lincoln Loop




     EuroDjangoCon – May 5, 2009
About Lincoln Loop
●   Django Corporate Sponsor
●   Open source contributer
●
    Services:
    ●
        Development
    ●
        Prototyping
    ●
        Consulting
    ●
        Training


    http://lincolnloop.com
Overview
●   User Interface is important
●   Default Admin UI is one-size-fits-all.
    User experience is not.
●   What can we do to improve upon it?
●   How do we implement those improvements?
(Some) Problems We Face
●   Clients want control over their web site
●   Clients don't want to pay for a minor changes
●   Clients often lack technical knowledge
●   Clients may not have specifications (just ideas)
●   Limited project and developer time
●   Etc, etc...
Problems with New, Custom Systems
               “ Easy is Hard ”
                     - Peter Lewis, NY Times

●   Time consuming – Research, Specs, Dev, Test
●   Hard to tell right from wrong
●   Good chance you might not nail it
●   Reinventing the wheel in most cases
So, What's the Solution?
Leverage the Django Admin!
          Yay Ponies!
The Good News
●   Handful of reusable apps that alleviate some
    of the pain
●   Admin is easy to extend, customize, etc.
●   Djangonauts are thinking about these problems
●   Lots of core functionality already exists in the
    admin
Why Care About UI?
Because...
●   UI is the gateway to application logic
●   Users remember bad experiences
●   Good experiences = Happy Customers = Profit!
●   Contributing helps Django mature
●   Good UI reduces the need for documentation
    & support, but isn't a complete substitute!
Problems with the Default Admin
Not Informative or Assistive
●   No dashboard, statistics, or recent (user)
    activity
●   No actions (or models) highlighted or given
    priority
●   No assistance/help for beginner users
●   Impact from changes is not always clear
●   Disconnect from external systems
Dashboard & Primary Actions Example




         WordPress informs the user of the basics
Doesn't Fit Into Customer Mental Models
●   Relationships (e.x. hierarchy) not intuitive
●   Apps are not organized by context
●   Little (or no) navigation outside of
    breadcrumbs
●   Doesn't mimic familiar process and workflow
Grouping & Navigation Done Right
Admin Clutter
Missing Features
●   Missing common web tools like WYSIWYG, file
    management, etc
●   Difficult to recover from actions (no undo)
●   Better management for complicated models
●   Project-wide search
Undo & Help Example
Poor Display for Complex Models
Field Count
Planning Customizations
Get to Know Your Customer
●   Learn (or ask) about the industry, workflow,
    etc.
●   Understand the needs of the different roles on
    the Customer's team
●   Put yourself in their shoes (empathy)
●   Learn the lingo, use it in your designs (laptop
    vs. notebook)
●   Learn about previously used tools, pros and
    cons
Brainstorming
●   Welcome all ideas, decide on what's
    reasonable
●   Embrace sketches to convey ideas and for
    clarification
●   Get feedback early and often on ideas, even in
    development
●   Don't be afraid to prototype with code
●   Leverage proven UI design patterns
Sketch Example
Satchmo Dashboard Concept
Satchmo Dashboard Concept
Implement!
Customization Options
1. ModelAdmin media
2. Custom templates
3. ModelAdmin/ModelForm hacking
4. Custom views
Low Hanging Fruit For the Win




  http://www.flickr.com/photos/11263821@N05/2224626086
ModelAdmin Media
ModelAdmin Media Code

class ArticleAdmin(admin.ModelAdmin):
    class Media:
        css = {
            "all": ("my_styles.css",)
        }
        js = ("my_code.js",)
ModelAdmin Media Examples
●   JavaScript
    ●   WYSIWYG Editor
    ●
        AJAX
    ●   Fancy Inlines     (drag & drop, dynamic add/delete)
        ‣   http://tinyurl.com/add-remove-inlines
        ‣   http://www.djangosnippets.org/snippets/1053/
    ●   Inject HTML
●   CSS
    ●   Colors
    ●   Layout
ModelAdmin Media Pros & Cons
●   Pros:
    ●   Easy for one-off projects
●   Cons:
    ●   Requires Javascript
    ●   Only works for the Change Form
    ●   Difficult to bundle as reusable app
Custom Templates
Custom Templates
●
    django.contrib.admin is a “reusable
    application”
●   Key templates:
    ●
        admin/base.html
    ●
        admin/index.html
    ●
        admin/change_form.html
    ●
        admin/change_list.html
Per Project/App/Model Templates
Templates can be overridden:
●   Across an entire project
    admin/change_form.html
●   Across an application
    admin/<my_app>/change_form.html
●   For an individual model
    admin/<my_app>/<my_model>/change_form.html
Custom Template Example
demo_app/templates/admin/demo_app/change_list.html


{% extends
"admin/change_list.html" %}

{% block object-tools %}
    <h1 class="errornote">
        Look Here!
    </h1>
    {{ block.super }}
{% endblock %}
Custom Template Tips
●   Extend, don't override
●   Use {{ block.super }} to extend blocks
●   Extend a symlink of the admin templates in
    the event of recursion
●   Extend the extrahead block in base.html for
    admin-wide media
Custom Templates in the Wild
sorl-curator




http://code.google.com/p/sorl-curator/
django-grapelli




http://code.google.com/p/django-grappelli/
ella




http://github.com/ella/ella
Gondola




http://gondolacms.com/
Custom Template Pros & Cons
●   Pros
    ●   Easy
    ●
        Touches every admin view
    ●   No additional work to bundle with reusable apps
●   Cons
    ●   Mostly cosmetic (not functional) changes
ModelAdmin/ModelForm Hacking
ModelAdmin/ModelForm Hacking
●   New in Django 1.0 (newforms-admin)
●   Old stuff (list_display, fields, ordering, etc.)
●   New stuff (exclude, inlines, form, etc.)
●   Really New stuff (list_editable, actions, etc.)
Reregistering a ModelAdmin
from django.contrib import admin
from django.contrib.auth.admin import UserAdmin
from demo_app.models import UserProfile

class UserProfileInline(admin.TabularInline):
    model = UserProfile
    fk_name = 'user'
    max_num = 1

class CustomUserAdmin(UserAdmin):
    inlines = [UserProfileInline, ]

admin.site.unregister(User)
admin.site.register(User, CustomUserAdmin)
Row-level Permissions

class ArticleAdmin(admin.ModelAdmin):
  def save_model(self, request, obj, form,
                                        change):
    obj.user = request.user
    obj.save()

  def queryset(self, request):
    qs = self.model._default_manager.filter(
                               user=request.user)
    return qs
ModelForms
●   Much of ModelAdmin's functionality is a
    wrapper around ModelForm
●   If you can't do it in ModelAdmin, chances are
    ModelForm can help
●   Pulled directly from django.forms and no
    different in functionality
ModelFoms Example
class AuthorForm(forms.ModelForm):
    exclude_states = ['AS', 'GU', 'MP', 'VI',]
    def __init__(self, *args, **kwargs):
        super(AuthorForm, self).__init__(*args,
                                      **kwargs)
        w = self.fields['state'].widget
        choices = []
        for key, value in w.choices:
            if key not in self.exclude_states:
                choices.append((key, value))
        w.choices = choices

class AuthorAdmin(admin.ModelAdmin):
    form = AuthorForm
Caution: Here be Dragons




 http://www.flickr.com/photos/sharynmorrow/3019436/
ModelAdmin/ModelForm Tips
●   The further you dig, the less documentation
    you'll find
●   Don't be afraid to study the source:
    ●
        django.contrib.admin.sites.AdminSite
    ●
        django.contrib.admin.options.ModelAdmin
    ●
        django.forms.models.ModelForm
    ●
        django.contrib.admin.options.InlineModelAdmin
    ●
        django.forms.formsets
●   Use a debugger for sanity (ipdb.set_trace())
ModelAdmin/ModelForm Pros & Cons
●   Pros
    ●   Flexible
    ●
        Powerful
    ●   No additional work to bundle with reusable apps
●   Cons
    ●   Gets complex quickly
    ●   May require getting familiar with undocumented
        Django internals
Custom Views
When in Doubt, Punt




http://www.flickr.com/photos/bobtravis/485216368/
Custom Views
●   The admin just wasn't built to do some things
●   Other things simply aren't worth the trouble
●   Build your own view and plug it into the admin
Custom View URL
class PostAdmin(admin.ModelAdmin):
    def my_view(self, request):
        return admin_my_view(request,
                                    self)
    def get_urls(self):
        urls = super(PostAdmin,
                     self).get_urls()
        my_urls = patterns('',
            (r'^my_view/$', self.my_view)
        )
        return my_urls + urls
Custom View
@permission_required('blog.add_post')
def admin_my_view(request, model_admin):
    opts = model_admin.model._meta
    admin_site = model_admin.admin_site
    has_perm = request.user.has_perm(opts.app_label 
                  + '.' + opts.get_change_permission())
    context = {'admin_site': admin_site.name,
        'title': "My Custom View",
        'opts': opts,
        'root_path': '/%s' % admin_site.root_path,
        'app_label': opts.app_label,
        'has_change_permission': has_perm}
    template = 'admin/demo_app/admin_my_view.html'
    return render_to_response(template, context,
              context_instance=RequestContext(request))
Custom View Template
{% extends "admin/base_site.html" %}
{% load i18n %}
{% block breadcrumbs %}
<div class="breadcrumbs">
    <a href="../../../">{% trans "Home" %}</a> &rsaquo;
    <a href="../../">{{ app_label|capfirst|
escape }}</a> &rsaquo;
    {% if has_change_permission %}<a
href="../">{{ opts.verbose_name_plural|
capfirst }}</a>{% else %}{{ opts.verbose_name_plural|
capfirst }}{% endif %} &rsaquo; My Custom View
</div>
{% endblock %}

{% block content %}
    <!-- do stuff here -->
{% endblock %}
Custom View Example
Custom View Pros & Cons
●   Pros
    ●   More flexible
    ●
        More powerful
    ●   No additional work to bundle with reusable apps
●   Cons
    ●   Can be tricky to integrate into workflow
    ●   You're on your own to validate forms, build
        templates, etc.
Review
●   UI is important. Think about your end-user
●   Think about your users, not your database
●   Newforms-admin gives you hooks for lots of
    easy wins
Questions


  Peter Baumgartner
    pete@lincolnloop.com


    Michael Trythall
   michael@lincolnloop.com




http://lincolnloop.com

More Related Content

What's hot

Rapport PFE : Développement D'une application de gestion des cartes de fidéli...
Rapport PFE : Développement D'une application de gestion des cartes de fidéli...Rapport PFE : Développement D'une application de gestion des cartes de fidéli...
Rapport PFE : Développement D'une application de gestion des cartes de fidéli...Riadh K.
 
Pfe sadki imen
Pfe sadki imenPfe sadki imen
Pfe sadki imenSadki Imen
 
rapport de projet de fin d'étude_PFE
rapport de projet de fin d'étude_PFErapport de projet de fin d'étude_PFE
rapport de projet de fin d'étude_PFEDonia Hammami
 
présentation soutenance PFE
présentation soutenance PFEprésentation soutenance PFE
présentation soutenance PFEHeithem Moumni
 
Présentation PFE - MarouaBouhachem VersionFinale
Présentation PFE - MarouaBouhachem VersionFinalePrésentation PFE - MarouaBouhachem VersionFinale
Présentation PFE - MarouaBouhachem VersionFinaleMaroua Bouhachem
 
Présentation mémoire de Fin d’Etudes
Présentation mémoire de Fin d’EtudesPrésentation mémoire de Fin d’Etudes
Présentation mémoire de Fin d’EtudesAmine MEGDICHE
 
Conception et Mise en place d'une Application Web SPA pour les établissements...
Conception et Mise en place d'une Application Web SPA pour les établissements...Conception et Mise en place d'une Application Web SPA pour les établissements...
Conception et Mise en place d'une Application Web SPA pour les établissements...Ben Ahmed Zohra
 
Appels de procédures distants (RPC)
Appels de procédures distants (RPC)Appels de procédures distants (RPC)
Appels de procédures distants (RPC)Heithem Abbes
 
La spécification des besoins
La spécification des besoinsLa spécification des besoins
La spécification des besoinsIsmahen Traya
 
Présentation PFE mohamed yosri yahyaoui
Présentation PFE  mohamed yosri yahyaouiPrésentation PFE  mohamed yosri yahyaoui
Présentation PFE mohamed yosri yahyaouiYahyaoui Mohamed Yosri
 
Projet de fin d’études
Projet de fin d’études  Projet de fin d’études
Projet de fin d’études TombariAhmed
 
Cours Génie Logiciel - Cours 2 - Cycles de vie
Cours Génie Logiciel - Cours 2 - Cycles de vieCours Génie Logiciel - Cours 2 - Cycles de vie
Cours Génie Logiciel - Cours 2 - Cycles de vieMohammed Amine Mostefai
 
Bus de médiation de services: modèle de corrélation d’événements à base de rè...
Bus de médiation de services: modèle de corrélation d’événements à base de rè...Bus de médiation de services: modèle de corrélation d’événements à base de rè...
Bus de médiation de services: modèle de corrélation d’événements à base de rè...Hamid Barakat
 
Développement d’une application Web et mobile d’un annuaire médical
Développement d’une application Web et mobile d’un annuaire médicalDéveloppement d’une application Web et mobile d’un annuaire médical
Développement d’une application Web et mobile d’un annuaire médicallitayem bechir
 
Introduction aux architectures des SI
Introduction aux architectures des SI Introduction aux architectures des SI
Introduction aux architectures des SI Heithem Abbes
 
Développement d'un forum de discussion
Développement d'un forum de discussionDéveloppement d'un forum de discussion
Développement d'un forum de discussionYoussef NIDABRAHIM
 
Manuel des TP : Atelier Web 2
Manuel des TP : Atelier Web 2Manuel des TP : Atelier Web 2
Manuel des TP : Atelier Web 2Faycel Chaoua
 

What's hot (20)

Rapport PFE : Développement D'une application de gestion des cartes de fidéli...
Rapport PFE : Développement D'une application de gestion des cartes de fidéli...Rapport PFE : Développement D'une application de gestion des cartes de fidéli...
Rapport PFE : Développement D'une application de gestion des cartes de fidéli...
 
Pfe sadki imen
Pfe sadki imenPfe sadki imen
Pfe sadki imen
 
rapport de projet de fin d'étude_PFE
rapport de projet de fin d'étude_PFErapport de projet de fin d'étude_PFE
rapport de projet de fin d'étude_PFE
 
présentation soutenance PFE
présentation soutenance PFEprésentation soutenance PFE
présentation soutenance PFE
 
Présentation PFE - MarouaBouhachem VersionFinale
Présentation PFE - MarouaBouhachem VersionFinalePrésentation PFE - MarouaBouhachem VersionFinale
Présentation PFE - MarouaBouhachem VersionFinale
 
Présentation mémoire de Fin d’Etudes
Présentation mémoire de Fin d’EtudesPrésentation mémoire de Fin d’Etudes
Présentation mémoire de Fin d’Etudes
 
Conception et Mise en place d'une Application Web SPA pour les établissements...
Conception et Mise en place d'une Application Web SPA pour les établissements...Conception et Mise en place d'une Application Web SPA pour les établissements...
Conception et Mise en place d'une Application Web SPA pour les établissements...
 
Appels de procédures distants (RPC)
Appels de procédures distants (RPC)Appels de procédures distants (RPC)
Appels de procédures distants (RPC)
 
La spécification des besoins
La spécification des besoinsLa spécification des besoins
La spécification des besoins
 
Introduction à Angular
Introduction à AngularIntroduction à Angular
Introduction à Angular
 
Présentation PFE mohamed yosri yahyaoui
Présentation PFE  mohamed yosri yahyaouiPrésentation PFE  mohamed yosri yahyaoui
Présentation PFE mohamed yosri yahyaoui
 
Projet de fin d’études
Projet de fin d’études  Projet de fin d’études
Projet de fin d’études
 
Cours Génie Logiciel - Cours 2 - Cycles de vie
Cours Génie Logiciel - Cours 2 - Cycles de vieCours Génie Logiciel - Cours 2 - Cycles de vie
Cours Génie Logiciel - Cours 2 - Cycles de vie
 
Bus de médiation de services: modèle de corrélation d’événements à base de rè...
Bus de médiation de services: modèle de corrélation d’événements à base de rè...Bus de médiation de services: modèle de corrélation d’événements à base de rè...
Bus de médiation de services: modèle de corrélation d’événements à base de rè...
 
Développement d’une application Web et mobile d’un annuaire médical
Développement d’une application Web et mobile d’un annuaire médicalDéveloppement d’une application Web et mobile d’un annuaire médical
Développement d’une application Web et mobile d’un annuaire médical
 
Introduction aux architectures des SI
Introduction aux architectures des SI Introduction aux architectures des SI
Introduction aux architectures des SI
 
Présentation PFE
Présentation PFEPrésentation PFE
Présentation PFE
 
Développement d'un forum de discussion
Développement d'un forum de discussionDéveloppement d'un forum de discussion
Développement d'un forum de discussion
 
Les étapes clés d'un projet web
Les étapes clés d'un projet webLes étapes clés d'un projet web
Les étapes clés d'un projet web
 
Manuel des TP : Atelier Web 2
Manuel des TP : Atelier Web 2Manuel des TP : Atelier Web 2
Manuel des TP : Atelier Web 2
 

Similar to Customizing the Django Admin

Extending CMS Made Simple
Extending CMS Made SimpleExtending CMS Made Simple
Extending CMS Made Simplecmsmssjg
 
Introduction to django framework
Introduction to django frameworkIntroduction to django framework
Introduction to django frameworkKnoldus Inc.
 
Some ways to DRY in Rails
Some ways to DRY in Rails Some ways to DRY in Rails
Some ways to DRY in Rails Framgia Vietnam
 
There's a Module for That, MIMA Summit 2010
There's a Module for That, MIMA Summit 2010There's a Module for That, MIMA Summit 2010
There's a Module for That, MIMA Summit 2010Emma Jane Hogbin Westby
 
[JogjaJS] Single Page Application nganggo Angular.js
[JogjaJS] Single Page Application nganggo Angular.js [JogjaJS] Single Page Application nganggo Angular.js
[JogjaJS] Single Page Application nganggo Angular.js Yanuar W
 
Implementing a Symfony Based CMS in a Publishing Company
Implementing a Symfony Based CMS in a Publishing CompanyImplementing a Symfony Based CMS in a Publishing Company
Implementing a Symfony Based CMS in a Publishing CompanyMarcos Labad
 
Adding custom ui controls to your application (1)
Adding custom ui controls to your application (1)Adding custom ui controls to your application (1)
Adding custom ui controls to your application (1)Oro Inc.
 
Clean code and refactoring
Clean code and refactoringClean code and refactoring
Clean code and refactoringYuriy Gerasimov
 
Joomla Extensions Kung Fu
Joomla Extensions Kung FuJoomla Extensions Kung Fu
Joomla Extensions Kung FuOleg Nesterov
 
Creating Extensible Plugins for WordPress
Creating Extensible Plugins for WordPressCreating Extensible Plugins for WordPress
Creating Extensible Plugins for WordPressHristo Chakarov
 
A Successful Magento Project From Design to Deployment
A Successful Magento Project From Design to DeploymentA Successful Magento Project From Design to Deployment
A Successful Magento Project From Design to DeploymentJoshua Warren
 
Django talk
Django talkDjango talk
Django talkpsibi
 
Developing Custom WordPress Themes for Clients
Developing Custom WordPress Themes for ClientsDeveloping Custom WordPress Themes for Clients
Developing Custom WordPress Themes for ClientsSteven Slack
 
UX DURING MODULE INSTALLATION AND CONFIGURATION
UX DURING MODULE INSTALLATION AND CONFIGURATIONUX DURING MODULE INSTALLATION AND CONFIGURATION
UX DURING MODULE INSTALLATION AND CONFIGURATIONDrupalCamp Kyiv
 
What’S New In Newforms Admin
What’S New In Newforms AdminWhat’S New In Newforms Admin
What’S New In Newforms AdminDjangoCon2008
 
Introduction to Django
Introduction to DjangoIntroduction to Django
Introduction to DjangoKnoldus Inc.
 

Similar to Customizing the Django Admin (20)

Extending CMS Made Simple
Extending CMS Made SimpleExtending CMS Made Simple
Extending CMS Made Simple
 
Introduction to django framework
Introduction to django frameworkIntroduction to django framework
Introduction to django framework
 
Some ways to DRY in Rails
Some ways to DRY in Rails Some ways to DRY in Rails
Some ways to DRY in Rails
 
There's a Module for That, MIMA Summit 2010
There's a Module for That, MIMA Summit 2010There's a Module for That, MIMA Summit 2010
There's a Module for That, MIMA Summit 2010
 
[JogjaJS] Single Page Application nganggo Angular.js
[JogjaJS] Single Page Application nganggo Angular.js [JogjaJS] Single Page Application nganggo Angular.js
[JogjaJS] Single Page Application nganggo Angular.js
 
Implementing a Symfony Based CMS in a Publishing Company
Implementing a Symfony Based CMS in a Publishing CompanyImplementing a Symfony Based CMS in a Publishing Company
Implementing a Symfony Based CMS in a Publishing Company
 
Adding custom ui controls to your application (1)
Adding custom ui controls to your application (1)Adding custom ui controls to your application (1)
Adding custom ui controls to your application (1)
 
Clean code and refactoring
Clean code and refactoringClean code and refactoring
Clean code and refactoring
 
Nicolas Embleton, Advanced Angular JS
Nicolas Embleton, Advanced Angular JSNicolas Embleton, Advanced Angular JS
Nicolas Embleton, Advanced Angular JS
 
Joomla Extensions Kung Fu
Joomla Extensions Kung FuJoomla Extensions Kung Fu
Joomla Extensions Kung Fu
 
Creating Extensible Plugins for WordPress
Creating Extensible Plugins for WordPressCreating Extensible Plugins for WordPress
Creating Extensible Plugins for WordPress
 
A Successful Magento Project From Design to Deployment
A Successful Magento Project From Design to DeploymentA Successful Magento Project From Design to Deployment
A Successful Magento Project From Design to Deployment
 
Django talk
Django talkDjango talk
Django talk
 
Developing Custom WordPress Themes for Clients
Developing Custom WordPress Themes for ClientsDeveloping Custom WordPress Themes for Clients
Developing Custom WordPress Themes for Clients
 
UX DURING MODULE INSTALLATION AND CONFIGURATION
UX DURING MODULE INSTALLATION AND CONFIGURATIONUX DURING MODULE INSTALLATION AND CONFIGURATION
UX DURING MODULE INSTALLATION AND CONFIGURATION
 
What’S New In Newforms Admin
What’S New In Newforms AdminWhat’S New In Newforms Admin
What’S New In Newforms Admin
 
Drupal Flyover, CMS Expo
Drupal Flyover, CMS ExpoDrupal Flyover, CMS Expo
Drupal Flyover, CMS Expo
 
An Introduction to Drupal
An Introduction to DrupalAn Introduction to Drupal
An Introduction to Drupal
 
Introduction to Angular Js
Introduction to Angular JsIntroduction to Angular Js
Introduction to Angular Js
 
Introduction to Django
Introduction to DjangoIntroduction to Django
Introduction to Django
 

Recently uploaded

08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking MenDelhi Call girls
 
Driving Behavioral Change for Information Management through Data-Driven Gree...
Driving Behavioral Change for Information Management through Data-Driven Gree...Driving Behavioral Change for Information Management through Data-Driven Gree...
Driving Behavioral Change for Information Management through Data-Driven Gree...Enterprise Knowledge
 
[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdfhans926745
 
IAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsIAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsEnterprise Knowledge
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024Rafal Los
 
08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking MenDelhi Call girls
 
Unblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesUnblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesSinan KOZAK
 
A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024Results
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Servicegiselly40
 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Drew Madelung
 
The Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxThe Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxMalak Abu Hammad
 
🐬 The future of MySQL is Postgres 🐘
🐬  The future of MySQL is Postgres   🐘🐬  The future of MySQL is Postgres   🐘
🐬 The future of MySQL is Postgres 🐘RTylerCroy
 
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure serviceWhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure servicePooja Nehwal
 
Automating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps ScriptAutomating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps Scriptwesley chun
 
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsMaria Levchenko
 
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...gurkirankumar98700
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slidevu2urc
 
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Miguel Araújo
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slidespraypatel2
 

Recently uploaded (20)

08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men
 
Driving Behavioral Change for Information Management through Data-Driven Gree...
Driving Behavioral Change for Information Management through Data-Driven Gree...Driving Behavioral Change for Information Management through Data-Driven Gree...
Driving Behavioral Change for Information Management through Data-Driven Gree...
 
[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf
 
IAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsIAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI Solutions
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024
 
08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men
 
Unblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesUnblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen Frames
 
A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Service
 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
 
The Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxThe Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptx
 
🐬 The future of MySQL is Postgres 🐘
🐬  The future of MySQL is Postgres   🐘🐬  The future of MySQL is Postgres   🐘
🐬 The future of MySQL is Postgres 🐘
 
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure serviceWhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
 
Automating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps ScriptAutomating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps Script
 
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed texts
 
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slide
 
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slides
 

Customizing the Django Admin

  • 1. Customizing the Django Admin When the Django Admin fails and what you can do to fix it Peter Baumgartner Founder, Lincoln Loop Michael Trythall User Experience Director, Lincoln Loop EuroDjangoCon – May 5, 2009
  • 2. About Lincoln Loop ● Django Corporate Sponsor ● Open source contributer ● Services: ● Development ● Prototyping ● Consulting ● Training http://lincolnloop.com
  • 3. Overview ● User Interface is important ● Default Admin UI is one-size-fits-all. User experience is not. ● What can we do to improve upon it? ● How do we implement those improvements?
  • 4. (Some) Problems We Face ● Clients want control over their web site ● Clients don't want to pay for a minor changes ● Clients often lack technical knowledge ● Clients may not have specifications (just ideas) ● Limited project and developer time ● Etc, etc...
  • 5. Problems with New, Custom Systems “ Easy is Hard ” - Peter Lewis, NY Times ● Time consuming – Research, Specs, Dev, Test ● Hard to tell right from wrong ● Good chance you might not nail it ● Reinventing the wheel in most cases
  • 6. So, What's the Solution?
  • 7. Leverage the Django Admin! Yay Ponies!
  • 8. The Good News ● Handful of reusable apps that alleviate some of the pain ● Admin is easy to extend, customize, etc. ● Djangonauts are thinking about these problems ● Lots of core functionality already exists in the admin
  • 10. Because... ● UI is the gateway to application logic ● Users remember bad experiences ● Good experiences = Happy Customers = Profit! ● Contributing helps Django mature ● Good UI reduces the need for documentation & support, but isn't a complete substitute!
  • 11. Problems with the Default Admin
  • 12. Not Informative or Assistive ● No dashboard, statistics, or recent (user) activity ● No actions (or models) highlighted or given priority ● No assistance/help for beginner users ● Impact from changes is not always clear ● Disconnect from external systems
  • 13. Dashboard & Primary Actions Example WordPress informs the user of the basics
  • 14. Doesn't Fit Into Customer Mental Models ● Relationships (e.x. hierarchy) not intuitive ● Apps are not organized by context ● Little (or no) navigation outside of breadcrumbs ● Doesn't mimic familiar process and workflow
  • 15. Grouping & Navigation Done Right
  • 17. Missing Features ● Missing common web tools like WYSIWYG, file management, etc ● Difficult to recover from actions (no undo) ● Better management for complicated models ● Project-wide search
  • 18. Undo & Help Example
  • 19. Poor Display for Complex Models
  • 22. Get to Know Your Customer ● Learn (or ask) about the industry, workflow, etc. ● Understand the needs of the different roles on the Customer's team ● Put yourself in their shoes (empathy) ● Learn the lingo, use it in your designs (laptop vs. notebook) ● Learn about previously used tools, pros and cons
  • 23. Brainstorming ● Welcome all ideas, decide on what's reasonable ● Embrace sketches to convey ideas and for clarification ● Get feedback early and often on ideas, even in development ● Don't be afraid to prototype with code ● Leverage proven UI design patterns
  • 28. Customization Options 1. ModelAdmin media 2. Custom templates 3. ModelAdmin/ModelForm hacking 4. Custom views
  • 29. Low Hanging Fruit For the Win http://www.flickr.com/photos/11263821@N05/2224626086
  • 31. ModelAdmin Media Code class ArticleAdmin(admin.ModelAdmin): class Media: css = { "all": ("my_styles.css",) } js = ("my_code.js",)
  • 32. ModelAdmin Media Examples ● JavaScript ● WYSIWYG Editor ● AJAX ● Fancy Inlines (drag & drop, dynamic add/delete) ‣ http://tinyurl.com/add-remove-inlines ‣ http://www.djangosnippets.org/snippets/1053/ ● Inject HTML ● CSS ● Colors ● Layout
  • 33. ModelAdmin Media Pros & Cons ● Pros: ● Easy for one-off projects ● Cons: ● Requires Javascript ● Only works for the Change Form ● Difficult to bundle as reusable app
  • 35. Custom Templates ● django.contrib.admin is a “reusable application” ● Key templates: ● admin/base.html ● admin/index.html ● admin/change_form.html ● admin/change_list.html
  • 36. Per Project/App/Model Templates Templates can be overridden: ● Across an entire project admin/change_form.html ● Across an application admin/<my_app>/change_form.html ● For an individual model admin/<my_app>/<my_model>/change_form.html
  • 37. Custom Template Example demo_app/templates/admin/demo_app/change_list.html {% extends "admin/change_list.html" %} {% block object-tools %} <h1 class="errornote"> Look Here! </h1> {{ block.super }} {% endblock %}
  • 38. Custom Template Tips ● Extend, don't override ● Use {{ block.super }} to extend blocks ● Extend a symlink of the admin templates in the event of recursion ● Extend the extrahead block in base.html for admin-wide media
  • 44. Custom Template Pros & Cons ● Pros ● Easy ● Touches every admin view ● No additional work to bundle with reusable apps ● Cons ● Mostly cosmetic (not functional) changes
  • 46. ModelAdmin/ModelForm Hacking ● New in Django 1.0 (newforms-admin) ● Old stuff (list_display, fields, ordering, etc.) ● New stuff (exclude, inlines, form, etc.) ● Really New stuff (list_editable, actions, etc.)
  • 47. Reregistering a ModelAdmin from django.contrib import admin from django.contrib.auth.admin import UserAdmin from demo_app.models import UserProfile class UserProfileInline(admin.TabularInline): model = UserProfile fk_name = 'user' max_num = 1 class CustomUserAdmin(UserAdmin): inlines = [UserProfileInline, ] admin.site.unregister(User) admin.site.register(User, CustomUserAdmin)
  • 48. Row-level Permissions class ArticleAdmin(admin.ModelAdmin): def save_model(self, request, obj, form, change): obj.user = request.user obj.save() def queryset(self, request): qs = self.model._default_manager.filter( user=request.user) return qs
  • 49. ModelForms ● Much of ModelAdmin's functionality is a wrapper around ModelForm ● If you can't do it in ModelAdmin, chances are ModelForm can help ● Pulled directly from django.forms and no different in functionality
  • 50. ModelFoms Example class AuthorForm(forms.ModelForm): exclude_states = ['AS', 'GU', 'MP', 'VI',] def __init__(self, *args, **kwargs): super(AuthorForm, self).__init__(*args, **kwargs) w = self.fields['state'].widget choices = [] for key, value in w.choices: if key not in self.exclude_states: choices.append((key, value)) w.choices = choices class AuthorAdmin(admin.ModelAdmin): form = AuthorForm
  • 51. Caution: Here be Dragons http://www.flickr.com/photos/sharynmorrow/3019436/
  • 52. ModelAdmin/ModelForm Tips ● The further you dig, the less documentation you'll find ● Don't be afraid to study the source: ● django.contrib.admin.sites.AdminSite ● django.contrib.admin.options.ModelAdmin ● django.forms.models.ModelForm ● django.contrib.admin.options.InlineModelAdmin ● django.forms.formsets ● Use a debugger for sanity (ipdb.set_trace())
  • 53. ModelAdmin/ModelForm Pros & Cons ● Pros ● Flexible ● Powerful ● No additional work to bundle with reusable apps ● Cons ● Gets complex quickly ● May require getting familiar with undocumented Django internals
  • 55. When in Doubt, Punt http://www.flickr.com/photos/bobtravis/485216368/
  • 56. Custom Views ● The admin just wasn't built to do some things ● Other things simply aren't worth the trouble ● Build your own view and plug it into the admin
  • 57. Custom View URL class PostAdmin(admin.ModelAdmin): def my_view(self, request): return admin_my_view(request, self) def get_urls(self): urls = super(PostAdmin, self).get_urls() my_urls = patterns('', (r'^my_view/$', self.my_view) ) return my_urls + urls
  • 58. Custom View @permission_required('blog.add_post') def admin_my_view(request, model_admin): opts = model_admin.model._meta admin_site = model_admin.admin_site has_perm = request.user.has_perm(opts.app_label + '.' + opts.get_change_permission()) context = {'admin_site': admin_site.name, 'title': "My Custom View", 'opts': opts, 'root_path': '/%s' % admin_site.root_path, 'app_label': opts.app_label, 'has_change_permission': has_perm} template = 'admin/demo_app/admin_my_view.html' return render_to_response(template, context, context_instance=RequestContext(request))
  • 59. Custom View Template {% extends "admin/base_site.html" %} {% load i18n %} {% block breadcrumbs %} <div class="breadcrumbs"> <a href="../../../">{% trans "Home" %}</a> &rsaquo; <a href="../../">{{ app_label|capfirst| escape }}</a> &rsaquo; {% if has_change_permission %}<a href="../">{{ opts.verbose_name_plural| capfirst }}</a>{% else %}{{ opts.verbose_name_plural| capfirst }}{% endif %} &rsaquo; My Custom View </div> {% endblock %} {% block content %} <!-- do stuff here --> {% endblock %}
  • 61. Custom View Pros & Cons ● Pros ● More flexible ● More powerful ● No additional work to bundle with reusable apps ● Cons ● Can be tricky to integrate into workflow ● You're on your own to validate forms, build templates, etc.
  • 62. Review ● UI is important. Think about your end-user ● Think about your users, not your database ● Newforms-admin gives you hooks for lots of easy wins
  • 63. Questions Peter Baumgartner pete@lincolnloop.com Michael Trythall michael@lincolnloop.com http://lincolnloop.com