-
Notifications
You must be signed in to change notification settings - Fork 21
Expand file tree
/
Copy pathTicketRepository.php
More file actions
67 lines (53 loc) · 1.57 KB
/
TicketRepository.php
File metadata and controls
67 lines (53 loc) · 1.57 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<?php
namespace TeachMe\Repositories;
use TeachMe\Entities\Ticket;
class TicketRepository extends BaseRepository {
public function getModel()
{
return new Ticket();
}
protected function selectTicketsList()
{
return $this->newQuery()->selectRaw(
'tickets.*, '
. '( SELECT COUNT(*) FROM ticket_comments WHERE ticket_comments.ticket_id = tickets.id ) as num_comments,'
. '( SELECT COUNT(*) FROM ticket_votes WHERE ticket_votes.ticket_id = tickets.id ) as num_votes'
)->with('author');
}
public function paginateLatest()
{
return $this->selectTicketsList()
->orderBy('created_at', 'DESC')
->paginate(20);
}
public function paginateOpen()
{
return $this->selectTicketsList()
->where('status', 'open')
->orderBy('created_at', 'DESC')
->paginate(20);
}
public function paginateClosed()
{
return $this->selectTicketsList()
->where('status', 'closed')
->orderBy('created_at', 'DESC')
->paginate(20);
}
public function openNew($user, $title, $link = '')
{
return $user->tickets()->create([
'title' => $title,
'link' => $link,
'status' => empty($link) ? 'open' : 'closed'
]);
}
public function closeTicket($id, $link)
{
$ticket = $this->findOrFail($id);
$ticket->status = 'closed';
$ticket->link = $link;
$ticket->save();
return $ticket;
}
}