TicketController.php 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use Illuminate\Http\Request;
  4. use App\Http\Controllers\Controller;
  5. use App\Models\Ticket;
  6. use App\Models\TicketMessage;
  7. use Illuminate\Support\Facades\Redis;
  8. class TicketController extends Controller
  9. {
  10. public function index (Request $request) {
  11. if ($request->input('id')) {
  12. $ticket = Ticket::where('id', $request->input('id'))
  13. ->first();
  14. if (!$ticket) {
  15. abort(500, '工单不存在');
  16. }
  17. $ticket['message'] = TicketMessage::where('ticket_id', $ticket->id)->get();
  18. for ($i = 0; $i < count($ticket['message']); $i++) {
  19. if ($ticket['message'][$i]['user_id'] == $request->session()->get('id')) {
  20. $ticket['message'][$i]['is_me'] = true;
  21. } else {
  22. $ticket['message'][$i]['is_me'] = false;
  23. }
  24. }
  25. return response([
  26. 'data' => $ticket
  27. ]);
  28. }
  29. return response([
  30. 'data' => Ticket::orderBy('created_at', 'DESC')
  31. ->get()
  32. ]);
  33. }
  34. public function reply (Request $request) {
  35. if (empty($request->input('id'))) {
  36. abort(500, '参数错误');
  37. }
  38. if (empty($request->input('message'))) {
  39. abort(500, '消息不能为空');
  40. }
  41. $ticket = Ticket::where('id', $request->input('id'))
  42. ->first();
  43. if (!$ticket) {
  44. abort(500, '工单不存在');
  45. }
  46. $ticketMessage = TicketMessage::create([
  47. 'user_id' => $request->session()->get('id'),
  48. 'ticket_id' => $ticket->id,
  49. 'message' => $request->input('message')
  50. ]);
  51. if (!$ticketMessage) {
  52. abort(500, '工单回复失败');
  53. }
  54. return response([
  55. 'data' => true
  56. ]);
  57. }
  58. }