2020-06-07 19:04:43 +03:00
|
|
|
<?php declare(strict_types=1);
|
|
|
|
namespace openvk\Web\Models\Repositories;
|
|
|
|
use openvk\Web\Models\Entities\TicketComment;
|
|
|
|
use Chandler\Database\DatabaseConnection;
|
|
|
|
|
|
|
|
class TicketComments
|
|
|
|
{
|
|
|
|
private $context;
|
|
|
|
private $comments;
|
|
|
|
|
|
|
|
function __construct()
|
|
|
|
{
|
|
|
|
$this->context = DatabaseConnection::i()->getContext();
|
|
|
|
$this->comments = $this->context->table("tickets_comments");
|
|
|
|
}
|
|
|
|
|
|
|
|
function getCommentsById(int $ticket_id): \Traversable
|
|
|
|
{
|
2022-01-28 16:34:13 +03:00
|
|
|
foreach($this->comments->where(['ticket_id' => $ticket_id, 'deleted' => 0]) as $comment) yield new TicketComment($comment);
|
2020-06-07 19:04:43 +03:00
|
|
|
}
|
2021-12-15 01:56:23 +03:00
|
|
|
|
|
|
|
function get(int $id): ?TicketComment
|
|
|
|
{
|
|
|
|
$comment = $this->comments->get($id);;
|
|
|
|
if (!is_null($comment))
|
|
|
|
return new TicketComment($comment);
|
|
|
|
else
|
|
|
|
return NULL;
|
|
|
|
}
|
2022-11-08 00:36:07 +03:00
|
|
|
|
|
|
|
function getCountByAgent(int $agent_id, int $mark = NULL): int
|
|
|
|
{
|
|
|
|
$filter = ['user_id' => $agent_id, 'user_type' => 1];
|
|
|
|
$mark && $filter['mark'] = $mark;
|
|
|
|
return sizeof($this->comments->where($filter));
|
|
|
|
}
|
2020-06-07 19:04:43 +03:00
|
|
|
|
|
|
|
use \Nette\SmartObject;
|
|
|
|
}
|