From 6067d35b688d67721dec1474355bd8e833e3f552 Mon Sep 17 00:00:00 2001 From: Collins Kiplangat Rono Date: Sun, 12 Nov 2023 17:39:24 +0300 Subject: [PATCH] added stats for student ages (#323) --- app/Http/Controllers/ReportController.php | 59 +++++- config/age.php | 10 + resources/views/reports/age.blade.php | 141 +++++++++++++ .../base/inc/sidebar_content.blade.php | 191 +++++++++++------- routes/web.php | 1 + 5 files changed, 328 insertions(+), 74 deletions(-) create mode 100644 config/age.php create mode 100644 resources/views/reports/age.blade.php diff --git a/app/Http/Controllers/ReportController.php b/app/Http/Controllers/ReportController.php index 1cae9018..ed007fd4 100644 --- a/app/Http/Controllers/ReportController.php +++ b/app/Http/Controllers/ReportController.php @@ -2,15 +2,16 @@ namespace App\Http\Controllers; +use Carbon\Carbon; +use App\Models\Year; use App\Models\Config; -use App\Models\Partner; use App\Models\Period; -use App\Models\Year; +use App\Models\Partner; +use App\Models\Student; use App\Services\DateRange; +use Illuminate\Http\Request; use App\Services\StatService; use App\Traits\PeriodSelection; -use Carbon\Carbon; -use Illuminate\Http\Request; class ReportController extends Controller { @@ -61,7 +62,7 @@ public function external(Request $request) $year_data = []; $years = []; - if (! (property_exists($request, 'period') && $request->period !== null)) { + if (!(property_exists($request, 'period') && $request->period !== null)) { $startperiod = Period::find(Config::where('name', 'first_external_period')->first()->value ?? Period::first()->id); } else { $startperiod = Period::find($request->period); @@ -270,6 +271,52 @@ public function genderReport(Request $request) ]); } + public function ageReport() + { + $ages = app('config')->get('age'); + + $all_students = Student::all(); //Fetch all students + $ages_of_all_students = []; //Initiate an array to add all student ages + + foreach ($all_students as $single_student) { + $age_of_each_student = Carbon::parse($single_student->birthdate)->age; + array_push($ages_of_all_students, $age_of_each_student); //add every age to the ages_of_all_students array + + } + + $labels = []; // This will contain the labels to be interpolated in the bar graph report + $data = []; // This will contain the data to be interpolated in the bar graph report + + $counts = array_fill_keys(array_keys($ages), 0); + // Initialize an array to store counts for each range + + foreach ($ages_of_all_students as $value) { + // Iterate through the values and count them in the specified ranges + foreach ($ages as $range => $limits) { + if ($value >= $limits[0] && $value <= $limits[1]) { + $counts[$range]++; + break; // No need to check other ranges once a match is found + } + } + } + + foreach ($counts as $range => $count) { + array_push($labels, $range); + array_push($data, $count); + // Add range and count from env to the labels and data arrays + } + + return view('reports.age')->with( + [ + 'ages' => $ages, + 'ages_of_all_students' => $ages_of_all_students, + 'labels' => $labels, + 'data' => $data, + ] + + ); + } + /** * Show the enrollment numbers per rhythm. */ @@ -344,7 +391,7 @@ public function levels(Request $request) private function getStartperiod(Request $request) { - if (! (property_exists($request, 'period') && $request->period !== null)) { + if (!(property_exists($request, 'period') && $request->period !== null)) { $startperiod = Period::find(Config::where('name', 'first_period')->first()->value); } else { $startperiod = Period::find($request->period); diff --git a/config/age.php b/config/age.php new file mode 100644 index 00000000..ff2d3914 --- /dev/null +++ b/config/age.php @@ -0,0 +1,10 @@ + [0, 6], + '7-12' => [7, 12], + '8-14' => [8, 14], + '15-20' => [15, 20], + '21+' => [21, PHP_INT_MAX], + +]; diff --git a/resources/views/reports/age.blade.php b/resources/views/reports/age.blade.php new file mode 100644 index 00000000..de70984a --- /dev/null +++ b/resources/views/reports/age.blade.php @@ -0,0 +1,141 @@ +@extends('backpack::blank') + +@section('header') +
+

+ {{ __('Students by age') }} +

+
+@endsection + +@section('content') +
+ + + +
+
+
+ +
+
+
+ +
+
+ + +
+ + + + + @foreach ($ages as $key => $value) + + @endforeach + + + + + + + + + + @foreach ($ages as $key => $value) + @php + $count_of_ages_in_range = 0; + + for ($i = 0; $i < sizeof($ages_of_all_students); $i++) { + if ($ages_of_all_students[$i] >= $value[0] && $ages_of_all_students[$i] <= $value[1]) { + $count_of_ages_in_range++; + } + } + @endphp + + @endforeach + + + + + +
{{ $key }} years
{{ $count_of_ages_in_range }}
+
+
+
+ +
+@endsection + + +@section('before_scripts') +@endsection + + +@section('after_scripts') + + + + + + + + + + + + + + +@endsection diff --git a/resources/views/vendor/backpack/base/inc/sidebar_content.blade.php b/resources/views/vendor/backpack/base/inc/sidebar_content.blade.php index 840e2475..4583a9f7 100644 --- a/resources/views/vendor/backpack/base/inc/sidebar_content.blade.php +++ b/resources/views/vendor/backpack/base/inc/sidebar_content.blade.php @@ -1,19 +1,27 @@ - + -@if(backpack_user()->hasRole(['admin', 'secretary'])) +@if (backpack_user()->hasRole(['admin', 'secretary'])) - - @if (config('settings.external_courses_enabled')) - - @endif + + @if (config('settings.external_courses_enabled')) + + @endif - - - - - + + + + + @@ -34,10 +42,12 @@ @if (isset($teachers) && $teachers->count() > 0) + @endforeach + @endif @endif @@ -56,77 +66,121 @@ @endif -@if(backpack_user()->hasRole('admin')) +@if (backpack_user()->hasRole('admin')) - - - + + + @endif -@if(backpack_user()->hasRole(['admin', 'manager']) || backpack_user()->hasPermissionTo('reports.view')) +@if (backpack_user()->hasRole(['admin', 'manager']) || backpack_user()->hasPermissionTo('reports.view')) - - - @if (config('settings.external_courses_enabled')) - - @endif + + + + + + + + + + + @if (config('settings.external_courses_enabled')) + + @endif @endif -@if(backpack_user()->hasRole(['admin', 'secretary'])) +@if (backpack_user()->hasRole(['admin', 'secretary'])) -