����JFIF��x�x����'
Server IP : 66.29.137.217 / Your IP : 3.147.2.160 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 /** * File name: DashboardController.php * Last modified: 18/07/21, 3:59 PM * Author: NearCraft - https://codecanyon.net/user/nearcraft * Copyright (c) 2021 */ namespace App\Http\Controllers\User; use App\Http\Controllers\Controller; use App\Models\ExamSchedule; use App\Models\PracticeSession; use App\Models\QuizSchedule; use App\Models\SubCategory; use App\Settings\LocalizationSettings; use App\Transformers\Platform\ExamScheduleCalendarTransformer; use App\Transformers\Platform\PracticeSessionCardTransformer; use App\Transformers\Platform\QuizScheduleCalendarTransformer; use Carbon\Carbon; use Illuminate\Database\Eloquent\Builder; use Illuminate\Database\Eloquent\ModelNotFoundException; use Illuminate\Support\Facades\Cookie; use Inertia\Inertia; class DashboardController extends Controller { private LocalizationSettings $localizationSettings; public function __construct(LocalizationSettings $localizationSettings) { $this->middleware(['role:guest|student|employee', 'verify.syllabus']); $this->localizationSettings = $localizationSettings; } /** * User's Main Dashboard * * @return \Inertia\Response */ public function index() { $userGroups = auth()->user()->userGroups()->pluck('id'); $minDate = Carbon::today()->timezone($this->localizationSettings->default_timezone); $maxDate = Carbon::today()->addMonths(1)->endOfMonth()->timezone($this->localizationSettings->default_timezone); $subCategory = auth()->user()->selectedSyllabus(); // Fetch quizzes scheduled for current user via user groups $quizSchedules = QuizSchedule::whereHas('userGroups', function (Builder $query) use ($userGroups) { $query->whereIn('user_group_id', $userGroups); })->whereHas('quiz', function (Builder $query) use ($subCategory) { $query->where('sub_category_id', $subCategory->id); })->with('quiz')->orderBy('end_date', 'asc')->active()->limit(4)->get(); // Fetch exams scheduled for current user via user groups $examSchedules = ExamSchedule::whereHas('userGroups', function (Builder $query) use ($userGroups) { $query->whereIn('user_group_id', $userGroups); })->whereHas('exam', function (Builder $query) use ($subCategory) { $query->where('sub_category_id', $subCategory->id); })->with('exam')->orderBy('end_date', 'asc')->active()->limit(4)->get(); // Fetch current user in-completed practice sessions $practiceSessions = PracticeSession::with(['practiceSet' => function($query) { $query->with('skill:id,name'); }])->whereHas('practiceSet', function (Builder $query) use ($subCategory) { $query->where('sub_category_id', $subCategory->id); })->where('user_id', auth()->user()->id)->pending() ->orderBy('updated_at', 'desc')->limit(1)->get(); return Inertia::render('User/Dashboard', [ 'scheduleCalendar' => array_merge(fractal($quizSchedules, new QuizScheduleCalendarTransformer())->toArray()['data'], fractal($examSchedules, new ExamScheduleCalendarTransformer())->toArray()['data']), 'practiceSessions' => fractal($practiceSessions, new PracticeSessionCardTransformer())->toArray()['data'], 'minDate' => $minDate, 'maxDate' => $maxDate, ]); } }