Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Adding a jQuery script to the Django admin interface

I'm gonna slightly simplify the situation. Let's say I've got a model called Lab.

from django.db import models  class Lab(models.Model):     acronym = models.CharField(max_length=20)     query = models.TextField() 

The field query is nearly always the same as the field acronym. Thus, I'd like the query field to be automatically filled in after entering text in the acronym field in the Django admin interface. This task must be performed by a jQuery script.

So if I take an example: you want to add a new lab to the database through the Django admin interface. You click the add button and you land on the empty form with the two fields. You manually fill in the acronym field with a value such as ABCD and then the query field should antomatically be completed with the same value, that means ABCD.

How should I proceed?

like image 377
user2282405 Avatar asked Apr 15 '13 12:04

user2282405


People also ask

Can I use jQuery with Django?

Inside your settings.py file make sure that django. contrib. staticfiles is under INSTALLED_APPS (it is there by default). And now you can use jQuery throughout your site!

What is the Django admin interface?

Django provides a default admin interface which can be used to perform create, read, update and delete operations on the model directly. It reads set of data that explain and gives information about data from the model, to provide an instant interface where the user can adjust contents of the application .

What we can do in admin portal in Django?

Overview. The Django admin application can use your models to automatically build a site area that you can use to create, view, update, and delete records. This can save you a lot of time during development, making it very easy to test your models and get a feel for whether you have the right data.


1 Answers

To add media to the admin you can simply add it to the meta class Media of your admin class, e.g.:

admin.py

class FooAdmin(admin.ModelAdmin):     # regular stuff     class Media:         js = (             '//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js', # jquery             'js/myscript.js',       # project static folder             'app/js/myscript.js',   # app static folder         )  admin.site.register(Foo, FooAdmin) 

Mind the trailing comma if you only have one file included, as it has to be a tuple. You can also opt in css this way.

The admin already has (an older version) of jquery included. To shortcut it for usage add this to the top of the 'myscript' file:

if (!$) {     $ = django.jQuery; } 

To solve your problem, I would extend the admin. You can add a js event to any DOM node to trigger an ajax call in your myscript file to the correct admin view for handling.

like image 125
Hedde van der Heide Avatar answered Oct 09 '22 16:10

Hedde van der Heide