2015-04-24 14:27:22 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Icinga\Module\Director\Web\Table;
|
|
|
|
|
|
|
|
use Icinga\Application\Icinga;
|
|
|
|
use Icinga\Data\Selectable;
|
2015-07-23 16:18:32 +02:00
|
|
|
use Icinga\Data\Paginatable;
|
2015-04-24 14:27:22 +02:00
|
|
|
use Icinga\Web\Url;
|
2015-07-23 16:18:32 +02:00
|
|
|
use Icinga\Web\Widget\Paginator;
|
2015-04-24 14:27:22 +02:00
|
|
|
|
2015-07-23 16:18:32 +02:00
|
|
|
abstract class QuickTable implements Paginatable
|
2015-04-24 14:27:22 +02:00
|
|
|
{
|
|
|
|
protected $view;
|
|
|
|
|
|
|
|
protected $connection;
|
|
|
|
|
2015-07-23 16:18:32 +02:00
|
|
|
protected $limit;
|
|
|
|
|
|
|
|
protected $offset;
|
|
|
|
|
2015-06-02 17:32:19 +02:00
|
|
|
protected function renderRow($row)
|
2015-04-24 14:27:22 +02:00
|
|
|
{
|
|
|
|
$htm = " <tr>\n";
|
2015-06-01 12:42:40 +02:00
|
|
|
$firstRow = true;
|
2015-04-24 14:27:22 +02:00
|
|
|
|
2015-06-02 17:32:19 +02:00
|
|
|
foreach ($this->getTitles() as $key => $title) {
|
|
|
|
$val = $row->$key;
|
2015-06-01 12:42:40 +02:00
|
|
|
$value = null;
|
|
|
|
|
|
|
|
if ($firstRow) {
|
|
|
|
if ($val !== null && $url = $this->getActionUrl($row)) {
|
|
|
|
$value = $this->view()->qlink($val, $this->getActionUrl($row));
|
|
|
|
}
|
|
|
|
$firstRow = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($value === null) {
|
|
|
|
$value = $val === null ? '-' : $this->view()->escape($val);
|
|
|
|
}
|
|
|
|
|
|
|
|
$htm .= ' <td>' . $value . "</td>\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->hasAdditionalActions()) {
|
|
|
|
$htm .= ' <td class="actions">' . $this->renderAdditionalActions($row) . "</td>\n";
|
2015-04-24 14:27:22 +02:00
|
|
|
}
|
2015-06-01 12:42:40 +02:00
|
|
|
|
2015-04-24 14:27:22 +02:00
|
|
|
return $htm . " </tr>\n";
|
|
|
|
}
|
|
|
|
|
2015-06-02 17:32:19 +02:00
|
|
|
abstract protected function getTitles();
|
|
|
|
|
2015-06-01 12:42:40 +02:00
|
|
|
protected function getActionUrl($row)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2015-04-24 14:27:22 +02:00
|
|
|
public function setConnection(Selectable $connection)
|
|
|
|
{
|
|
|
|
$this->connection = $connection;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2015-07-23 16:18:32 +02:00
|
|
|
abstract protected function getBaseQuery();
|
|
|
|
|
|
|
|
public function fetchData()
|
|
|
|
{
|
|
|
|
$db = $this->connection()->getConnection();
|
|
|
|
$query = $this->getBaseQuery()->columns($this->getColumns());
|
|
|
|
|
|
|
|
if ($this->hasLimit() || $this->hasOffset()) {
|
|
|
|
$query->limit($this->getLimit(), $this->getOffset());
|
|
|
|
}
|
|
|
|
|
|
|
|
return $db->fetchAll($query);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getPaginator()
|
|
|
|
{
|
|
|
|
$paginator = new Paginator();
|
|
|
|
$paginator->setQuery($this);
|
|
|
|
|
|
|
|
return $paginator;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function count()
|
|
|
|
{
|
|
|
|
$db = $this->connection()->getConnection();
|
|
|
|
|
|
|
|
return $db->fetchOne($this->getBaseQuery()->columns(array('COUNT(*)')));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function limit($count = null, $offset = null)
|
|
|
|
{
|
|
|
|
$this->limit = $count;
|
|
|
|
$this->offset = $offset;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function hasLimit()
|
|
|
|
{
|
|
|
|
return $this->limit !== null;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getLimit()
|
|
|
|
{
|
|
|
|
return $this->limit;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function hasOffset()
|
|
|
|
{
|
|
|
|
return $this->offset !== null;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getOffset()
|
|
|
|
{
|
|
|
|
return $this->offset;
|
|
|
|
}
|
|
|
|
|
2015-06-01 12:42:40 +02:00
|
|
|
public function hasAdditionalActions()
|
|
|
|
{
|
|
|
|
return method_exists($this, 'renderAdditionalActions');
|
|
|
|
}
|
|
|
|
|
2015-04-24 14:27:22 +02:00
|
|
|
protected function connection()
|
|
|
|
{
|
|
|
|
// TODO: Fail if missing? Require connection in constructor?
|
|
|
|
return $this->connection;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function renderTitles($row)
|
|
|
|
{
|
2015-07-26 15:37:01 +02:00
|
|
|
$view = $this->view();
|
2015-04-24 14:27:22 +02:00
|
|
|
$htm = "<thead>\n <tr>\n";
|
2015-06-01 12:42:40 +02:00
|
|
|
|
2015-04-24 14:27:22 +02:00
|
|
|
foreach ($row as $title) {
|
|
|
|
$htm .= ' <th>' . $view->escape($title) . "</th>\n";
|
|
|
|
}
|
2015-06-01 12:42:40 +02:00
|
|
|
|
|
|
|
if ($this->hasAdditionalActions()) {
|
|
|
|
$htm .= ' <th class="actions">' . $view->translate('Actions') . "</th>\n";
|
|
|
|
}
|
|
|
|
|
2015-04-24 14:27:22 +02:00
|
|
|
return $htm . " </tr>\n</thead>\n";
|
|
|
|
}
|
|
|
|
|
2015-06-01 12:42:40 +02:00
|
|
|
protected function url($url, $params)
|
|
|
|
{
|
|
|
|
return Url::fromPath($url, $params);
|
|
|
|
}
|
|
|
|
|
2015-04-24 14:27:22 +02:00
|
|
|
public function render()
|
|
|
|
{
|
|
|
|
$data = $this->fetchData();
|
|
|
|
|
|
|
|
$htm = '<table class="simple action">' . "\n"
|
|
|
|
. $this->renderTitles($this->getTitles())
|
|
|
|
. "<tbody>\n";
|
|
|
|
foreach ($data as $row) {
|
|
|
|
$htm .= $this->renderRow($row);
|
|
|
|
}
|
|
|
|
return $htm . "</tbody>\n</table>\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function view()
|
|
|
|
{
|
|
|
|
if ($this->view === null) {
|
|
|
|
$this->view = Icinga::app()->getViewRenderer()->view;
|
|
|
|
}
|
|
|
|
return $this->view;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function setView($view)
|
|
|
|
{
|
|
|
|
$this->view = $view;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function __toString()
|
|
|
|
{
|
|
|
|
return $this->render();
|
|
|
|
}
|
|
|
|
}
|