<?php namespace App\Http\Controllers; use App\Models\Faq; use App\Repositories\Faqs\FaqsInterface; use App\Services\BootstrapTableService; use App\Services\CachingService; use App\Services\ResponseService; use Illuminate\Http\Request; use Illuminate\Http\Response; use Illuminate\Support\Facades\Validator; use Throwable; class FaqController extends Controller { private FaqsInterface $faqs; private CachingService $cache; public function __construct(FaqsInterface $faqs, CachingService $cache) { $this->faqs = $faqs; $this->cache = $cache; } public function index() { ResponseService::noAnyPermissionThenRedirect(['faqs-list', 'faqs-create']); return view('faqs.index'); } public function store(Request $request) { // ResponseService::noPermissionThenRedirect('faqs-create'); $validator = Validator::make($request->all(), [ 'title' => 'required', 'description' => 'required', ]); if ($validator->fails()) { ResponseService::errorResponse($validator->errors()->first()); } try { $this->faqs->create($request->all()); $this->cache->removeSystemCache(config('constants.CACHE.SYSTEM.FAQS')); ResponseService::successResponse('Data Stored Successfully'); } catch (Throwable $e) { ResponseService::logErrorResponse($e, "Faq Controller -> Store Method"); ResponseService::errorResponse(); } } public function show($id) { ResponseService::noPermissionThenRedirect('faqs-list'); $offset = request('offset', 0); $limit = request('limit', 10); $sort = request('sort', 'id'); $order = request('order', 'DESC'); $search = request('search'); $sql = $this->faqs->builder() ->when($search, function ($query) use ($search) { $query->where(function ($query) use ($search) { $query->where('id', 'LIKE', "%$search%") ->orwhere('title', 'LIKE', "%$search%") ->orwhere('description', 'LIKE', "%$search%"); }); }); $total = $sql->count(); if ($offset >= $total && $total > 0) { $lastPage = floor(($total - 1) / $limit) * $limit; // calculate last page offset $offset = $lastPage; } $sql->orderBy($sort, $order)->skip($offset)->take($limit); $res = $sql->get(); $bulkData = array(); $bulkData['total'] = $total; $rows = array(); $no = 1; foreach ($res as $row) { $operate = BootstrapTableService::editButton(route('faqs.update', $row->id)); $operate .= BootstrapTableService::deleteButton(route('faqs.destroy', $row->id)); $tempRow = $row->toArray(); $tempRow['no'] = $no++; $tempRow['operate'] = $operate; $rows[] = $tempRow; } $bulkData['rows'] = $rows; return response()->json($bulkData); } public function update(Request $request, $id) { ResponseService::noPermissionThenSendJson('faqs-edit'); $validator = Validator::make($request->all(), [ 'title' => 'required', 'description' => 'required', ]); if ($validator->fails()) { ResponseService::errorResponse($validator->errors()->first()); } try { $this->faqs->update($id, $request->all()); $this->cache->removeSystemCache(config('constants.CACHE.SYSTEM.FAQS')); ResponseService::successResponse('Data Updated Successfully'); } catch (Throwable $e) { ResponseService::logErrorResponse($e, "Faq Controller -> Update Method"); ResponseService::errorResponse(); } } public function destroy($id) { ResponseService::noPermissionThenSendJson('faqs-delete'); try { $this->faqs->deleteById($id); ResponseService::successResponse('Data Deleted Successfully'); } catch (Throwable $e) { ResponseService::logErrorResponse($e, "Faq Controller -> Destroy Method"); ResponseService::errorResponse(); } } }