Skip to main content

django admin row actions

Project description

Django Admin Row Actions
========================

Allows you to easily define a drop-down 'actions' menu that is appended as the final column in your model's changelist and perform actions on that row.

Menu items can call urls or methods, can be disabled, have tooltips, etc.

I've extracted this from code written for http://hireablehq.com/. The admin there has Bootstrap available but I've modified this version to use a standalone jQuery dropdown.


Installation
============

1. Install from PyPI:

```bash
pip install django-admin-row-actions
```

or install using pip and git:

```bash
pip install git+https://github.com/DjangoAdminHackers/django-admin-row-actions.git
```

2. Add to INSTALLED_APPS:

```python
INSTALLED_APPS = [
...
'django_admin_row_actions',
...
]
```

3. Add the mixin to your ModelAdmin:

```python
from django_admin_row_actions import AdminRowActionsMixin
...

class ExampleAdmin(AdminRowActionsMixin, admin.ModelAdmin):
...
```

4. Define a `get_row_actions` method on your ModelAdmin

```python
def get_row_actions(self, obj):
row_actions = [
{
'label': 'Edit',
'url': obj.get_edit_url(),
'enabled': obj.status is not 'cancelled',
}, {
'label': 'Download PDF',
'url': obj.get_pdf_url(),
}, {
'label': 'Convert',
'url': reverse('convert_stuff', args=[obj.id]),
'tooltip': 'Convert stuff',
}, {
'label': 'Cancel',
'action': 'mark_cancelled',
},
]
row_actions += super(ExampleAdmin, self).get_row_actions(obj)
return row_actions
```

The first three menu items are simple links to a url you provide by whatever means you choose.

The final one defines 'action' instead of 'url'. This should be the name of a callable on your `ModelAdmin` or `Model` class (similar to [ModelAdmin.list_display](https://docs.djangoproject.com/en/1.8/ref/contrib/admin/#django.contrib.admin.ModelAdmin.list_display)).

You can add mouseover tooltips to each individual actions with the 'tooltip' dictionary key, and enable/disable individual actions for each individual object with the 'enabled'.


Credits
=======

Inspired (and code based on): [django-object-actions](https://github.com/crccheck/django-object-actions)

Includes parts of [jquery-dropdown](http://labs.abeautifulsite.net/jquery-dropdown/); credits go to Cory LaViska.

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-admin-row-actions-0.0.2.tar.gz (9.5 kB view details)

Uploaded Source

File details

Details for the file django-admin-row-actions-0.0.2.tar.gz.

File metadata

File hashes

Hashes for django-admin-row-actions-0.0.2.tar.gz
Algorithm Hash digest
SHA256 43fbfbda84dcd7f94b3ba4d8434820ecc029c4ad944592bc5bbbb350bf3b3c8a
MD5 ca2ecc287c9942e64b63ba14d2bdb931
BLAKE2b-256 7ce583de31570247011139a891d488b334ece8b06323e195c1f5228116fceb2e

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page