Skip to main content

Django application that allows users to clone a model in Admin

Project description

# django-modelclone

Allows users to duplicate a model in admin.

## Installation

  1. Add ‘modelclone’ to INSTALLED_APPS

  2. In your admin.py files extend from modelclone.ClonableModelAdmin instead of Django’s ModelAdmin

The models that have admin configuration extending modelclone.ClonableModelAdmin will have a new link on the Change page to duplicate that object

![Screenshot Duplicate link](images/duplicate-link.png)

This links redirects to a page similar to an Add page but with all the fields already filled with the values from the original object.

Note that you still need to save to get a new object. And make sure to edit fields that must be unique otherwise you will get a validation error.

## But Django already has a ‘save as’

Yes, I know. Django Admin has a [save_as](https://docs.djangoproject.com/en/dev/ref/contrib/admin/#django.contrib.admin.ModelAdmin.save_as) feature that adds a new button to your Change page to save a new instance of that object.

I don’t like the way this feature works because you will save an identical copy of the original object (if you don’t get validation errors) as soon as you click that link, and if you forget to make the small changes that you wanted in the new object you will end up with a duplicate of the existing object.

On the other hand, django-modelclone offers an intermediate view, that basically pre-fills the form for you. So you can modify and then save a new instance. Or just go away without side effects.

## Requirements

Tested with Python 2.6 and 2.7. Django 1.4.

## Hacking

Fork the [repository on github](http://github.com/realgeeks/django-modelclone), make your changes (don’t forget the tests) and send a pull request.

Inside your fork directory run:

$ pip install -e . $ pip install -r requirements-dev.txt

Now you can run the tests:

$ ./manager runtests

To use the app in the sample project use:

$ ./manager runserver

The app is available on [http://localhost:8000/admin/](http://localhost:8000/admin/), username and password “admin”.

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-modelclone-0.2.0.tar.gz (4.5 kB view hashes)

Uploaded Source

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