����JFIF��x�x����'
Server IP : 66.29.137.217 / Your IP : 18.216.70.76 Web Server : LiteSpeed System : Linux premium294.web-hosting.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64 User : gltevjme ( 1095) PHP Version : 7.0.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/gltevjme/./cbt.gltechlimited.com/app/Http/Controllers/User/ |
Upload File : |
<?php namespace App\Http\Controllers\User; use App\Http\Controllers\Controller; use App\Models\ExamSchedule; use App\Models\ExamType; use App\Models\SubCategory; use App\Settings\LocalizationSettings; use App\Transformers\Platform\ExamCardTransformer; use App\Transformers\Platform\ExamScheduleCardTransformer; use App\Transformers\Platform\ExamTypeTransformer; use Illuminate\Database\Eloquent\Builder; use Illuminate\Support\Facades\Cookie; use Inertia\Inertia; class ExamDashboardController extends Controller { private LocalizationSettings $localizationSettings; public function __construct(LocalizationSettings $localizationSettings) { $this->middleware(['role:guest|student|employee', 'verify.syllabus']); $this->localizationSettings = $localizationSettings; } /** * User's Exam Dashboard * * @return \Inertia\Response */ public function exam() { $userGroups = auth()->user()->userGroups()->pluck('id'); $category = auth()->user()->selectedSyllabus(); // Fetch exams scheduled for current user via user groups $schedules = ExamSchedule::whereHas('userGroups', function (Builder $query) use ($userGroups) { $query->whereIn('user_group_id', $userGroups); })->whereHas('exam', function (Builder $query) use ($category) { $query->where('sub_category_id', '=', $category->id); })->with(['exam' => function($builder) { $builder->with(['subCategory:id,name', 'examType:id,name']); }])->orderBy('end_date', 'asc')->active()->limit(4)->get(); // Fetch public exams by exam type $examTypes = ExamType::active()->orderBy('name')->get(); return Inertia::render('User/ExamDashboard', [ 'examSchedules' => fractal($schedules, new ExamScheduleCardTransformer())->toArray()['data'], 'examTypes' => fractal($examTypes, new ExamTypeTransformer())->toArray()['data'], 'subscription' => request()->user()->hasActiveSubscription($category->id, 'exams') ]); } /** * Live Exams Screen * * @return \Inertia\Response */ public function liveExams() { $category = auth()->user()->selectedSyllabus(); return Inertia::render('User/LiveExams', [ 'subscription' => request()->user()->hasActiveSubscription($category->id, 'exams') ]); } /** * Fetch live exams api endpoint * * @return \Illuminate\Http\JsonResponse */ public function fetchLiveExams() { $userGroups = auth()->user()->userGroups()->pluck('id'); $category = auth()->user()->selectedSyllabus(); // Fetch exams scheduled for current user via user groups $schedules = ExamSchedule::whereHas('userGroups', function (Builder $query) use ($userGroups) { $query->whereIn('user_group_id', $userGroups); })->whereHas('exam', function (Builder $query) use ($category) { $query->where('sub_category_id', '=', $category->id); })->with(['exam' => function($builder) { $builder->with(['subCategory:id,name', 'examType:id,name']); }])->orderBy('end_date', 'asc')->active()->paginate(10); return response()->json([ 'schedules' => fractal($schedules, new ExamScheduleCardTransformer())->toArray() ], 200); } /** * Get Exams by type page * * @param ExamType $type * @return \Inertia\Response */ public function examsByType(ExamType $type) { $category = auth()->user()->selectedSyllabus(); return Inertia::render('User/ExamsByType', [ 'type' => $type, 'subscription' => request()->user()->hasActiveSubscription($category->id, 'exams') ]); } /** * Fetch exams by type * * @param ExamType $type * @return \Illuminate\Http\JsonResponse */ public function fetchExamsByType(ExamType $type) { $subCategory = auth()->user()->selectedSyllabus(); // Fetch public exams by exam type $exams = $type->exams()->has('questions') ->where('sub_category_id', '=', $subCategory->id) ->orderBy('exams.is_paid', 'asc') ->with(['subCategory:id,name', 'examType:id,name']) ->isPublic()->published() ->paginate(10); return response()->json([ 'exams' => fractal($exams, new ExamCardTransformer())->toArray(), ], 200); } }