whenFilled('username', function ($username) use ($query) { $query->whereHas('user', function ($query) use ($username) { $query->where('username', 'like', "%$username%"); }); }); foreach (['user_id', 'status', 'code'] as $field) { $request->whenFilled($field, function ($value) use ($query, $field) { $query->where($field, $value); }); } return view('admin.subscribe.index', ['subscribeList' => $query->sortable(['id' => 'desc'])->paginate(20)->appends($request->except('page'))]); } public function subscribeLog(Request $request, UserSubscribe $userSubscribe): View { // 订阅记录 $query = $userSubscribe->userSubscribeLogs(); $request->whenFilled('id', function ($value) use ($query) { $query->where('id', $value); }); $request->whenFilled('ip', function ($value) use ($query) { $query->where('request_ip', 'like', "%$value%"); }); if ($request->filled('start')) { $query->whereBetween('request_time', [$request->input('start').' 00:00:00', $request->input('end').' 23:59:59']); } $subscribeLogs = $query->latest()->paginate(20)->appends($request->except('page'))->transform(function ($log) { if ($log->request_ip) { $log->ipInfo = optional(IP::getIPInfo($log->request_ip))['address'] ?? null; } return $log; }); return view('admin.subscribe.log', ['subscribeLog' => $subscribeLogs, 'subscribe' => $userSubscribe]); } public function setSubscribeStatus(UserSubscribe $userSubscribe): JsonResponse { $data = $userSubscribe->status ? ['status' => 0, 'ban_time' => strtotime(sysConfig('ban_duration').' minutes'), 'ban_desc' => 'Your subscription has been disabled by the administrator, please contact the administrator to restore it'] : ['status' => 1, 'ban_time' => null, 'ban_desc' => null]; $ret = $userSubscribe->update($data) ? ['status' => 'success', 'message' => trans('common.success_item', ['attribute' => trans('common.update')])] : ['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.update')])]; return response()->json($ret); } }