����JFIF��x�x����'
Server IP : 66.29.137.217 / Your IP : 18.218.195.15 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\QuizSchedule; use App\Models\QuizType; use App\Models\SubCategory; use App\Settings\LocalizationSettings; use App\Transformers\Platform\QuizCardTransformer; use App\Transformers\Platform\QuizScheduleCardTransformer; use App\Transformers\Platform\QuizTypeTransformer; use Illuminate\Database\Eloquent\Builder; use Illuminate\Support\Facades\Cookie; use Inertia\Inertia; class QuizDashboardController extends Controller { private LocalizationSettings $localizationSettings; public function __construct(LocalizationSettings $localizationSettings) { $this->middleware(['role:guest|student|employee', 'verify.syllabus']); $this->localizationSettings = $localizationSettings; } /** * User's Quiz Dashboard * * @return \Inertia\Response */ public function quiz() { $userGroups = auth()->user()->userGroups()->pluck('id'); $category = auth()->user()->selectedSyllabus(); // Fetch quizzes scheduled for current user via user groups $schedules = QuizSchedule::whereHas('userGroups', function (Builder $query) use ($userGroups) { $query->whereIn('user_group_id', $userGroups); })->whereHas('quiz', function (Builder $query) use ($category) { $query->where('sub_category_id', '=', $category->id); })->with(['quiz' => function($builder) { $builder->with(['subCategory:id,name', 'quizType:id,name']); }])->orderBy('end_date', 'asc')->active()->limit(4)->get(); // Fetch public quizzes by quiz type $quizTypes = QuizType::active()->orderBy('name')->get(); return Inertia::render('User/QuizDashboard', [ 'quizSchedules' => fractal($schedules, new QuizScheduleCardTransformer())->toArray()['data'], 'quizTypes' => fractal($quizTypes, new QuizTypeTransformer())->toArray()['data'], 'subscription' => request()->user()->hasActiveSubscription($category->id, 'quizzes') ]); } /** * Live Quizzes Screen * * @return \Inertia\Response */ public function liveQuizzes() { $category = auth()->user()->selectedSyllabus(); return Inertia::render('User/LiveQuizzes', [ 'subscription' => request()->user()->hasActiveSubscription($category->id, 'quizzes') ]); } /** * Fetch live quizzes api endpoint * * @return \Illuminate\Http\JsonResponse */ public function fetchLiveQuizzes() { $userGroups = auth()->user()->userGroups()->pluck('id'); $category = auth()->user()->selectedSyllabus(); // Fetch quizzes scheduled for current user via user groups $schedules = QuizSchedule::whereHas('userGroups', function (Builder $query) use ($userGroups) { $query->whereIn('user_group_id', $userGroups); })->whereHas('quiz', function (Builder $query) use ($category) { $query->where('sub_category_id', '=', $category->id); })->with(['quiz' => function($builder) { $builder->with(['subCategory:id,name', 'quizType:id,name']); }])->orderBy('end_date', 'asc')->active()->paginate(10); return response()->json([ 'schedules' => fractal($schedules, new QuizScheduleCardTransformer())->toArray() ], 200); } /** * Get Quizzes by type page * * @param QuizType $type * @return \Inertia\Response */ public function quizzesByType(QuizType $type) { $category = auth()->user()->selectedSyllabus(); return Inertia::render('User/QuizzesByType', [ 'type' => $type, 'subscription' => request()->user()->hasActiveSubscription($category->id, 'quizzes') ]); } /** * Fetch quizzes by type * * @param QuizType $type * @return \Illuminate\Http\JsonResponse */ public function fetchQuizzesByType(QuizType $type) { $subCategory = auth()->user()->selectedSyllabus(); // Fetch public quizzes by quiz type $quizzes = $type->quizzes()->has('questions') ->where('sub_category_id', '=', $subCategory->id) ->orderBy('quizzes.is_paid', 'asc') ->with(['subCategory:id,name', 'quizType:id,name']) ->isPublic()->published() ->paginate(10); return response()->json([ 'quizzes' => fractal($quizzes, new QuizCardTransformer())->toArray(), ], 200); } }