mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
70d5ffefdd
API CHANGE: Added GridField::getDataFieldValue() to encapsulate field lookup for all components. API CHANGE: Allow 'callback' key to be specified in a GridFieldDataColumn column info. In this case, title should be put as the 'title' key of a map rather than simply the column info.
258 lines
6.9 KiB
PHP
258 lines
6.9 KiB
PHP
<?php
|
|
/**
|
|
*
|
|
* @see GridField
|
|
*
|
|
* @package framework
|
|
* @subpackage fields-relational
|
|
*/
|
|
class GridFieldDataColumns implements GridField_ColumnProvider {
|
|
|
|
/** @var array */
|
|
public $fieldCasting = array();
|
|
|
|
/** @var array */
|
|
public $fieldFormatting = array();
|
|
|
|
/**
|
|
* This is the columns that will be visible
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $displayFields = array();
|
|
|
|
/**
|
|
* Modify the list of columns displayed in the table.
|
|
* See {@link GridFieldDataColumns->getDisplayFields()} and {@link GridFieldDataColumns}.
|
|
*
|
|
* @param GridField $gridField
|
|
* @param array - List reference of all column names.
|
|
*/
|
|
public function augmentColumns($gridField, &$columns) {
|
|
$baseColumns = array_keys($this->getDisplayFields($gridField));
|
|
foreach($baseColumns as $col) $columns[] = $col;
|
|
}
|
|
|
|
/**
|
|
* Names of all columns which are affected by this component.
|
|
*
|
|
* @param GridField $gridField
|
|
* @return array
|
|
*/
|
|
public function getColumnsHandled($gridField) {
|
|
return array_keys($this->getDisplayFields($gridField));
|
|
}
|
|
|
|
/**
|
|
* Override the default behaviour of showing the models summaryFields with
|
|
* these fields instead
|
|
* Example: array( 'Name' => 'Members name', 'Email' => 'Email address')
|
|
*
|
|
* @param array $fields
|
|
*/
|
|
public function setDisplayFields($fields) {
|
|
if(!is_array($fields)) {
|
|
throw new InvalidArgumentException('Arguments passed to GridFieldDataColumns::setDisplayFields() must be an array');
|
|
}
|
|
$this->displayFields = $fields;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get the DisplayFields
|
|
*
|
|
* @return array
|
|
* @see GridFieldDataColumns::setDisplayFields
|
|
*/
|
|
public function getDisplayFields($gridField) {
|
|
if(!$this->displayFields) {
|
|
return singleton($gridField->getModelClass())->summaryFields();
|
|
}
|
|
return $this->displayFields;
|
|
}
|
|
|
|
/**
|
|
* Specify castings with fieldname as the key, and the desired casting as value.
|
|
* Example: array("MyCustomDate"=>"Date","MyShortText"=>"Text->FirstSentence")
|
|
*
|
|
* @param array $casting
|
|
*/
|
|
public function setFieldCasting($casting) {
|
|
$this->fieldCasting = $casting;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Specify custom formatting for fields, e.g. to render a link instead of pure text.
|
|
* Caution: Make sure to escape special php-characters like in a normal php-statement.
|
|
* Example: "myFieldName" => '<a href=\"custom-admin/$ID\">$ID</a>'.
|
|
* Alternatively, pass a anonymous function, which takes one parameter: The list item.
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getFieldCasting() {
|
|
return $this->fieldCasting;
|
|
}
|
|
|
|
/**
|
|
* @param array $formatting
|
|
*/
|
|
public function setFieldFormatting($formatting) {
|
|
$this->fieldFormatting = $formatting;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
public function getFieldFormatting() {
|
|
return $this->fieldFormatting;
|
|
}
|
|
|
|
/**
|
|
* HTML for the column, content of the <td> element.
|
|
*
|
|
* @param GridField
|
|
* @param DataObject - Record displayed in this row
|
|
* @param string
|
|
* @return string HTML for the column. Return NULL to skip.
|
|
*/
|
|
public function getColumnContent($gridField, $record, $columnName) {
|
|
// Find the data column for the given named column
|
|
$columns = $this->getDisplayFields($gridField);
|
|
$columnInfo = $columns[$columnName];
|
|
|
|
// Allow callbacks
|
|
if(is_array($columnInfo) && isset($columnInfo['callback'])) {
|
|
$method = $columnInfo['callback'];
|
|
$value = Convert::raw2xml($method($record));
|
|
|
|
// This supports simple FieldName syntax
|
|
} else {
|
|
$value = Convert::raw2xml($gridField->getDataFieldValue($record, $columnName));
|
|
}
|
|
|
|
$value = $this->castValue($gridField, $columnName, $value);
|
|
$value = $this->formatValue($gridField, $record, $columnName, $value);
|
|
$value = $this->escapeValue($gridField, $value);
|
|
|
|
return $value;
|
|
}
|
|
|
|
/**
|
|
* Attributes for the element containing the content returned by {@link getColumnContent()}.
|
|
*
|
|
* @param GridField $gridField
|
|
* @param DataObject $record displayed in this row
|
|
* @param string $columnName
|
|
* @return array
|
|
*/
|
|
public function getColumnAttributes($gridField, $record, $columnName) {
|
|
return array('class' => 'col-' . preg_replace('/[^\w]/', '-', $columnName));
|
|
}
|
|
|
|
/**
|
|
* Additional metadata about the column which can be used by other components,
|
|
* e.g. to set a title for a search column header.
|
|
*
|
|
* @param GridField $gridField
|
|
* @param string $columnName
|
|
* @return array - Map of arbitrary metadata identifiers to their values.
|
|
*/
|
|
public function getColumnMetadata($gridField, $column) {
|
|
$columns = $this->getDisplayFields($gridField);
|
|
|
|
$title = null;
|
|
if(is_string($columns[$column])) {
|
|
$title = $columns[$column];
|
|
} else if(is_array($columns[$column]) && isset($columns[$column]['title'])) {
|
|
$title = $columns[$column]['title'];
|
|
}
|
|
|
|
return array(
|
|
'title' => $title,
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Translate a Object.RelationName.ColumnName $columnName into the value that ColumnName returns
|
|
*
|
|
* @param DataObject $record
|
|
* @param string $columnName
|
|
* @return string|null - returns null if it could not found a value
|
|
*/
|
|
protected function getValueFromRelation($record, $columnName) {
|
|
$fieldNameParts = explode('.', $columnName);
|
|
$tmpItem = clone($record);
|
|
for($idx = 0; $idx < sizeof($fieldNameParts); $idx++) {
|
|
$methodName = $fieldNameParts[$idx];
|
|
// Last mmethod call from $columnName return what that method is returning
|
|
if($idx == sizeof($fieldNameParts) - 1) {
|
|
return $tmpItem->XML_val($methodName);
|
|
}
|
|
// else get the object from this $methodName
|
|
$tmpItem = $tmpItem->$methodName();
|
|
}
|
|
return null;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param GridField $gridField
|
|
* @param string $fieldName
|
|
* @param string $value
|
|
* @return string
|
|
*/
|
|
protected function castValue($gridField, $fieldName, $value) {
|
|
if(array_key_exists($fieldName, $this->fieldCasting)) {
|
|
return $gridField->getCastedValue($value, $this->fieldCasting[$fieldName]);
|
|
} elseif(is_object($value) && method_exists($value, 'Nice')) {
|
|
return $value->Nice();
|
|
}
|
|
return $value;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param GridField $gridField
|
|
* @param DataObject $item
|
|
* @param string $fieldName
|
|
* @param string $value
|
|
* @return string
|
|
*/
|
|
protected function formatValue($gridField, $item, $fieldName, $value) {
|
|
if(!array_key_exists($fieldName, $this->fieldFormatting)) {
|
|
return $value;
|
|
}
|
|
|
|
$spec = $this->fieldFormatting[$fieldName];
|
|
if(is_callable($spec)) {
|
|
return $spec($item);
|
|
} else {
|
|
$format = str_replace('$value', "__VAL__", $spec);
|
|
$format = preg_replace('/\$([A-Za-z0-9-_]+)/', '$item->$1', $format);
|
|
$format = str_replace('__VAL__', '$value', $format);
|
|
eval('$value = "' . $format . '";');
|
|
return $value;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Remove values from a value using FieldEscape setter
|
|
*
|
|
* @param GridField $gridField
|
|
* @param string $value
|
|
* @return string
|
|
*/
|
|
protected function escapeValue($gridField, $value) {
|
|
if(!$escape = $gridField->FieldEscape) {
|
|
return $value;
|
|
}
|
|
|
|
foreach($escape as $search => $replace) {
|
|
$value = str_replace($search, $replace, $value);
|
|
}
|
|
return $value;
|
|
}
|
|
}
|