Files
ProxyPanel/app/Http/Controllers/Admin/TicketController.php
兔姬桑 f25f2aea62 优化数据库 与 简化控制器 & more
1. 继续修改表表关系,与关联字段的限制;
2. 通过表表关系,简化一部分代码,自动让Laravel建立关联;
3. 拆分验证 与 优化数据创建与修改的获取数据操作;
4. 修改部分无意义的数据名称;
2020-12-28 12:09:20 +08:00

122 lines
3.7 KiB
PHP

<?php
namespace App\Http\Controllers\Admin;
use App\Components\Helpers;
use App\Http\Controllers\Controller;
use App\Mail\closeTicket;
use App\Mail\replyTicket;
use App\Models\Ticket;
use App\Models\User;
use Auth;
use Illuminate\Http\Request;
use Mail;
use Response;
/**
* 工单控制器.
*
* Class TicketController
*/
class TicketController extends Controller
{
// 工单列表
public function index(Request $request)
{
$email = $request->input('email');
$query = Ticket::whereAdminId(Auth::id())->orwhere('admin_id');
if (isset($email)) {
$query->whereHas('user', static function ($q) use ($email) {
$q->where('email', 'like', '%'.$email.'%');
});
}
return view('admin.ticket.index', ['ticketList' => $query->latest()->paginate(10)->appends($request->except('page'))]);
}
// 创建工单
public function store(Request $request)
{
$id = $request->input('id');
$email = $request->input('email');
$title = $request->input('title');
$content = $request->input('content');
$user = User::find($id) ?: User::whereEmail($email)->first();
if (! $user) {
return Response::json(['status' => 'fail', 'message' => '用户不存在']);
}
if ($user === Auth::user()) {
return Response::json(['status' => 'fail', 'message' => '不能对自己发起工单']);
}
if (empty($title) || empty($content)) {
return Response::json(['status' => 'fail', 'message' => '请输入标题和内容']);
}
$obj = new Ticket();
$obj->user_id = $user->id;
$obj->admin_id = Auth::id();
$obj->title = $title;
$obj->content = $content;
if ($obj->save()) {
return Response::json(['status' => 'success', 'message' => '工单创建成功']);
}
return Response::json(['status' => 'fail', 'message' => '工单创建失败']);
}
// 回复
public function edit(Ticket $ticket)
{
return view('admin.ticket.reply', [
'ticket' => $ticket,
'replyList' => $ticket->reply()->oldest()->get(),
]);
}
// 回复工单
public function update(Request $request, Ticket $ticket)
{
$content = substr(str_replace(['atob', 'eval'], '', clean($request->input('content'))), 0, 300);
if ($ticket->reply()->create(['admin_id' => Auth::id(), 'content' => $content])) {
// 将工单置为已回复
$ticket->update(['status' => 1]);
$title = '工单回复提醒';
$content = '标题:'.$ticket->title.'<br>管理员回复:'.$content;
// 发通知邮件
$logId = Helpers::addNotificationLog($title, $content, 1, $ticket->user->email);
Mail::to($ticket->user->email)->send(new replyTicket($logId, $title, $content));
return Response::json(['status' => 'success', 'message' => '回复成功']);
}
return Response::json(['status' => 'fail', 'message' => '回复失败']);
}
// 关闭工单
public function destroy(Ticket $ticket)
{
if (! $ticket->close()) {
return Response::json(['status' => 'fail', 'message' => '关闭失败']);
}
$title = '工单关闭提醒';
$content = '工单【'.$ticket->title.'】已关闭';
// 发邮件通知用户
$logId = Helpers::addNotificationLog($title, $content, 1, $ticket->user->email);
Mail::to($ticket->user->email)->send(new closeTicket($logId, $title, $content));
return Response::json(['status' => 'success', 'message' => '关闭成功']);
}
}