icingaweb2-module-director/application/tables/ImportedrowsTable.php

72 lines
1.6 KiB
PHP
Raw Normal View History

2015-07-26 15:39:37 +02:00
<?php
namespace Icinga\Module\Director\Tables;
use Icinga\Data\DataArray\ArrayDatasource;
use Icinga\Module\Director\Objects\ImportRun;
use Icinga\Module\Director\Web\Table\QuickTable;
2015-07-26 15:39:37 +02:00
class ImportedrowsTable extends QuickTable
{
protected $columns;
2015-07-26 15:39:37 +02:00
protected $importRun;
public function setImportRun(ImportRun $run)
2015-07-26 15:39:37 +02:00
{
$this->importRun = $run;
return $this;
2015-07-26 15:39:37 +02:00
}
public function setColumns($columns)
2015-07-26 15:39:37 +02:00
{
$this->columns = $columns;
2015-07-26 15:39:37 +02:00
return $this;
}
public function getColumns()
{
if ($this->columns === null) {
$cols = $this->importRun->listColumnNames();
} else {
$cols = $this->columns;
}
return array_combine($cols, $cols);
}
2015-07-26 15:39:37 +02:00
public function getTitles()
{
$cols = $this->getColumns();
// TODO: replace key column with object name!?
// $view = $this->view();
// 'object_name' => $view->translate('Object name')
return array_combine($cols, $cols);
2015-07-26 15:39:37 +02:00
}
public function fetchData()
{
$query = $this->getBaseQuery()->columns($this->getColumns());
2015-07-26 15:39:37 +02:00
if ($this->hasLimit() || $this->hasOffset()) {
$query->limit($this->getLimit(), $this->getOffset());
}
return $query->fetchAll();
}
public function count()
{
return $this->getBaseQuery()->count();
2015-07-26 15:39:37 +02:00
}
public function getBaseQuery()
{
2015-12-16 20:27:10 +01:00
$ds = new ArrayDatasource(
$this->importRun->fetchRows($this->columns, $this->filter)
2015-12-16 20:27:10 +01:00
);
return $ds->select()->order('object_name');
2015-07-26 15:39:37 +02:00
}
}