Django-Select2 ============== This is a [Django](https://www.djangoproject.com/) integration of [Select2](http://ivaynberg.github.com/select2/). The app includes Select2 driven Django Widgets and Form Fields. Installation ============ 1. Install `django_select2` pip install django_select2 2. Add `django_select2` to your `INSTALLED_APPS` in your project settings. 3. When deploying on production server, run :- python manage.py collectstatic Documentation ============= Documentation available at http://django-select2.readthedocs.org/. More details ============ More details can be found on my blog at - http://blog.applegrew.com/2012/08/django-select2/. External Dependencies ===================== * Django - This is obvious. * jQuery - This is not included in the package since it is expected that in most scenarios this would already be available. * Memcached (python-memcached) - If you plan on running multiple python processes with `GENERATE_RANDOM_SELECT2_ID` enabled, then you need to turn on `ENABLE_SELECT2_MULTI_PROCESS_SUPPORT`. In that mode it is highly recommended that you use Memcached, to minimize DB hits. Example Application =================== Please see `testapp` application. This application is used to manually test the functionalities of this package. This also serves as a good example. You need only Django 1.4 or above to run that. It might run on older versions but that is not tested. Special Thanks ============== * Samuel Goldszmidt (@ouhouhsami) for reporting many fundamental issues with the code, because of which versions 2.0 and 2.0.1 were released. Changelog Summary ================= ### v4.0.0 * Main version number bumped to bring your attention to the fact that the default Id generation scheme has now changed. Now Django Select2 will use hashed paths of fields to generate their Ids. The old scheme of generating random Ids are still there. You can enable that by setting `GENERATE_RANDOM_SELECT2_ID` to `True`. ### v3.3.1 * Addressed issue[#30](https://github.com/applegrew/django-select2/issues/30). * Merged pull request[#31](https://github.com/applegrew/django-select2/issues/31). * Added `light` parameter to `import_django_select2_js`, `import_django_select2_css` and `import_django_select2_js_css` template tags. Please see doc's "Getting Started", for more details. ### v3.3.0 * Updated Select2 to version 3.3.1. * Added multi-process support. ([Issue#28](https://github.com/applegrew/django-select2/issues/28)). * Addressed issue[#26](https://github.com/applegrew/django-select2/issues/26). * Addressed issue[#24](https://github.com/applegrew/django-select2/issues/24). * Addressed issue[#23](https://github.com/applegrew/django-select2/issues/23). * Addressed some typos. ### v3.2.0 * Fixed issue[#20](https://github.com/applegrew/django-select2/issues/20). Infact while fixing that I realised that heavy components do not need the help of cookies, infact due to a logic error in previous code the cookies were not being used anyway. Now Django Select2 does not use cookies etc. * Few more bugs fixed in `heav_data.js`. * Now production code will use minimized versions of js and css files. * Codes added in `setup.py` to automate the task of minimizing js and css files, using a web service. ### v3.1.5 * Merged pull request (issue[#17](https://github.com/applegrew/django-select2/issues/17)). Which allows the user to pass some extra data to Select2 clients-side component. * Updated License. The previous one was inadequently worded. Now this project use Apache 2.0 license. ### v3.1.4 * Manually merged changes from pull request (issue[#16](https://github.com/applegrew/django-select2/issues/16)). * Django Select2 widgets now allow passing of any Select2 Js options. Previously it used to allow only white-listed options. Now it will block only black-listed options. For example, Light Select2 widgets won't allow you to set `multiple` option, since it is an error to set them when Select2 Js is bound to `