2012-01-09 11:37:13 +01:00
|
|
|
<?php
|
2016-06-15 16:03:16 +12:00
|
|
|
|
|
|
|
use SilverStripe\ORM\ValidationException;
|
2012-01-09 11:37:13 +01:00
|
|
|
/**
|
2014-08-15 18:53:05 +12:00
|
|
|
* This class is a {@link GridField} component that adds a delete action for
|
2013-05-20 22:18:07 +12:00
|
|
|
* objects.
|
|
|
|
*
|
2014-08-15 18:53:05 +12:00
|
|
|
* This component also supports unlinking a relation instead of deleting the
|
2013-05-20 22:18:07 +12:00
|
|
|
* object.
|
2012-03-23 10:50:17 +13:00
|
|
|
*
|
2012-03-23 10:59:17 +13:00
|
|
|
* Use the {@link $removeRelation} property set in the constructor.
|
2012-03-23 10:50:17 +13:00
|
|
|
*
|
|
|
|
* <code>
|
|
|
|
* $action = new GridFieldDeleteAction(); // delete objects permanently
|
2013-05-20 22:18:07 +12:00
|
|
|
*
|
|
|
|
* // removes the relation to object instead of deleting
|
2014-08-15 18:53:05 +12:00
|
|
|
* $action = new GridFieldDeleteAction(true);
|
2012-03-23 10:50:17 +13:00
|
|
|
* </code>
|
|
|
|
*
|
2013-11-29 17:12:47 +13:00
|
|
|
* @package forms
|
2013-05-20 22:18:07 +12:00
|
|
|
* @subpackage fields-gridfield
|
2012-01-09 11:37:13 +01:00
|
|
|
*/
|
2012-03-06 12:57:16 +01:00
|
|
|
class GridFieldDeleteAction implements GridField_ColumnProvider, GridField_ActionProvider {
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-03-09 13:55:49 +13:00
|
|
|
/**
|
2014-08-15 18:53:05 +12:00
|
|
|
* If this is set to true, this {@link GridField_ActionProvider} will
|
|
|
|
* remove the object from the list, instead of deleting.
|
2013-05-20 22:18:07 +12:00
|
|
|
*
|
2014-08-15 18:53:05 +12:00
|
|
|
* In the case of a has one, has many or many many list it will uncouple
|
2013-05-20 22:18:07 +12:00
|
|
|
* the item from the list.
|
2012-03-09 13:55:49 +13:00
|
|
|
*
|
|
|
|
* @var boolean
|
|
|
|
*/
|
|
|
|
protected $removeRelation = false;
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-03-09 13:55:49 +13:00
|
|
|
/**
|
|
|
|
*
|
2012-03-23 10:51:23 +13:00
|
|
|
* @param boolean $removeRelation - true if removing the item from the list, but not deleting it
|
2012-03-09 13:55:49 +13:00
|
|
|
*/
|
2012-03-23 10:51:23 +13:00
|
|
|
public function __construct($removeRelation = false) {
|
|
|
|
$this->removeRelation = $removeRelation;
|
2012-03-09 13:55:49 +13:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-01-09 11:37:13 +01:00
|
|
|
/**
|
|
|
|
* Add a column 'Delete'
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2013-06-21 10:32:08 +12:00
|
|
|
* @param GridField $gridField
|
2014-08-15 18:53:05 +12:00
|
|
|
* @param array $columns
|
2012-01-09 11:37:13 +01:00
|
|
|
*/
|
|
|
|
public function augmentColumns($gridField, &$columns) {
|
2012-03-23 10:51:23 +13:00
|
|
|
if(!in_array('Actions', $columns)) {
|
2012-02-08 11:21:34 +13:00
|
|
|
$columns[] = 'Actions';
|
2012-03-23 10:51:23 +13:00
|
|
|
}
|
2012-01-09 11:37:13 +01:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-01-09 11:37:13 +01:00
|
|
|
/**
|
2012-11-15 14:19:57 +13:00
|
|
|
* Return any special attributes that will be used for FormField::create_tag()
|
2012-01-09 11:37:13 +01:00
|
|
|
*
|
|
|
|
* @param GridField $gridField
|
|
|
|
* @param DataObject $record
|
|
|
|
* @param string $columnName
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getColumnAttributes($gridField, $record, $columnName) {
|
2016-07-01 13:37:29 +12:00
|
|
|
return array('class' => 'grid-field__col-compact');
|
2012-01-09 11:37:13 +01:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-01-09 11:37:13 +01:00
|
|
|
/**
|
2014-08-15 18:53:05 +12:00
|
|
|
* Add the title
|
|
|
|
*
|
2012-01-09 11:37:13 +01:00
|
|
|
* @param GridField $gridField
|
|
|
|
* @param string $columnName
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getColumnMetadata($gridField, $columnName) {
|
2012-02-08 11:21:34 +13:00
|
|
|
if($columnName == 'Actions') {
|
2012-01-09 17:16:07 +01:00
|
|
|
return array('title' => '');
|
2012-01-09 11:37:13 +01:00
|
|
|
}
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-01-09 11:37:13 +01:00
|
|
|
/**
|
|
|
|
* Which columns are handled by this component
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2013-06-21 10:32:08 +12:00
|
|
|
* @param GridField $gridField
|
|
|
|
* @return array
|
2012-01-09 11:37:13 +01:00
|
|
|
*/
|
|
|
|
public function getColumnsHandled($gridField) {
|
2012-02-08 11:21:34 +13:00
|
|
|
return array('Actions');
|
2012-01-09 11:37:13 +01:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-01-09 11:37:13 +01:00
|
|
|
/**
|
|
|
|
* Which GridField actions are this component handling
|
|
|
|
*
|
|
|
|
* @param GridField $gridField
|
2014-08-15 18:53:05 +12:00
|
|
|
* @return array
|
2012-01-09 11:37:13 +01:00
|
|
|
*/
|
|
|
|
public function getActions($gridField) {
|
2012-03-09 13:55:49 +13:00
|
|
|
return array('deleterecord', 'unlinkrelation');
|
2012-01-09 11:37:13 +01:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-01-09 11:37:13 +01:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param GridField $gridField
|
|
|
|
* @param DataObject $record
|
|
|
|
* @param string $columnName
|
2014-08-15 18:53:05 +12:00
|
|
|
* @return string - the HTML for the column
|
2012-01-09 11:37:13 +01:00
|
|
|
*/
|
|
|
|
public function getColumnContent($gridField, $record, $columnName) {
|
2012-03-09 13:55:49 +13:00
|
|
|
if($this->removeRelation) {
|
2012-12-17 00:46:51 +01:00
|
|
|
if(!$record->canEdit()) return;
|
|
|
|
|
2015-06-19 17:43:05 +12:00
|
|
|
$field = GridField_FormAction::create($gridField, 'UnlinkRelation'.$record->ID, false,
|
2016-07-01 13:37:29 +12:00
|
|
|
"unlinkrelation", array('RecordID' => $record->ID))
|
|
|
|
->addExtraClass('btn btn--no-text btn--icon-md font-icon-link-broken grid-field__icon-action gridfield-button-unlink')
|
|
|
|
->setAttribute('title', _t('GridAction.UnlinkRelation', "Unlink"));
|
|
|
|
|
2012-03-09 13:55:49 +13:00
|
|
|
} else {
|
2012-12-17 00:46:51 +01:00
|
|
|
if(!$record->canDelete()) return;
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2015-06-19 17:43:05 +12:00
|
|
|
$field = GridField_FormAction::create($gridField, 'DeleteRecord'.$record->ID, false, "deleterecord",
|
2012-09-27 09:34:00 +12:00
|
|
|
array('RecordID' => $record->ID))
|
2016-07-01 13:37:29 +12:00
|
|
|
->addExtraClass('gridfield-button-delete btn--icon-md font-icon-trash-bin btn--no-text grid-field__icon-action')
|
2012-03-09 13:55:49 +13:00
|
|
|
->setAttribute('title', _t('GridAction.Delete', "Delete"))
|
2012-05-28 12:05:41 +12:00
|
|
|
->setDescription(_t('GridAction.DELETE_DESCRIPTION','Delete'));
|
2012-03-08 13:58:53 +13:00
|
|
|
}
|
2012-03-06 16:58:13 +01:00
|
|
|
return $field->Field();
|
2012-01-09 11:37:13 +01:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-01-09 11:37:13 +01:00
|
|
|
/**
|
|
|
|
* Handle the actions and apply any changes to the GridField
|
|
|
|
*
|
|
|
|
* @param GridField $gridField
|
|
|
|
* @param string $actionName
|
|
|
|
* @param mixed $arguments
|
|
|
|
* @param array $data - form data
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function handleAction(GridField $gridField, $actionName, $arguments, $data) {
|
2012-03-09 13:55:49 +13:00
|
|
|
if($actionName == 'deleterecord' || $actionName == 'unlinkrelation') {
|
|
|
|
$item = $gridField->getList()->byID($arguments['RecordID']);
|
|
|
|
if(!$item) {
|
|
|
|
return;
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-08-21 23:31:34 +01:00
|
|
|
if($actionName == 'deleterecord') {
|
2012-12-17 00:46:51 +01:00
|
|
|
if(!$item->canDelete()) {
|
|
|
|
throw new ValidationException(
|
|
|
|
_t('GridFieldAction_Delete.DeletePermissionsFailure',"No delete permissions"),0);
|
|
|
|
}
|
|
|
|
|
2012-08-21 23:31:34 +01:00
|
|
|
$item->delete();
|
|
|
|
} else {
|
2012-12-17 00:46:51 +01:00
|
|
|
if(!$item->canEdit()) {
|
|
|
|
throw new ValidationException(
|
|
|
|
_t('GridFieldAction_Delete.EditPermissionsFailure',"No permission to unlink record"),0);
|
|
|
|
}
|
|
|
|
|
2012-08-21 23:31:34 +01:00
|
|
|
$gridField->getList()->remove($item);
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
}
|
2012-01-09 11:37:13 +01:00
|
|
|
}
|
2012-03-23 10:50:17 +13:00
|
|
|
}
|