2011-12-06 13:56:24 +13:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Description of GridFieldConfig
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
class GridFieldConfig {
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @return GridFieldConfig
|
|
|
|
*/
|
|
|
|
public static function create(){
|
|
|
|
return new GridFieldConfig();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @var ArrayList
|
|
|
|
*/
|
|
|
|
protected $components = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function __construct() {
|
2012-01-30 15:47:22 +01:00
|
|
|
$this->components = new ArrayList();
|
2011-12-06 13:56:24 +13:00
|
|
|
}
|
|
|
|
|
2012-02-21 22:06:41 +01:00
|
|
|
/**
|
|
|
|
* @param GridFieldComponent $component
|
|
|
|
*/
|
2011-12-06 13:56:24 +13:00
|
|
|
public function addComponent(GridFieldComponent $component) {
|
|
|
|
$this->getComponents()->push($component);
|
|
|
|
return $this;
|
|
|
|
}
|
2012-02-21 22:06:41 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param GridFieldComponent One or more components
|
|
|
|
*/
|
|
|
|
public function addComponents() {
|
|
|
|
$components = func_get_args();
|
|
|
|
foreach($components as $component) $this->addComponent($component);
|
|
|
|
return $this;
|
|
|
|
}
|
2011-12-06 13:56:24 +13:00
|
|
|
|
|
|
|
/**
|
2012-01-30 15:47:22 +01:00
|
|
|
* @return ArrayList Of GridFieldComponent
|
2011-12-06 13:56:24 +13:00
|
|
|
*/
|
|
|
|
public function getComponents() {
|
|
|
|
if(!$this->components) {
|
|
|
|
$this->components = new ArrayList();
|
|
|
|
}
|
|
|
|
return $this->components;
|
|
|
|
}
|
2012-01-30 15:47:22 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns all components extending a certain class, or implementing a certain interface.
|
|
|
|
*
|
|
|
|
* @param String Class name or interface
|
|
|
|
* @return ArrayList Of GridFieldComponent
|
|
|
|
*/
|
|
|
|
public function getComponentsByType($type) {
|
|
|
|
$components = new ArrayList();
|
|
|
|
foreach($this->components as $component) {
|
|
|
|
if($component instanceof $type) $components->push($component);
|
|
|
|
}
|
|
|
|
return $components;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the first available component with the given class or interface.
|
|
|
|
*
|
|
|
|
* @param String ClassName
|
|
|
|
* @return GridFieldComponent
|
|
|
|
*/
|
|
|
|
public function getComponentByType($type) {
|
|
|
|
foreach($this->components as $component) {
|
|
|
|
if($component instanceof $type) return $component;
|
|
|
|
}
|
|
|
|
}
|
2012-01-24 12:36:25 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
class GridFieldConfig_Base extends GridFieldConfig {
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param int $itemsPerPage - How many items per page should show up per page
|
|
|
|
* @return GridFieldConfig_Base
|
|
|
|
*/
|
2012-02-22 16:25:11 +13:00
|
|
|
public static function create($itemsPerPage=15){
|
2012-03-02 15:59:39 +13:00
|
|
|
return new GridFieldConfig_Base($itemsPerPage);
|
2011-12-06 13:56:24 +13:00
|
|
|
}
|
2012-01-24 12:36:25 +13:00
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param int $itemsPerPage - How many items per page should show up
|
|
|
|
*/
|
2012-02-22 16:25:11 +13:00
|
|
|
public function __construct($itemsPerPage=15) {
|
2012-02-09 16:02:47 +13:00
|
|
|
$this->addComponent(new GridFieldTitle());
|
2012-01-24 12:36:25 +13:00
|
|
|
$this->addComponent(new GridFieldSortableHeader());
|
2012-01-30 15:51:07 +01:00
|
|
|
$this->addComponent(new GridFieldFilter());
|
2012-01-24 12:36:25 +13:00
|
|
|
$this->addComponent(new GridFieldDefaultColumns());
|
|
|
|
$this->addComponent(new GridFieldPaginator($itemsPerPage));
|
2011-12-06 13:56:24 +13:00
|
|
|
}
|
2012-01-24 12:36:25 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This GridFieldConfig bundles a common set of componentes used for displaying
|
|
|
|
* a gridfield with:
|
|
|
|
*
|
|
|
|
* - Relation adding
|
|
|
|
* - Sortable header
|
|
|
|
* - Default columns
|
|
|
|
* - Edit links on every item
|
|
|
|
* - Action for removing relationship
|
|
|
|
* - Paginator
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
class GridFieldConfig_ManyManyEditor extends GridFieldConfig {
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param string $fieldToSearch - Which field on the object should be searched for
|
|
|
|
* @param int $itemsPerPage - How many items per page should show up
|
|
|
|
* @return GridFieldConfig_ManyManyEditor
|
|
|
|
*/
|
2012-03-01 14:43:42 +01:00
|
|
|
public static function create($fieldToSearch, $itemsPerPage=15){
|
|
|
|
return new GridFieldConfig_ManyManyEditor($fieldToSearch, $itemsPerPage=15);
|
2011-12-06 13:56:24 +13:00
|
|
|
}
|
2012-01-24 12:36:25 +13:00
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param string $fieldToSearch - Which field on the object should be searched for
|
|
|
|
* @param int $itemsPerPage - How many items per page should show up
|
|
|
|
*/
|
2012-03-01 14:43:42 +01:00
|
|
|
public function __construct($fieldToSearch, $itemsPerPage=15) {
|
|
|
|
$this->addComponent(new GridFieldRelationAdd($fieldToSearch));
|
2012-01-24 12:36:25 +13:00
|
|
|
$this->addComponent(new GridFieldSortableHeader());
|
2012-03-02 16:03:23 +13:00
|
|
|
$this->addComponent(new GridFieldFilter());
|
2012-01-24 12:36:25 +13:00
|
|
|
$this->addComponent(new GridFieldDefaultColumns());
|
|
|
|
$this->addComponent(new GridFieldAction_Edit());
|
|
|
|
$this->addComponent(new GridFieldRelationDelete());
|
|
|
|
$this->addComponent(new GridFieldPaginator($itemsPerPage));
|
2012-02-27 18:32:13 +01:00
|
|
|
$this->addComponent(new GridFieldPopupForms());
|
2011-12-06 13:56:24 +13:00
|
|
|
}
|
|
|
|
}
|