$semester->start)
{
$min_start=$semester->start;
}
if($max_end<$semester->end)
{
$max_end=$semester->end;
}
}
$outcomes = Outcome::where(function($query) use ($min_start)
{
$query->where('deactivation_date', '>=', $min_start)
->orWhere('deactivation_date', null);
})
->where('activation_date', '<=', $max_end)
->where(function($query2) use ($level)
{
$query2->where("level", $level+1)
->orWhere("level",3);
})
->orderBy('name', 'ASC')
->get();
$outcomeCount = Outcome::where(function($query) use ($min_start)
{
$query->where('deactivation_date', '>=', $min_start)
->orWhere('deactivation_date', null);
})
->where('activation_date', '<=', $max_end)
->where(function($query2) use ($level)
{
$query2->where("level",$level+1)
->orWhere("level",3);
})
->count();
foreach($outcomes as $outcome)
{
// var_dump($outcome->id);
// print "
";
$outcomes_attempted[$outcome->id]=$outcome->attempted($selected_semesters, $level);
$outcomes_achieved[$outcome->id]=$outcome->achieved($selected_semesters, $level);
}
$uhs_school_id = School::where('name', 'LIKE', '%UHS%')->first()->id;
$uhs_program_id = Program::where('name', 'LIKE', '%UHS%')->first()->id;
foreach ($outcomes as $outcome)
{
$achievedProgramsPerOutcome[$outcome->id]=0; // For each program with courses that do assessment
$attemptedProgramsPerOutcome[$outcome->id]=0; // For each program with courses that do assessment
foreach (Program::with(array('courses' => function($query){
// $query->whereNotNull('outcomes_attempted');
$query->where('code', '!=', 'TEST');
$query->whereIn('semester_id', Session::get('semesters_ids'));
}))->where('is_graduate', $level)->where('school_id', '!=', $uhs_school_id)->orderBy('name', 'asc')->get() as $program)
{
$achieved_outcomes_per_program[$program->id]=0;
$attempted_outcomes_per_program[$program->id]=0;
$participating_programs[$program->id]=(object)array('id'=>$program->id, 'name'=>$program->name, 'is_graduate'=> $program->is_graduate, 'school_id'=>$program->school_id);
// SELECT ac.id activity_criterion_id, ac.activity_id, ac.expected_student_score, ac.expected_percentage_students_achieving, co.program_id FROM activity_criterion ac, new_criteria c, activities a, objectives o, courses co where co.id=a.course_id and co.semester_id=13 and a.id=ac.activity_id and c.id = ac.criterion_id and o.id=c.objective_id and o.outcome_id = 2 order by program_id
$program_attempted_outcome=$program->attempted_outcome($outcome->id, $selected_semesters);
$attempted_outcomes_per_program[$program->id]+=$program_attempted_outcome;
// var_dump($program_attempted_outcome);
// exit();
if($program_attempted_outcome)
{
$program_achieved_outcome=$program->achieved_outcome($outcome->id, $selected_semesters);
$achieved_outcomes_per_program[$program->id]+=$program_achieved_outcome;
$attemptedProgramsPerOutcome[$outcome->id]+=$program_attempted_outcome;
// $attemptedProgramsPerOutcome[$outcome->id]+=1;
$achievedProgramsPerOutcome[$outcome->id]+=$program_achieved_outcome;
// $achieved_outcomes_per_program[$outcome->id]=$program->achieved_outcome($outcome->id, $selected_semesters);
// if($attempted_outcomes_per_program[$outcome->id]!=0 && 100.0*$achieved_outcomes_per_program[$outcome->id]/$attempted_outcomes_per_program[$outcome->id] >= $outcome->expected_outcome)
// {
// $achievedProgramsPerOutcome[$outcome->id]+=1;
// // $output[]= 'END OF PROGRAM: '.$program->name.'-'.json_encode($achievedProgramsPerOutcome);
// }
}
}
}
return array('outcomes'=>$outcomes,'outcomes_attempted'=>$outcomes_attempted, 'outcomes_achieved'=>$outcomes_achieved, 'attemptedProgramsPerOutcome'=>$attemptedProgramsPerOutcome, 'achievedProgramsPerOutcome'=>$achievedProgramsPerOutcome,'participating_programs'=>$participating_programs);
}
public function overview()
{
$selected_semesters = Semester::find(Session::get('semesters_ids'));
$subgraduado=$this->outcomes_semesters($selected_semesters,0);
$outcomes_subgrad=$subgraduado['outcomes'];
$undergrad_outcomes_achieved=$subgraduado['outcomes_achieved'];
$undergrad_outcomes_attempted=$subgraduado['outcomes_attempted'];
$attemptedUndergradProgramsPerOutcome=$subgraduado['attemptedProgramsPerOutcome'];
$achievedUndergradProgramsPerOutcome=$subgraduado['achievedProgramsPerOutcome'];
$participating_undergrad_programs=$subgraduado['participating_programs'];
$graduado=$this->outcomes_semesters($selected_semesters,1);
$outcomes_grad=$graduado['outcomes'];
$grad_outcomes_achieved=$graduado['outcomes_achieved'];
$grad_outcomes_attempted=$graduado['outcomes_attempted'];
$attemptedGradProgramsPerOutcome=$graduado['attemptedProgramsPerOutcome'];
$achievedGradProgramsPerOutcome=$graduado['achievedProgramsPerOutcome'];
$participating_grad_programs=$graduado['participating_programs'];
//Total amount of learning outcomes
// $outcomeCount = Outcome::withTrashed()->count();
// $selected_semester = Semester::find(Session::get('semesters_ids')[0]);
// $outcomes_subgrad = Outcome::where(function($query) use ($selected_semester)
// {
// $query->where('deactivation_date', '>=', $selected_semester->start)
// ->orWhere('deactivation_date', null);
// })
// ->where('activation_date', '<=', $selected_semester->end)
// ->where(function($query2)
// {
// $query2->where("level",1)
// ->orWhere("level",3);
// })
// ->orderBy('name', 'ASC')
// ->get();
// $outcomeCount_subgrad = Outcome::where(function($query) use ($selected_semester)
// {
// $query->where('deactivation_date', '>=', $selected_semester->start)
// ->orWhere('deactivation_date', null);
// })
// ->where('activation_date', '<=', $selected_semester->end)
// ->where(function($query2)
// {
// $query2->where("level",1)
// ->orWhere("level",3);
// })
// ->count();
//
// $outcomes_grad = Outcome::where(function($query) use ($selected_semester){$query->where('deactivation_date', '>=', $selected_semester->start)->orWhere('deactivation_date', null);})->where(function($query2){$query2->where("level",2)->orWhere("level",3);})->orderBy('name', 'ASC')->get();
// $outcomeCount_grad = Outcome::where(function($query) use ($selected_semester){$query->where('deactivation_date', '>=', $selected_semester->start)->orWhere('deactivation_date', null);})->where(function($query2){$query2->where("level",2)->orWhere("level",3);})->count();
// print($outcomeCount_subgrad);
// print($outcomeCount_grad);
// Id for excluding UHS from records
$uhs_school_id = School::where('name', 'LIKE', '%UHS%')->first()->id;
// $uhs_program_id = Program::where('name', 'LIKE', '%UHS%')->first()->id;
$schools = School::where('id', '!=', $uhs_school_id)->orderBy('name', 'asc')->get();
$title = 'Campus Overview';
/**
* Calculate campus wide outcome performance by counting the number of students
$undergrad_outcomes_attempted will have the number of criteria that was assessed in undergradute courses during the selected semester
$undergrad_outcomes_achieved will have the number of criteria that was assessed in undergradute courses during the selected semester
where the percentage of students that obtained a better or equal score than the expected_student_score established in the
activity_criterion table is greater or equal than the expected_percentage_students_achieving also established in the
activity_criterion table
*/
// foreach($outcomes_subgrad as $outcome)
// {
// $undergrad_outcomes_attempted[$outcome->id]=$outcome->attempted($selected_semester->id,0);
// $undergrad_outcomes_achieved[$outcome->id]=$outcome->achieved($selected_semester->id,0);
// }
// var_dump($undergrad_outcomes_attempted);
// print"
";
// var_dump($undergrad_outcomes_achieved);
// print"
";
// foreach($outcomes_grad as $outcome)
// {
// $grad_outcomes_attempted[$outcome->id]=$outcome->attempted($selected_semester->id,1);
// $grad_outcomes_achieved[$outcome->id]=$outcome->achieved($selected_semester->id,1);
// }
/**
* Calculate how many programs achieved and attempted each outcome
*/
// Number of programs that achieved a particular learning outcome
// $achievedUndergradProgramsPerOutcome = array_fill(1, $outcomeCount_subgrad, 0);
// Number of programs that attempted a particular learning outcome
// $attemptedUndergradProgramsPerOutcome = array_fill(1, $outcomeCount_subgrad, 0);
// Names of programs doing assessment
// Fetch programs with participation
// $participating_undergrad_programs = DB::table('VIEW_participating_programs')
// ->whereIn('semester_id', Session::get('semesters_ids'))
// ->where('is_graduate', 0)
// ->groupBy('id')
// ->orderBy('name', 'asc')
// ->get();
// $output = array();
/**
* Calculate how many undergrad programs achieved and attempted each outcome
*/
// foreach ($outcomes_subgrad as $outcome)
// {
// $achieved_outcomes_per_undergrad_program[$outcome->id]=0;
// $attempted_outcomes_per_undergrad_program[$outcome->id]=0;
// $achievedUndergradProgramsPerOutcome[$outcome->id]=0; // For each program with courses that do assessment
// $attemptedUndergradProgramsPerOutcome[$outcome->id]=0; // For each program with courses that do assessment
// foreach (Program::with(array('courses' => function($query){
// // $query->whereNotNull('outcomes_attempted');
// $query->where('code', '!=', 'TEST');
// $query->whereIn('semester_id', Session::get('semesters_ids'));
// }))->where('is_graduate', 0)->where('school_id', '!=', $uhs_school_id)->orderBy('name', 'asc')->get() as $program)
// {
// $participating_undergrad_programs[$program->id]=(object)array('id'=>$program->id, 'name'=>$program->name, 'is_graduate'=> $program->is_graduate, 'school_id'=>$program->school_id,'semestre_id',$selected_semester);
//
// // SELECT ac.id activity_criterion_id, ac.activity_id, ac.expected_student_score, ac.expected_percentage_students_achieving, co.program_id FROM activity_criterion ac, new_criteria c, activities a, objectives o, courses co where co.id=a.course_id and co.semester_id=13 and a.id=ac.activity_id and c.id = ac.criterion_id and o.id=c.objective_id and o.outcome_id = 2 order by program_id
// $program_attempted_outcome=$program->attempted_outcome($outcome->id, $selected_semester->id);
// $attempted_outcomes_per_undergrad_program[$outcome->id]+=$program_attempted_outcome;
// // var_dump($program_attempted_outcome);
// // exit();
// if($program_attempted_outcome)
// {
// $attemptedUndergradProgramsPerOutcome[$outcome->id]+=1;
// $achieved_outcomes_per_undergrad_program[$outcome->id]=$program->achieved_outcome($outcome->id, $selected_semester->id);
// if($attempted_outcomes_per_undergrad_program[$outcome->id]!=0 && 100.0*$achieved_outcomes_per_undergrad_program[$outcome->id]/$attempted_outcomes_per_undergrad_program[$outcome->id] >= $outcome->expected_outcome)
// {
// $achievedUndergradProgramsPerOutcome[$outcome->id]+=1;
// // $output[]= 'END OF PROGRAM: '.$program->name.'-'.json_encode($achievedUndergradProgramsPerOutcome);
// }
// }
// }
// }
// var_dump($attempted_outcomes_per_undergrad_program);
// print"
";
// var_dump($achieved_outcomes_per_undergrad_program);
// print"
";
// var_dump($attemptedUndergradProgramsPerOutcome);
// print"
";
// var_dump($achievedUndergradProgramsPerOutcome);
// print"
";
// exit();
/**
* Calculate how many grad programs achieved and attempted each outcome
$grad_outcomes_attempted will have the number of criteria that was assessed in gradute courses during the selected semester
$grad_outcomes_achieved will have the number of criteria that was assessed in gradute courses during the selected semester
where the percentage of students that obtained a better or equal score than the expected_student_score established in the
activity_criterion table is greater or equal than the expected_percentage_students_achieving also established in the
activity_criterion table
*/
// Names of programs doing assessment
// $participating_grad_programs = DB::table('VIEW_participating_programs')
// ->whereIn('semester_id', Session::get('semesters_ids'))
// ->where('is_graduate', 1)
// ->groupBy('id')
// ->orderBy('name', 'asc')
// ->get();
// foreach ($outcomes_grad as $outcome)
// {
// $achieved_outcomes_per_grad_program[$outcome->id]=0;
// $attempted_outcomes_per_grad_program[$outcome->id]=0;
// $achievedGradProgramsPerOutcome[$outcome->id]=0; // For each program with courses that do assessment
// $attemptedGradProgramsPerOutcome[$outcome->id]=0; // For each program with courses that do assessment
// foreach (Program::with(array('courses' => function($query){
// $query->whereNotNull('outcomes_attempted');
// $query->where('code', '!=', 'TEST');
// $query->whereIn('semester_id', Session::get('semesters_ids'));
// }))->where('is_graduate', 1)->where('school_id', '!=', $uhs_school_id)->orderBy('name', 'asc')->get() as $program)
// {
// $participating_grad_programs[$program->id]=(object)array('id'=>$program->id, 'name'=>$program->name, 'is_graduate'=> $program->is_graduate, 'school_id'=>$program->school_id,'semestre_id',$selected_semester);
// // SELECT ac.id activity_criterion_id, ac.activity_id, ac.expected_student_score, ac.expected_percentage_students_achieving, co.program_id FROM activity_criterion ac, new_criteria c, activities a, objectives o, courses co where co.id=a.course_id and co.semester_id=13 and a.id=ac.activity_id and c.id = ac.criterion_id and o.id=c.objective_id and o.outcome_id = 2 order by program_id
// $program_attempted_outcome=$program->attempted_outcome($outcome->id, $selected_semester->id);
// $attempted_outcomes_per_grad_program[$outcome->id]+=$program_attempted_outcome;
// // var_dump($attempted_outcomes_per_undergrad_program);
// // exit();
// if($program_attempted_outcome)
// {
// $attemptedGradProgramsPerOutcome[$outcome->id]+=1;
// $achieved_outcomes_per_grad_program[$outcome->id]=$program->achieved_outcome($outcome->id, $selected_semester->id);
// if($attempted_outcomes_per_grad_program[$outcome->id]!=0 && (float)$achieved_outcomes_per_grad_program[$outcome->id]/$attempted_outcomes_per_grad_program[$outcome->id]*100 >= $outcome->expected_outcome)
// {
// $achievedGradProgramsPerOutcome[$outcome->id]+=1;
// // $output[]= 'END OF PROGRAM: '.$program->name.'-'.json_encode($achievedUndergradProgramsPerOutcome);
// }
// }
// }
// }
// var_dump($grad_outcomes_attempted);
// print("
");
// var_dump($grad_outcomes_achieved);
// exit();
return View::make('local.managers.admins.overview', compact('title', 'schools', 'outcomes_subgrad', 'outcomes_grad', 'undergrad_outcomes_achieved', 'undergrad_outcomes_attempted', 'grad_outcomes_achieved', 'grad_outcomes_attempted', 'attemptedUndergradProgramsPerOutcome', 'participating_undergrad_programs', 'achievedUndergradProgramsPerOutcome', 'attemptedGradProgramsPerOutcome', 'participating_grad_programs', 'achievedGradProgramsPerOutcome'));
}
public function overview2()
{
// '''
//stucture of outcomes array:
//
// $outcome->id
// $outcome->name
// $outcome->semesters
//
// $outcome->semesters[i]->id
// $outcome->semesters[i]->code
// $outcome->semesters[i]->name
// $outcome->semesters[i]->tested
// $outcome->semesters[i]->achievers
// '''
$selected_semesters = Semester::find(Session::get('semesters_ids'));
$title = 'Overview2';
$semesters = DB::table('overview')
->join('semesters','semesters.id','=','overview.semester_id')
->select('semesters.name', 'semesters.code')
->orderBy('semesters.code', 'asc')
->groupBy('semesters.id')
->get();
$outcomes = DB::table('overview')
->join('outcomes','outcomes.id','=','overview.outcome_id')
->selectRaw('outcomes.name, overview.outcome_id as id, sum(overview.total_evaluated) as total_evaluated, sum(overview.total_achieved) as total_achieved')
->orderBy('outcomes.name', 'asc')
->groupBy('overview.outcome_id')
->get();
foreach ($outcomes as $outcome) {
$outcome->semesters = DB::table('overview')
->join('semesters','semesters.id','=','overview.semester_id')
->where('overview.outcome_id', $outcome->id)
->selectRaw('semesters.id, semesters.name, semesters.code, sum(overview.total_evaluated) as total_evaluated, sum(overview.total_achieved) as total_achieved')
->orderBy('semesters.code', 'asc')
->groupBy('overview.outcome_id')
->groupBy('overview.semester_id')
->get();
}
$filters = array();
$filters['school'] = DB::table('overview')
->join('programs','programs.id','=','overview.program_id')
->join('schools','schools.id','=','programs.school_id')
->select('schools.id','schools.name')
->orderBy('schools.name', 'asc')
->groupBy('schools.id')
->get();
$filters['program'] = DB::table('overview')
->join('programs','programs.id','=','overview.program_id')
->select('programs.id','programs.name')
->orderBy('programs.name', 'asc')
->groupBy('overview.program_id')
->get();
$filters['semester'] = DB::table('overview')
->join('semesters','semesters.id','=','overview.semester_id')
->select('semesters.id','semesters.name','semesters.code')
->orderBy('semesters.code', 'asc')
->groupBy('overview.semester_id')
->get();
$filters['year'] = DB::table('overview')//
->join('semesters','semesters.id','=','overview.semester_id')
->select('semesters.id','semesters.start')
->orderBy('semesters.code', 'asc')
->groupBy('overview.semester_id')
->get();
$filters['outcome'] = DB::table('overview')
->join('outcomes','outcomes.id','=','overview.outcome_id')
->select('outcomes.id','outcomes.name')
->orderBy('outcomes.name', 'asc')
->groupBy('overview.outcome_id')
->get();
$target = 0.70;
return View::make('local.managers.admins.overview2', compact('title','selected_semesters','outcomes','semesters','filters','target'));
}
// this is called when filters are changed
public function overview2_filter_results()
{
// selected filter data
$schools = Input::get('schools');
$programs = Input::get('programs');
$semesters = Input::get('semesters');
$years = Input::get('years');
$outcomes = Input::get('outcomes');
// make an array id's of schools selected. if All, use All available id's
if ($schools == array("0")){
$result = DB::table('overview')
->join('programs','programs.id','=','overview.program_id')
->join('schools','schools.id','=','programs.school_id')
->select('schools.id')
->orderBy('schools.name', 'asc')
->groupBy('schools.id')
->get();
$schools_id = array();
foreach ($result as $school) {
array_push($schools_id,$school->id);
}
}else {
$schools_id = array();
foreach ($schools as $school_id) {
array_push($schools_id,intval($school_id));
}
}
// make an array id's of programs selected. if All, use All available id's
if ($programs == array("0")){
$result = DB::table('overview')
->join('programs','programs.id','=','overview.program_id')
->select('programs.id')
->orderBy('programs.name', 'asc')
->groupBy('overview.program_id')
->get();
$programs_id = array();
foreach ($result as $program) {
array_push($programs_id,$program->id);
}
}else {
$programs_id = array();
foreach ($programs as $program_id) {
array_push($programs_id,intval($program_id));
}
}
// make an array id's of semesters selected. if All, use All available id's
if ($semesters == array("0")){
$result = DB::table('overview')
->join('semesters','semesters.id','=','overview.semester_id')
->select('semesters.id')
->orderBy('semesters.code', 'asc')
->groupBy('overview.semester_id')
->get();
$semesters_id = array();
foreach ($result as $semester) {
array_push($semesters_id,$semester->id);
}
}else {
$semesters_id = array();
foreach ($semesters as $semester_id) {
array_push($semesters_id,intval($semester_id));
}
}
// make an array id's of years selected. if All, use All available id's
if ($years == array("0")){
$result = DB::table('overview')//
->join('semesters','semesters.id','=','overview.semester_id')
->select('semesters.id')
->orderBy('semesters.code', 'asc')
->groupBy('overview.semester_id')
->get();
$years_id = array();
foreach ($result as $year) {
array_push($years_id,$year->id);
}
}else {
$years_id = array();
foreach ($years as $year_id) {
array_push($years_id,intval($year_id));
}
}
// make an array id's of outcomes selected. if All, use All available id's
if ($outcomes == array("0")){
$result = DB::table('overview')
->join('outcomes','outcomes.id','=','overview.outcome_id')
->select('outcomes.id')
->orderBy('outcomes.name', 'asc')
->groupBy('overview.outcome_id')
->get();
$outcomes_id = array();
foreach ($result as $outcome) {
array_push($outcomes_id,$outcome->id);
}
}else {
$outcomes_id = array();
foreach ($outcomes as $outcome_id) {
array_push($outcomes_id,intval($outcome_id));
}
}
// get data for graph
$semesters = DB::table('overview')
->join('programs','programs.id','=','overview.program_id')
->join('schools','schools.id','=','programs.school_id')
->join('semesters','semesters.id','=','overview.semester_id')
->join('outcomes','outcomes.id','=','overview.outcome_id')
->whereIn('schools.id',$schools_id)
->whereIn('programs.id',$programs_id)
->whereIn('semesters.id',$semesters_id)
// ->whereIn('years.id',$years_id)
->whereIn('outcomes.id',$outcomes_id)
->select('semesters.name', 'semesters.code')
->orderBy('semesters.code', 'asc')
->groupBy('semesters.id')
->get();
$outcomes = DB::table('overview')
->join('programs','programs.id','=','overview.program_id')
->join('schools','schools.id','=','programs.school_id')
->join('semesters','semesters.id','=','overview.semester_id')
->join('outcomes','outcomes.id','=','overview.outcome_id')
->whereIn('schools.id',$schools_id)
->whereIn('programs.id',$programs_id)
->whereIn('semesters.id',$semesters_id)
// ->whereIn('years.id',$years_id)
->whereIn('outcomes.id',$outcomes_id)
->selectRaw('outcomes.name, overview.outcome_id as id, sum(overview.total_evaluated) as total_evaluated, sum(overview.total_achieved) as total_achieved')
->orderBy('outcomes.name', 'asc')
->groupBy('overview.outcome_id')
->get();
foreach ($outcomes as $outcome) {
$outcome->semesters = DB::table('overview')
->join('programs','programs.id','=','overview.program_id')
->join('schools','schools.id','=','programs.school_id')
->join('semesters','semesters.id','=','overview.semester_id')
->join('outcomes','outcomes.id','=','overview.outcome_id')
->whereIn('schools.id',$schools_id)
->whereIn('programs.id',$programs_id)
->whereIn('semesters.id',$semesters_id)
// ->whereIn('years.id',$years_id)
->whereIn('outcomes.id',$outcomes_id)
->where('overview.outcome_id', $outcome->id)
->selectRaw('semesters.id, semesters.name, semesters.code, sum(overview.total_evaluated) as total_evaluated, sum(overview.total_achieved) as total_achieved')
->orderBy('semesters.code', 'asc')
->groupBy('overview.outcome_id')
->groupBy('overview.semester_id')
->get();
}
// get data for filters
$filters = array();
$filters['school'] = DB::table('overview')
->join('programs','programs.id','=','overview.program_id')
->join('schools','schools.id','=','programs.school_id')
->join('semesters','semesters.id','=','overview.semester_id')
->join('outcomes','outcomes.id','=','overview.outcome_id')
->whereIn('schools.id',$schools_id)
->whereIn('programs.id',$programs_id)
->whereIn('semesters.id',$semesters_id)
// ->whereIn('years.id',$years_id)
->whereIn('outcomes.id',$outcomes_id)
->select('schools.id','schools.name')
->orderBy('schools.name', 'asc')
->groupBy('schools.id')
->get();
$filters['program'] = DB::table('overview')
->join('programs','programs.id','=','overview.program_id')
->join('schools','schools.id','=','programs.school_id')
->join('semesters','semesters.id','=','overview.semester_id')
->join('outcomes','outcomes.id','=','overview.outcome_id')
->whereIn('schools.id',$schools_id)
// ->whereIn('programs.id',$programs_id)
->whereIn('semesters.id',$semesters_id)
// ->whereIn('years.id',$years_id)
->whereIn('outcomes.id',$outcomes_id)
->select('programs.id','programs.name')
->orderBy('programs.name', 'asc')
->groupBy('overview.program_id')
->get();
$filters['semester'] = DB::table('overview')
->join('programs','programs.id','=','overview.program_id')
->join('schools','schools.id','=','programs.school_id')
->join('semesters','semesters.id','=','overview.semester_id')
->join('outcomes','outcomes.id','=','overview.outcome_id')
->whereIn('schools.id',$schools_id)
->whereIn('programs.id',$programs_id)
// ->whereIn('semesters.id',$semesters_id)
// ->whereIn('years.id',$years_id)
->whereIn('outcomes.id',$outcomes_id)
->select('semesters.id','semesters.name','semesters.code')
->orderBy('semesters.code', 'asc')
->groupBy('overview.semester_id')
->get();
$filters['year'] = DB::table('overview')////////////////////////////////////////////
->join('programs','programs.id','=','overview.program_id')
->join('schools','schools.id','=','programs.school_id')
->join('semesters','semesters.id','=','overview.semester_id')
->join('outcomes','outcomes.id','=','overview.outcome_id')
->whereIn('schools.id',$schools_id)
->whereIn('programs.id',$programs_id)
->whereIn('semesters.id',$semesters_id)
// ->whereIn('years.id',$years_id)
->whereIn('outcomes.id',$outcomes_id)
->get();
$filters['outcome'] = DB::table('overview')
->join('programs','programs.id','=','overview.program_id')
->join('schools','schools.id','=','programs.school_id')
->join('semesters','semesters.id','=','overview.semester_id')
->join('outcomes','outcomes.id','=','overview.outcome_id')
->whereIn('schools.id',$schools_id)
->whereIn('programs.id',$programs_id)
->whereIn('semesters.id',$semesters_id)
// ->whereIn('years.id',$years_id)
// ->whereIn('outcomes.id',$outcomes_id)
->select('outcomes.id','outcomes.name')
->orderBy('outcomes.name', 'asc')
->groupBy('overview.outcome_id')
->get();
return array(
"semesters" => $semesters,
"outcomes_info" => $outcomes,
"filters" => $filters,
);
}
}