openvk/Web/Models/Repositories/TicketComments.php

47 lines
1.2 KiB
PHP
Raw Normal View History

<?php
declare(strict_types=1);
2020-06-07 19:04:43 +03:00
namespace openvk\Web\Models\Repositories;
2020-06-07 19:04:43 +03:00
use openvk\Web\Models\Entities\TicketComment;
use Chandler\Database\DatabaseConnection;
class TicketComments
{
use \Nette\SmartObject;
2020-06-07 19:04:43 +03:00
private $context;
private $comments;
public function __construct()
2020-06-07 19:04:43 +03:00
{
$this->context = DatabaseConnection::i()->getContext();
$this->comments = $this->context->table("tickets_comments");
}
public function getCommentsById(int $ticket_id): \Traversable
2020-06-07 19:04:43 +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
}
public function get(int $id): ?TicketComment
{
$comment = $this->comments->get($id);
;
if (!is_null($comment)) {
return new TicketComment($comment);
} else {
return null;
}
}
public 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
}