Skip to main content

Django mppt widget that uses Fancytree to search and display tree data

Project description

Django Mptt Autocomplete Widget

django-mptt-autocomplete provides a widget using the fancytree js library to
render a forms.ChoiceField as a tree with selectable and
collapsable nodes with an autocomplete to search in existing tree.

See included project 'treewidget' as an example. Widget is used in
ModelChoiceField and allows user to select single category.


django, django-mptt, jquery, jquery-ui



from mptt_autocomplete.widgets import FancyTreeWidget

categories = Category.objects.order_by('tree_id', 'lft')

class CategoryForm(forms.Form):
categories = forms.ModelChoiceField(

In this example Category is a model registered with django-mptt.

Widget accepts **queryset** option, which expects pre-ordered queryset by
"tree_id" and "lft".

If you want to adjust tree data creation, you can define 'get_doc' method on
your model. Example:


def get_doc(self, values):
doc = {"title": name, "key":}
if str( in values:
doc['select'] = True
doc['expand'] = True
return doc

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-mptt-autocomplete-0.1.0.tar.gz (320.0 kB view hashes)

Uploaded source

Supported by

AWS AWS Cloud computing Datadog Datadog Monitoring Facebook / Instagram Facebook / Instagram PSF Sponsor Fastly Fastly CDN Google Google Object Storage and Download Analytics Huawei Huawei PSF Sponsor Microsoft Microsoft PSF Sponsor NVIDIA NVIDIA PSF Sponsor Pingdom Pingdom Monitoring Salesforce Salesforce PSF Sponsor Sentry Sentry Error logging StatusPage StatusPage Status page