Django form fields using the Select2 jQuery plugin
Project description
django-select2-forms is a project that makes available Django form fields that use the Select2 javascript plugin. It was created by developers at The Atlantic.
Installation
The recommended way to install is with pip:
pip install django-select2-forms
or, to install with pip from source:
pip install -e git+git://github.com/theatlantic/django-select2-forms.git#egg=django-select2-forms
If the source is already checked out, use setuptools:
python setup.py develop
Configuration
django-select2-forms serves static assets using django.contrib.staticfiles, and so requires that "select2" be added to your settings’ INSTALLED_APPS:
INSTALLED_APPS = ( # ... 'select2', )
(django-staticfiles should also work for Django <= 1.2).
To use django-select2-forms’ ajax support, 'select2.urls' must be included in your urls.py urlpatterns:
urlpatterns = patterns('', # ... url(r'^select2/', include('select2.urls')), )
Usage
The simplest way to use django-select2-forms is to use select2.fields.ForeignKey and select2.fields.ManyToManyField in place of django.db.models.ForeignKey and django.db.models.ManyToManyField, respectively. These fields extend their django equivalents and take the same arguments, along with extra optional keyword arguments.
select2.fields.ForeignKey examples
In the following two examples, an “entry” is associated with only one author. The example below does not use ajax, but instead performs autocomplete filtering on the client-side using the <option> elements (the labels of which are drawn from Author.__unicode__()) in an html <select>.
class Author(models.Model): name = models.CharField(max_length=100) def __unicode__(self): return self.name class Entry(models.Model): author = select2.fields.ForeignKey(Author, overlay="Choose an author...")
This more advanced example autocompletes via ajax using the Author.name field and limits the autocomplete search to Author.objects.filter(active=True)
class Author(models.Model): name = models.CharField(max_length=100) active = models.BooleanField() class Entry(models.Model): author = select2.fields.ForeignKey(Author, limit_choices_to=models.Q(active=True), ajax=True, search_field='name', overlay="Choose an author...", js_options={ 'quiet_millis': 200, })
select2.fields.ManyToManyField examples
In the following basic example, entries can have more than one author. This example does not do author name lookup via ajax, but populates <option> elements in a <select> with Author.__unicode__() for labels.
class Author(models.Model): name = models.CharField(max_length=100) def __unicode__(self): return self.name class Entry(models.Model): authors = select2.fields.ManyToManyField(Author)
The following “kitchen sink” example allows authors to be ordered, and uses ajax to autocomplete on two variants of an author’s name.
from django.db import models from django.db.models import Q import select2.fields import select2.models class Author(models.Model): name = models.CharField(max_length=100) alt_name = models.CharField(max_length=100, blank=True, null=True) class EntryAuthors(select2.models.SortableThroughModel): """ A custom m2m through table, with a `position` field for sorting. This allows us to store and retrieve an ordered list of authors for an entry. """ entry = models.ForeignKey('Entry') author = models.ForeignKey(Author) position = models.PositiveSmallIntegerField() class Entry(models.Model): categories = select2.fields.ManyToManyField(Author, through='EntryAuthors', ajax=True, search_field=lambda q: Q(name__icontains=q) | Q(alt_name__icontains=q), sort_field='position', js_options={'quiet_millis': 200})
form field example
If you don’t need to use the ajax features of django-select2-forms it is possible to use select2 on django forms without modifying your models. The select2 formfields exist in the select2.fields module and have the same class names as their standard django counterparts (ChoiceField, MultipleChoiceField, ModelChoiceField, ModelMultipleChoiceField). Here is the first ForeignKey example above, done with django formfields.
class AuthorManager(models.Manager): def as_choices(self): for author in self.all(): yield (author.pk, unicode(author)) class Author(models.Model): name = models.CharField(max_length=100) objects = AuthorManager() def __unicode__(self): return self.name class Entry(models.Model): author = models.ForeignKey(Author) class EntryForm(forms.ModelForm): author = select2.fields.ChoiceField( choices=Author.objects.as_choices(), overlay="Choose an author...") class Meta: model = Entry
API Documentation
License
The django code is licensed under the Simplified BSD License and is copyright The Atlantic Media Company. View the LICENSE file under the root directory for complete license and copyright information.
The Select2 javascript library included is licensed under the Apache Software Foundation License Version 2.0. View the file select2/static/select2/select2/LICENSE for complete license and copyright information about the Select2 javascript library.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file django-select2-forms-1.1.11.tar.gz
.
File metadata
- Download URL: django-select2-forms-1.1.11.tar.gz
- Upload date:
- Size: 194.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cc340f78fe84e805fb6bd3e5d5369a1259af11a97c9e391e846a43bef2600540 |
|
MD5 | e1d5ab948ff2ef863606306a16d85472 |
|
BLAKE2b-256 | d8f48f5fbead361822fd1670ecebcf8e67859b05a618987dff9e91b84392b72a |