middleware([ "auth" ]); $this->middleware([ "check.auth:contact.list" ])->only("index"); $this->middleware([ "check.auth:contact.show" ])->only("show"); $this->middleware([ "check.auth:contact.create" ])->only("create", "store"); $this->middleware([ "check.auth:contact.edit" ])->only("edit", "update"); $this->middleware([ "check.auth:contact.delete" ])->only("delete"); } /** * Display a listing of the resource. * * @return \Illuminate\Http\Response */ public function index(Request $request) { $contact = Contact::query()->paginate($request->input("limit", 20)); return Response::detect("contacts.index", [ "contacts" => $contact]); } /** * Show the form for creating a new resource. * * @return \Illuminate\Http\Response */ public function create() { return Response::detect("contacts.create"); } /** * Store a newly created resource in storage. * * @param \Illuminate\Http\Request $request * @return \Illuminate\Http\Response */ public function store(Request $request) { $requestContact = $request->validate([ "contactname" => "required|max:255", "title" => "required|max:255", "email" => "required|max:255", "phone" => "required|max:255", ]); $contact = new Contact($requestContact); $saved = $contact->save(); if(!$saved){ return Response::detect("contacts.store"); }else{ $contact = Contact::query()->paginate($request->input("limit", 20)); return Response::detect("contacts.index", ['contacts' => $contact]); } } /** * Display the specified resource. * * @param int $id * @return \Illuminate\Http\Response */ public function show($id) { return Response::detect("contacts.show", [ "contacts" => $id]); } /** * Show the form for editing the specified resource. * * @param int $id * @return \Illuminate\Http\Response */ public function edit($id) { $contact = Contact::find($id); return Response::detect("contacts.edit", ["contact" => $contact]); } /** * Update the specified resource in storage. * * @param \Illuminate\Http\Request $request * @param int $id * @return \Illuminate\Http\Response */ public function update(Request $request, $id) { $data = $request->all(); $contact = Contact::find($id); $contact->update($data); $saved = $contact->save(); if(!$saved){ return Response::detect("contacts.update", [ "contacts" => $contact ]); }else{ $contact = Contact::query()->paginate($request->input("limit", 20)); return Response::detect("contacts.index", ['contacts' => $contact]); } } /** * Remove the specified resource from storage. * * @param int $id * @return \Illuminate\Http\RedirectResponse * @throws \Exception */ public function destroy($id) { $contact = Contact::find($id); $contact->delete(); return redirect()->route("contacts.index"); } public function search(Request $request){ if($request->ajax()){ $output = "". "Kontakt Navn". "Titel". "E-mail". "Tlf". "\"Update\"". "\"Delete\"". ""; $users = DB::table('contacts')->where('contactname', 'LIKE',$request->search.'%') ->orWhere('title','LIKE', $request->search.'%') ->orWhere('phone','LIKE', $request->search.'%') ->orWhere('email','LIKE',$request->search. '%')->get(); if(count($users) !== 0){ foreach ($users as $key => $user){ $output.=''. '' . $user->contactname . ''. '' . $user->title . ''. '' . $user->email . ''. '' . $user->phone .''. ' $user->id ]) . '">Update'. '
$user->id ]). '" class="w-100 nostyle">'. csrf_field(). method_field("delete"). ''. '
'. ''. ''; } }else{ $output.=''. 'Din søgning matchede ikke nogen personer'. ''. ''. ''. ''. ''. ''; } return Response($output); } } }