Edit

Clone Operation PRO

--

About

This CRUD operation allows your admins to duplicate one or more entries from the database.

IMPORTANT: The clone operation does NOT duplicate related entries. So n-n relationships will be unaffected. However, this also means that n-n relationships are ignored. So when you clone an entry, the new entry:

  • will NOT have the same 1-1 relationships
  • will have the same 1-n relationships
  • will NOT have the same n-1 relationships
  • will NOT have the same n-n relationships

This might be somewhat counterintuitive for end users - though it should make perfect sense for us developers. This is why the Clone operation is NOT enabled by default.

Requirements

This is a PRO operation. It requires that you have purchased access to backpack/pro.

Clone a Single Item

How it Works

Using AJAX, a POST request is performed towards /entity-name/{id}/clone, which points to the clone() method in your EntityCrudController.

How to Use

To enable it, you need to use \Backpack\CRUD\app\Http\Controllers\Operations\CloneOperation; on your EntityCrudController. For example:

<?php

namespace App\Http\Controllers\Admin;

use Backpack\CRUD\app\Http\Controllers\CrudController;

class ProductCrudController extends CrudController
{
    use \Backpack\CRUD\app\Http\Controllers\Operations\CloneOperation;

    public function setup()
    {
        CRUD::setModel(\App\Models\Product::class);
        CRUD::setRoute(backpack_url('product'));
        CRUD::setEntityNameStrings('product', 'products');
    }
}

This will make the Clone button appear in the table view, and will allow access to the controller method if manually accessed.

How to Overwrite

In case you need to change how this operation works, overwrite the clone() trait method in your EntityCrudController; make sure you give the method in the trait a different name, so that there are no conflicts:

use \Backpack\CRUD\app\Http\Controllers\Operations\CloneOperation { clone as traitClone; }

public function clone($id)
{
    CRUD::hasAccessOrFail('clone');
    CRUD::setOperation('clone');

    // whatever you want

    // if you still want to call the old clone method
    $this->traitClone($id);
}

You can also overwrite the clone button by creating a file with the same name inside your resources/views/vendor/backpack/crud/buttons/. You can easily publish the clone button there to make changes using:

php artisan backpack:button --from=clone

Clone Multiple Items (Bulk Clone)

In addition to the button for each entry, you can show checkboxes next to each element, and allow your admin to clone multiple entries at once.

How it Works

Using AJAX, a POST request is performed towards /entity-name/bulk-clone, which points to the bulkClone() method in your EntityCrudController.

NOTES:

  • The bulk checkbox is added inside the first column defined in the table. For that reason the first column should be visible on table to display the bulk actions checkbox next to it.
  • Bulk Actions also disable all click events for the first column, so make sure the first column doesn't contain an anchor tag (<a>), as it won't work.

How to Use

To enable it, you need to use \Backpack\CRUD\app\Http\Controllers\Operations\BulkCloneOperation; on your EntityCrudController.

How to Overwrite

In case you need to change how this operation works, just create a bulkClone() method in your EntityCrudController:

use \Backpack\CRUD\app\Http\Controllers\Operations\BulkCloneOperation { bulkClone as traitBulkClone; }

public function bulkClone($id)
{
    // your custom code here
    //
    // then you can call the old bulk clone if you want
    $this->traitBulkClone($id);
}

You can also overwrite the bulk clone button by creating a file with the same name inside your resources/views/vendor/backpack/crud/buttons/. You can easily publish the clone button there to make changes using:

php artisan backpack:button --from=bulk_clone

Exempt attributes when cloning

If you have attributes that should not be cloned (eg. a SKU with an unique constraint), you can overwrite the replicate method on your model:

    public function replicate(array $except = null) {

        return parent::replicate(['sku']);
    }

Like our open-core?

Then you'll love our premium add-ons - productivity tools and tons of new features.