whenFilled($field, function ($value) use ($query, $field) { $query->where($field, 'like', "%$value%"); }); } return view('admin.permission.index', ['permissions' => $query->paginate(20)->appends($request->except('page'))]); } public function store(PermissionRequest $request): RedirectResponse { if ($permission = Permission::create($request->validated())) { return redirect()->route('admin.permission.edit', $permission)->with('successMsg', trans('common.success_item', ['attribute' => trans('common.add')])); } return redirect()->back()->withInput()->withErrors(trans('common.failed_item', ['attribute' => trans('common.add')])); } public function create(): View { return view('admin.permission.info'); } public function edit(Permission $permission): View { return view('admin.permission.info', compact('permission')); } public function update(PermissionRequest $request, Permission $permission): RedirectResponse { if ($permission->update($request->validated())) { return redirect()->back()->with('successMsg', trans('common.success_item', ['attribute' => trans('common.update')])); } return redirect()->back()->withInput()->withErrors(trans('common.failed_item', ['attribute' => trans('common.update')])); } public function destroy(Permission $permission): JsonResponse { try { if ($permission->delete()) { return response()->json(['status' => 'success', 'message' => trans('common.success_item', ['attribute' => trans('common.delete')])]); } } catch (Exception $e) { Log::error(trans('common.error_action_item', ['action' => trans('common.delete'), 'attribute' => trans('admin.logs.rule.title')]).': '.$e->getMessage()); return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.delete')]).', '.$e->getMessage()]); } return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.delete')])]); } }