2013-02-02 04:14:59 +01:00
|
|
|
<?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 {
|
|
|
|
|
2013-07-11 04:40:13 +02:00
|
|
|
private static $allowed_actions = array(
|
|
|
|
'handleAdd'
|
|
|
|
);
|
|
|
|
|
2013-02-02 04:14:59 +01:00
|
|
|
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
|
2013-04-24 08:28:47 +02:00
|
|
|
* @return GridFieldAddNewMultiClass $this
|
2013-02-02 04:14:59 +01:00
|
|
|
*/
|
|
|
|
public function setFragment($fragment) {
|
|
|
|
$this->fragment = $fragment;
|
2013-04-24 08:28:47 +02:00
|
|
|
return $this;
|
2013-02-02 04:14:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the button title text.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getTitle() {
|
|
|
|
return $this->title;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the button title text.
|
|
|
|
*
|
|
|
|
* @param string $title
|
2013-04-24 08:28:47 +02:00
|
|
|
* @return GridFieldAddNewMultiClass $this
|
2013-02-02 04:14:59 +01:00
|
|
|
*/
|
|
|
|
public function setTitle($title) {
|
|
|
|
$this->title = $title;
|
2013-04-24 08:28:47 +02:00
|
|
|
return $this;
|
2013-02-02 04:14:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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
|
2013-04-24 08:28:47 +02:00
|
|
|
* @return GridFieldAddNewMultiClass $this
|
2013-02-02 04:14:59 +01:00
|
|
|
*/
|
|
|
|
public function setClasses(array $classes) {
|
|
|
|
$this->classes = $classes;
|
2013-04-24 08:28:47 +02:00
|
|
|
return $this;
|
2013-02-02 04:14:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handles adding a new instance of a selected class.
|
|
|
|
*
|
|
|
|
* @param GridField $grid
|
|
|
|
* @param SS_HTTPRequest $request
|
2013-11-14 13:36:28 +01:00
|
|
|
* @return GridFieldAddNewMultiClassHandler
|
2013-02-02 04:14:59 +01:00
|
|
|
*/
|
|
|
|
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();
|
|
|
|
}
|
|
|
|
|
2013-02-08 15:42:48 +01:00
|
|
|
GridFieldExtensions::include_requirements();
|
|
|
|
|
2013-02-02 04:14:59 +01:00
|
|
|
$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(),
|
2013-10-09 11:34:12 +02:00
|
|
|
'Link' => Controller::join_links($grid->Link(), 'add-multi-class', '{class}'),
|
2013-02-02 04:14:59 +01:00
|
|
|
'ClassField' => $field
|
|
|
|
));
|
|
|
|
|
|
|
|
return array(
|
|
|
|
$this->getFragment() => $data->renderWith(__CLASS__)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritDoc}
|
|
|
|
*/
|
|
|
|
public function getURLHandlers($grid) {
|
|
|
|
return array(
|
|
|
|
'add-multi-class/$ClassName!' => 'handleAdd'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|