DataView: Use a more flexible way to provide filter columns

refs 
This commit is contained in:
Johannes Meyer 2015-08-17 12:53:17 +02:00
parent 97245c5166
commit 57ea5d6d5a
1 changed files with 37 additions and 4 deletions
modules/monitoring/library/Monitoring/DataView

View File

@ -35,6 +35,13 @@ abstract class DataView implements QueryInterface, SortRules, FilterColumns, Ite
protected $isSorted = false;
/**
* The cache for all filter columns
*
* @var array
*/
protected $filterColumns;
/**
* Create a new view
*
@ -174,8 +181,7 @@ abstract class DataView implements QueryInterface, SortRules, FilterColumns, Ite
}
/**
* Check whether the given column is a valid filter column, i.e. the view actually provides the column or it's
* a non-queryable filter column
* Check whether the given column is a valid filter column
*
* @param string $column
*
@ -183,10 +189,37 @@ abstract class DataView implements QueryInterface, SortRules, FilterColumns, Ite
*/
public function isValidFilterTarget($column)
{
return in_array($column, $this->getColumns()) || in_array($column, $this->getFilterColumns());
return in_array($column, $this->getFilterColumns());
}
/**
* Return all filter columns with their optional label as key
*
* This will merge the results of self::getColumns(), self::getStaticFilterColumns() and
* self::getDynamicFilterColumns() *once*. (i.e. subsequent calls of this function will
* return the same result.)
*
* @return array
*/
public function getFilterColumns()
{
if ($this->filterColumns === null) {
$this->filterColumns = array_merge(
$this->getColumns(),
$this->getStaticFilterColumns(),
$this->getDynamicFilterColumns()
);
}
return $this->filterColumns;
}
/**
* Return all static filter columns
*
* @return array
*/
public function getStaticFilterColumns()
{
return array();
}