forked from symbiote/silverstripe-gridfieldextensions
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add GridFieldAddNewMultiClass component.
This component allows the user to select from a list of classes when creating a new record.
- Loading branch information
Showing
6 changed files
with
237 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,162 @@ | ||
<?php | ||
/** | ||
* A component which lets the user select from a list of classes to create a new record form. | ||
* | ||
* By default the list of classes that are createable is the grid field's model class, and any | ||
* subclasses. This can be customised using {@link setClasses()}. | ||
*/ | ||
class GridFieldAddNewMultiClass implements GridField_HTMLProvider, GridField_URLHandler { | ||
|
||
private $fragment; | ||
|
||
private $title; | ||
|
||
private $classes; | ||
|
||
/** | ||
* @param string $fragment the fragment to render the button in | ||
*/ | ||
public function __construct($fragment = 'before') { | ||
$this->setFragment($fragment); | ||
$this->setTitle(_t('GridFieldExtensions.ADD', 'Add')); | ||
} | ||
|
||
/** | ||
* Gets the fragment name this button is rendered into. | ||
* | ||
* @return string | ||
*/ | ||
public function getFragment() { | ||
return $this->fragment; | ||
} | ||
|
||
/** | ||
* Sets the fragment name this button is rendered into. | ||
* | ||
* @param string $fragment | ||
*/ | ||
public function setFragment($fragment) { | ||
$this->fragment = $fragment; | ||
} | ||
|
||
/** | ||
* Gets the button title text. | ||
* | ||
* @return string | ||
*/ | ||
public function getTitle() { | ||
return $this->title; | ||
} | ||
|
||
/** | ||
* Sets the button title text. | ||
* | ||
* @param string $title | ||
*/ | ||
public function setTitle($title) { | ||
$this->title = $title; | ||
} | ||
|
||
/** | ||
* Gets the classes that can be created using this button, defaulting to the model class and | ||
* its subclasses. | ||
* | ||
* @param GridField $grid | ||
* @return array a map of class name to title | ||
*/ | ||
protected function getClasses($grid) { | ||
$result = array(); | ||
|
||
if(is_null($this->classes)) { | ||
$classes = array_values(ClassInfo::subclassesFor($grid->getModelClass())); | ||
} else { | ||
$classes = $this->classes; | ||
} | ||
|
||
foreach($classes as $class => $title) { | ||
if(!is_string($class)) { | ||
$class = $title; | ||
$title = singleton($class)->i18n_singular_name(); | ||
} | ||
|
||
if(!singleton($class)->canCreate()) { | ||
continue; | ||
} | ||
|
||
$result[$class] = $title; | ||
} | ||
|
||
return $result; | ||
} | ||
|
||
/** | ||
* Sets the classes that can be created using this button. | ||
* | ||
* @param array $classes a set of class names, optionally mapped to titles | ||
*/ | ||
public function setClasses(array $classes) { | ||
$this->classes = $classes; | ||
} | ||
|
||
/** | ||
* Handles adding a new instance of a selected class. | ||
* | ||
* @param GridField $grid | ||
* @param SS_HTTPRequest $request | ||
*/ | ||
public function handleAdd($grid, $request) { | ||
$class = $request->param('ClassName'); | ||
$classes = $this->getClasses($grid); | ||
$component = $grid->getConfig()->getComponentByType('GridFieldDetailForm'); | ||
|
||
if(!$component) { | ||
throw new Exception('The add new multi class component requires the detail form component.'); | ||
} | ||
|
||
if(!$class || !array_key_exists($class, $classes)) { | ||
throw new SS_HTTPResponse_Exception(400); | ||
} | ||
|
||
$handler = new GridFieldAddNewMultiClassHandler( | ||
$grid, $component, new $class(), $grid->getForm()->getController(), 'add-multi-class' | ||
); | ||
$handler->setTemplate($component->getTemplate()); | ||
|
||
return $handler; | ||
} | ||
|
||
/** | ||
* {@inheritDoc} | ||
*/ | ||
public function getHTMLFragments($grid) { | ||
$classes = $this->getClasses($grid); | ||
|
||
if(!count($classes)) { | ||
return array(); | ||
} | ||
|
||
$field = new DropdownField(sprintf('%s[ClassName]', __CLASS__), '', $classes); | ||
$field->setEmptyString(_t('GridFieldExtensions.SELECTTYPETOCREATE', '(Select type to create)')); | ||
$field->addExtraClass('no-change-track'); | ||
|
||
$data = new ArrayData(array( | ||
'Title' => $this->getTitle(), | ||
'Link' => Controller::join_links($grid->Link(), 'add-multi-class'), | ||
'ClassField' => $field | ||
)); | ||
|
||
return array( | ||
$this->getFragment() => $data->renderWith(__CLASS__) | ||
); | ||
} | ||
|
||
/** | ||
* {@inheritDoc} | ||
*/ | ||
public function getURLHandlers($grid) { | ||
return array( | ||
'add-multi-class/$ClassName!' => 'handleAdd' | ||
); | ||
} | ||
|
||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
<?php | ||
/** | ||
* A custom grid field request handler that allows interacting with form fields when adding records. | ||
*/ | ||
class GridFieldAddNewMultiClassHandler extends GridFieldDetailForm_ItemRequest { | ||
|
||
public function Link($action = null) { | ||
if($this->record->ID) { | ||
return parent::Link($action); | ||
} else { | ||
return Controller::join_links( | ||
$this->gridField->Link(), 'add-multi-class', get_class($this->record) | ||
); | ||
} | ||
} | ||
|
||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
<div class="ss-gridfield-add-new-multi-class"> | ||
$ClassField.FieldHolder | ||
|
||
<a href="$Link" class="ss-ui-action-constructive ss-ui-button" data-icon="add"> | ||
$Title | ||
</a> | ||
</div> |