Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/incuna/django-orderable
Add manual sort order to Django objects via an abstract base class and admin classes
https://github.com/incuna/django-orderable
django python sort-order
Last synced: about 14 hours ago
JSON representation
Add manual sort order to Django objects via an abstract base class and admin classes
- Host: GitHub
- URL: https://github.com/incuna/django-orderable
- Owner: incuna
- License: bsd-2-clause
- Created: 2012-05-01T13:38:15.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2023-06-29T19:53:38.000Z (over 1 year ago)
- Last Synced: 2024-11-12T19:24:25.757Z (4 days ago)
- Topics: django, python, sort-order
- Language: Python
- Homepage:
- Size: 154 KB
- Stars: 41
- Watchers: 26
- Forks: 19
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.rst
- License: LICENSE
Awesome Lists containing this project
README
# Django Orderable
Add manual sort order to Django objects via an abstract base class and admin classes. Project includes:
* Abstract base Model
* Admin class
* Inline admin class
* Admin templates## Demo
![django-orderable demo](https://cloud.githubusercontent.com/assets/30606/6326221/667992e0-bb47-11e4-923e-29334573ff5c.gif)
## Installation
Grab from the PyPI:
pip install django-orderable
Add to your INSTALLED_APPS:
...
'orderable',
...Subclass the Orderable class:
from orderable.models import Orderable
class Book(Orderable):
...Subclass the appropriate Orderable admin classes:
from orderable.admin import OrderableAdmin, OrderableTabularInline
class SomeInlineClass(OrderableTabularInline):
...class SomeAdminClass(OrderableAdmin):
list_display = ('__unicode__', 'sort_order_display')
...jQuery and jQuery UI are used in the Admin for the draggable UI. You may override the versions with your own (rather than using Google's CDN):
class SomeAdminClass(OrderableAdmin):
class Media:
extend = False
js = (
'path/to/jquery.js',
'path/to/jquery.ui.js',
)## Notes
### `class Meta`
If your subclass of `Orderable` defines [`class Meta`](https://docs.djangoproject.com/en/2.0/ref/models/options/) then make sure it subclasses `Orderable.Meta` one so the model is sorted by `sort_order`. ie:
class MyOrderable(Orderable):
class Meta(Orderable.Meta):
...### Custom Managers
Similarly, if your model has a custom manager, subclass `orderable.managers.OrderableManager` instead of `django.db.models.Manager`.
### Transactions
Saving orderable models invokes a fair number of database queries, and in order
to avoid race conditions should be run in a transaction.### Adding Orderable to Existing Models
You will need to populate the required `sort_order` field. Typically this is
done by adding the field in one migration with a default of `0`, then creating
a data migration to set the value to that of its primary key:for obj in orm['appname.Model'].objects.all():
obj.sort_order = obj.pk
obj.save()### Multiple Models using Orderable
When multiple models inherit from Orderable the `next()` and `previous()`
methods will look for the next/previous model with a sort order. However you'll
likely want to have the various sort orders determined by a foreign key or some
other predicate. The easiest way (currently) is to override the method in
question.