File: //var/www/html/orbidirectory.com/app/Http/Controllers/FaqController.php
<?php
namespace App\Http\Controllers;
use App\Models\Faq;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Validator;
use Yajra\DataTables\DataTables;
class FaqController extends Controller
{
public function index(Request $request)
{
if ($request->ajax()) {
$query = Faq::query();
$data = $query->get();
$count_total = Faq::count();
$count_filter = $query->count();
return DataTables::of($data)
->addColumn('question', function ($row) {
return $row->question;
})
->addColumn('answer', function ($row) {
return $row->answer;
})
->addColumn('status', function ($row) {
return $row->status == 0 ? 'Active' : 'Inactive';
})
->addColumn('action', function ($row) {
return view('admin.faq.partially.delete', compact('row'));
})
->rawColumns(['action'])
->with([
"recordsTotal" => $count_total,
"recordsFiltered" => $count_filter,
])
->make(true);
}
return view('admin.faq.index');
}
public function create()
{
return view('admin.faq.create');
}
public function store(Request $request)
{
$validator = Validator::make($request->all(), [
'question' => 'required',
'answer' => 'required',
]);
if ($validator->fails()) {
return redirect()->back()->withErrors($validator)->withInput();
}
$faq = new Faq();
$faq->question = $request->question;
$faq->answer = $request->answer;
$faq->status = $request->status;
$faq->save();
return redirect()->route('faq.index')->with('success', 'Faq added Successfully');
}
public function edit($id)
{
$faq = Faq::find($id);
return view('admin.faq.edit', compact('faq'));
}
public function update(Request $request, $id)
{
$validator = Validator::make($request->all(), [
'question' => 'required',
'answer' => 'required',
]);
if ($validator->fails()) {
return redirect()->back()->withErrors($validator)->withInput();
}
$faq = Faq::find($id);
if (isset($faq)) {
$faq->question = $request->question;
$faq->answer = $request->answer;
$faq->status = $request->status;
$faq->save();
return redirect()->route('faq.index')->with('success', 'Faq updated successfully!');
}
}
public function destroy(string $id)
{
$faq = Faq::find($id);
if (isset($faq)) {
$faq->Delete();
return redirect()->back()->with('success', 'Faq has been deleted successfully.');
} else {
return back()->with('error', 'Faq not found.');
}
}
}