2021-09-20 23:08:35 +03:00
|
|
|
<?php declare(strict_types=1);
|
|
|
|
namespace openvk\Web\Models\Repositories;
|
|
|
|
use openvk\Web\Models\Entities\Report;
|
|
|
|
use Nette\Database\Table\ActiveRow;
|
|
|
|
use Chandler\Database\DatabaseConnection;
|
|
|
|
|
|
|
|
class Reports
|
|
|
|
{
|
|
|
|
private $context;
|
|
|
|
private $reports;
|
|
|
|
|
|
|
|
function __construct()
|
|
|
|
{
|
|
|
|
$this->context = DatabaseConnection::i()->getContext();
|
|
|
|
$this->reports = $this->context->table("reports");
|
|
|
|
}
|
|
|
|
|
|
|
|
private function toReport(?ActiveRow $ar): ?Report
|
|
|
|
{
|
|
|
|
return is_null($ar) ? NULL : new Report($ar);
|
|
|
|
}
|
|
|
|
|
|
|
|
function getReports(int $state = 0, int $page = 1): \Traversable
|
|
|
|
{
|
|
|
|
foreach($this->reports->where(["deleted" => 0])->page($page, 15) as $t)
|
|
|
|
yield new Ticket($t);
|
|
|
|
}
|
|
|
|
|
|
|
|
function getReportsCount(int $state = 0): int
|
|
|
|
{
|
|
|
|
return sizeof($this->tickets->where(["deleted" => 0, "type" => $state]));
|
|
|
|
}
|
|
|
|
|
|
|
|
function get(int $id): ?Ticket
|
|
|
|
{
|
|
|
|
return $this->toTicket($this->tickets->get($id));
|
|
|
|
}
|
2021-09-21 01:02:53 +03:00
|
|
|
|
|
|
|
function getByContentId(int $id): ?Ticket
|
|
|
|
{
|
|
|
|
$post = $this->reports->where(["deleted" => 0, "content_id" => $id])->fetch();
|
|
|
|
|
|
|
|
if($post)
|
|
|
|
return new Report($post);
|
|
|
|
else
|
|
|
|
return null;
|
|
|
|
}
|
2021-09-20 23:08:35 +03:00
|
|
|
|
|
|
|
use \Nette\SmartObject;
|
|
|
|
}
|