TicketController.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  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\DB;
  8. class TicketController extends Controller
  9. {
  10. public function fetch(Request $request)
  11. {
  12. if ($request->input('id')) {
  13. $ticket = Ticket::where('id', $request->input('id'))
  14. ->first();
  15. if (!$ticket) {
  16. abort(500, '工单不存在');
  17. }
  18. $ticket['message'] = TicketMessage::where('ticket_id', $ticket->id)->get();
  19. for ($i = 0; $i < count($ticket['message']); $i++) {
  20. if ($ticket['message'][$i]['user_id'] !== $ticket->user_id) {
  21. $ticket['message'][$i]['is_me'] = true;
  22. } else {
  23. $ticket['message'][$i]['is_me'] = false;
  24. }
  25. }
  26. return response([
  27. 'data' => $ticket
  28. ]);
  29. }
  30. $current = $request->input('current') ? $request->input('current') : 1;
  31. $pageSize = $request->input('pageSize') >= 10 ? $request->input('pageSize') : 10;
  32. $model = Ticket::orderBy('created_at', 'DESC');
  33. if ($request->input('status') !== NULL) {
  34. $model->where('status', $request->input('status'));
  35. }
  36. $total = $model->count();
  37. $res = $model->forPage($current, $pageSize)
  38. ->get();
  39. for ($i = 0; $i < count($res); $i++) {
  40. if ($res[$i]['last_reply_user_id'] == $request->session()->get('id')) {
  41. $res[$i]['reply_status'] = 0;
  42. } else {
  43. $res[$i]['reply_status'] = 1;
  44. }
  45. }
  46. return response([
  47. 'data' => $res,
  48. 'total' => $total
  49. ]);
  50. }
  51. public function reply(Request $request)
  52. {
  53. if (empty($request->input('id'))) {
  54. abort(500, '参数错误');
  55. }
  56. if (empty($request->input('message'))) {
  57. abort(500, '消息不能为空');
  58. }
  59. $ticket = Ticket::where('id', $request->input('id'))
  60. ->first();
  61. if (!$ticket) {
  62. abort(500, '工单不存在');
  63. }
  64. if ($ticket->status) {
  65. abort(500, '工单已关闭,无法回复');
  66. }
  67. DB::beginTransaction();
  68. $ticketMessage = TicketMessage::create([
  69. 'user_id' => $request->session()->get('id'),
  70. 'ticket_id' => $ticket->id,
  71. 'message' => $request->input('message')
  72. ]);
  73. $ticket->last_reply_user_id = $request->session()->get('id');
  74. if (!$ticketMessage || !$ticket->save()) {
  75. DB::rollback();
  76. abort(500, '工单回复失败');
  77. }
  78. DB::commit();
  79. return response([
  80. 'data' => true
  81. ]);
  82. }
  83. public function close(Request $request)
  84. {
  85. if (empty($request->input('id'))) {
  86. abort(500, '参数错误');
  87. }
  88. $ticket = Ticket::where('id', $request->input('id'))
  89. ->first();
  90. if (!$ticket) {
  91. abort(500, '工单不存在');
  92. }
  93. $ticket->status = 1;
  94. if (!$ticket->save()) {
  95. abort(500, '关闭失败');
  96. }
  97. return response([
  98. 'data' => true
  99. ]);
  100. }
  101. }