Download the PHP package restruct/silverstripe-copybutton without Composer
On this page you can find all versions of the php package restruct/silverstripe-copybutton. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download restruct/silverstripe-copybutton
More information about restruct/silverstripe-copybutton
Files in restruct/silverstripe-copybutton
Package silverstripe-copybutton
Short Description Adds copy/duplicate button to the GridField.
License BSD-3-Clause
Informations about the package silverstripe-copybutton
silverstripe-copybutton
Adds a copy/duplicate button to GridFields
Original author
Elvinas Liutkevičius <elvinas (at) unisolutions (dot) eu>
(Forked from dhensby's SS4-updated fork for quick maintenance & updates/tags)
Documentation
Simply install the module using the standard method.
To add the button to the GridField you need to extend ModelAdmin and override getEditForm() method like this:
function getEditForm($id = null, $fields = null) {
$form = parent::getEditForm();
$form
->Fields()
->fieldByName($this->sanitiseClassName($this->modelClass))
->getConfig()
->addComponent(new GridFieldCopyButton(), 'GridFieldEditButton') // or just ->addComponent(new GridFieldCopyButton())
;
return $form;
}
This action will make exact copy of the record (with all relations and etc.). Note: you have to set configs for cascading duplications in your DataObjects to duplicate relations See: https://docs.silverstripe.org/en/4/developer_guides/model/relations/#cascading-duplications
Sometimes you will need to do some actions just after copy operation (i.e. you'll need to remove some relations). It is easily achieved by extending DataObject and writing all the actions in the onAfterDuplicate() method.
class SomeObjectExtension extends DataExtension {
public function onAfterDuplicate() {
DB::query("delete from Member_SomeObject where SomeObjectID = ".$this->owner->ID);
}
}