Nenhuma descrição

Outcome.php 38KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895
  1. <?php
  2. use Illuminate\Database\Eloquent\SoftDeletingTrait;
  3. class Outcome extends Eloquent
  4. {
  5. use SoftDeletingTrait;
  6. protected $dates = ['deleted_at'];
  7. protected $fillable = array('name', 'definition');
  8. protected $appends = array("annual_objectives");
  9. //dirty code, this belongs to annual plan, but outcome has the important data
  10. public function getExpectedTargetAttribute()
  11. {
  12. if (isset($this->semester_id) && isset($this->program_id)) {
  13. $expected_target = DB::table("target_outcomes_program")
  14. ->where('program_id', $this->program_id)
  15. ->where('semester_id', $this->semester_id)
  16. ->first();
  17. if ($expected_target != null) {
  18. return $expected_target->expected_target;
  19. } else return "Go to Annual Plan and define a target for learning outcome";
  20. }
  21. Log::info("PApi rip chabau");
  22. return null;
  23. }
  24. //Dirty code sort of, la accion transformadora es para el programa, ppero esta bajo el dominio
  25. //tecnicamente esto es hasta del annual plan, pero na, outcomes bajo el annual plan van a tener
  26. // este atributo
  27. //program_transformative_actions
  28. public function getProgramTransformativeActionsAttribute()
  29. {
  30. /*$transformative_actions = DB::table('transformative_typ_outcome')
  31. ->where('typ_semester_outcome_id', $this->typ_semester_outcome_id)
  32. ->get();
  33. $trans_actions = [];
  34. foreach ($transformative_actions as $trans) {
  35. $ta = TransformativeAction::where('id', $trans->trans_id)->first();
  36. $ta->setAttribute('semester_id', $this->semester_id);
  37. $trans_actions[] = $ta;
  38. }
  39. return $trans_actions;*/
  40. return TransformativeAction::join('transformative_typ_outcome', 'transformative_typ_outcome.trans_id', '=', 'transformative_actions.id')
  41. ->where('typ_semester_outcome_id', $this->typ_semester_outcome_id)
  42. ->select('transformative_actions.*', DB::raw("{$this->semester_id} as semester_id"))
  43. ->get();
  44. }
  45. public function getCommentsAttribute()
  46. {
  47. return DB::table('typ_outcome_report_comments')
  48. ->where('typ_semester_outcome_id', $this->typ_semester_outcome_id)
  49. ->get();
  50. }
  51. // Son los resultados de los estudiantes por dominio, devuelve el percent.
  52. public function getStudentPerformanceAttribute()
  53. {
  54. //create Counter for students
  55. $whole_dict = [];
  56. foreach ($this->annual_objectives as $objective) {
  57. foreach ($objective->grouped_annual_course as $course_code) {
  58. $course_code->grouped = 1;
  59. foreach ($course_code->student_report_for_outcome as $student) {
  60. //If is not defined, define
  61. if (!isset($whole_dict[$student->student_id])) {
  62. $whole_dict[$student->student_id] = array(
  63. 'student' => $student->student_id,
  64. 'criteria_attempted' => 0,
  65. 'criteria_achieved' => 0
  66. );
  67. }
  68. $whole_dict[$student->student_id]["criteria_attempted"] += $student->criteria_attempted;
  69. $whole_dict[$student->student_id]["criteria_achieved"] += $student->criteria_achieved;
  70. }
  71. }
  72. }
  73. $students_achieved = 0;
  74. $students_attempted = 0;
  75. Log::info('Outcome_content');
  76. Log::info($whole_dict);
  77. foreach ($whole_dict as $student) {
  78. if ($student['criteria_attempted']) {
  79. $students_attempted += 1;
  80. $percentage = (($student['criteria_achieved'] / $student['criteria_attempted']) * 100);
  81. if ($percentage >= $this->expected_outcome) {
  82. $students_achieved += 1;
  83. }
  84. }
  85. }
  86. if ($students_attempted != 0)
  87. return round(($students_achieved / $students_attempted) * 100, 2);
  88. else
  89. return "N/A";
  90. /*
  91. if (course_code.criteria.length) {
  92. $.each(course_code.students, function(index, student) {
  93. if (wholeDict[student.student_id] === undefined) {
  94. wholeDict[student.student_id] = {
  95. 'student': student.student_id,
  96. 'criteria_attempted': 0,
  97. 'criteria_achieved': 0
  98. }
  99. }
  100. wholeDict[student.student_id][
  101. "criteria_attempted"
  102. ] += student
  103. .criteria_attempted;
  104. wholeDict[student.student_id][
  105. "criteria_achieved"
  106. ] += student
  107. .criteria_achieved;
  108. });
  109. $.each(wholeDict, function(key, dict) {
  110. if (dict.criteria_attempted) {
  111. students_attempted += 1;
  112. percentage = ((dict.criteria_achieved / dict.criteria_attempted) * 100).toFixed(
  113. 2);
  114. if (parseFloat(percentage) >= parseFloat(outcome.expected_outcome)) {
  115. achieved = "Yes"
  116. students_achieved += 1;
  117. } else achieved = "No"
  118. } else {
  119. percentage = "N/A"
  120. achieved = "N/A"
  121. }
  122. tableStudent.row.add([
  123. dict.student,
  124. dict.criteria_attempted,
  125. dict.criteria_achieved,
  126. percentage,
  127. achieved
  128. ]);
  129. })
  130. */
  131. }
  132. public function criteria()
  133. {
  134. return $this->hasManyThrough('Criterion', 'Objective')->orderBy('name');
  135. }
  136. public function fetchObjectivesReport($semester_id, $program_id, $with_model = false)
  137. {
  138. /*$objectives = DB::table('typ_semester_outcome')
  139. ->join('typ_semester_objectives', 'typ_semester_objectives.typ_semester_outcome_id', '=', 'typ_semester_outcome.id')
  140. ->join('objectives', 'objectives.id', '=', 'typ_semester_objectives.objective_id')
  141. ->join("typ_program", 'typ_program.id', '=', 'typ_semester_outcome.typ_program_id')
  142. ->where('typ_semester_outcome.semester_id', $semester_id)
  143. ->where('typ_program.program_id', $program_id)
  144. ->where('typ_semester_outcome.outcome_id', $this->id)
  145. ->select('objectives.*')
  146. ->get();*/
  147. $objectives = DB::table('objectives')
  148. ->join('typ_semester_objectives', 'typ_semester_objectives.objective_id', '=', 'objectives.id')
  149. ->join('typ_semester_outcome', 'typ_semester_outcome.id', '=', 'typ_semester_objectives.typ_semester_outcome_id')
  150. ->join('typ_program', 'typ_program.id', '=', 'typ_semester_outcome.typ_program_id')
  151. ->where('semester_id', $semester_id)
  152. ->where('program_id', $program_id)
  153. ->where('outcome_id', $this->id)
  154. ->select('objectives.id as objective_id', 'objectives.text', 'typ_semester_objectives.id as typ_semester_objective_id', 'program_id', 'semester_id')
  155. ->distinct();
  156. // Log::info('agooooo me');
  157. // Log::info($objectives->toSql());exit();
  158. //Log::info('semester_program_outcome' . $semester_id . ',' . $program_id . ',' . $this->id);
  159. if ($with_model) {
  160. //Log::info("Acho aqui estamos en with_model");
  161. $objective_id = $objectives->lists('objective_id');
  162. $typ_semester_objective_ids = $objectives->lists('typ_semester_objective_id');
  163. //$program_id = $objectives->lists('program_id');
  164. //$semester_id = $objectives ->lists('semester_id');
  165. $objectives = Objective::whereIn("objectives.id", $objective_id);
  166. //Log::info($objective_id);
  167. //Log::info(array($objectives));
  168. foreach ($objectives as $i => $o) {
  169. Log::info("entramos aqui tambien?");
  170. $o->setAttribute("typ_semester_objective_id", $typ_semester_objective_ids[$i]);
  171. $o->setAttribute("program_id", $program_id);
  172. $o->setAttribute("semester_id", $semester_id);
  173. }
  174. return $objectives;
  175. }
  176. // Log::info('agooooo me');
  177. $objectives_result=$objectives->get();
  178. Log::info('En fetchObjectivesReport'.json_encode($objectives_result)); //exit();
  179. return $objectives_result;
  180. // return $objectives;
  181. }
  182. //Intento de get objectives pareados en un plan
  183. public function getAnnualObjectivesAttribute()
  184. {
  185. if (isset($this->typ_semester_outcome_id)) {
  186. /*Log::info('estamos aqui');
  187. $objectives = DB::table("typ_semester_objectives")
  188. ->join('objectives', 'objectives.id', '=', 'typ_semester_objectives.objective_id')
  189. ->where('typ_semester_outcome_id', $this->typ_semester_outcome_id)
  190. ->select('typ_semester_objectives.id as typ_semester_objective_id', 'objectives.id as objective_id')
  191. ->get();
  192. //$objectives_id = $objectives->lists('objective_id');
  193. //$typ_semester_objective_ids = $objectives->lists('typ_semester_objective_id');
  194. //$program_id = $objectives->lists('program_id');
  195. //$semester_id = $objectives ->lists('semester_id');
  196. //Log::info($this->typ_semester_outcome_id);
  197. //Log::info($objectives_id);
  198. $objectives_list = []; // Objective::whereIn("id", $objectives_id)->get();
  199. foreach ($objectives as $i => $ob) {
  200. $o = Objective::find($ob->objective_id);
  201. //Log::info("entramos aqui tambien?");
  202. $o->setAttribute("typ_semester_objective_id", $ob->typ_semester_objective_id); //$typ_semester_objective_ids[$i]);
  203. $o->setAttribute("semester_id", $this->semester_id);
  204. $o->setAttribute('program_id', $this->program_id);
  205. $objectives_list[] = $o;
  206. }
  207. return $objectives_list;*/
  208. return Objective::join("typ_semester_objectives", 'objectives.id', '=', 'typ_semester_objectives.objective_id')
  209. ->where('typ_semester_outcome_id', $this->typ_semester_outcome_id)
  210. ->select(
  211. 'typ_semester_objectives.id as typ_semester_objective_id',
  212. 'objectives.id as objective_id',
  213. 'objectives.*',
  214. DB::raw("{$this->semester_id} as semester_id"),
  215. DB::raw("{$this->program_id} as program_id")
  216. )
  217. ->get();
  218. //return $objectives;
  219. }
  220. //Log::info("Lol");
  221. return null;
  222. }
  223. /**
  224. * Return the objectives that the outcome belongs to
  225. *
  226. * @return Illuminate\Database\Eloquent\Model
  227. */
  228. public function getObjectivesAttribute()
  229. {
  230. //return $this->hasManyThrough('Objective', "Objective_Outcome", 'outcome_id', 'id');
  231. // return $this->belongsToMany('Objective', 'objective_outcome');
  232. $objectives = Objective::join('objective_outcome', 'objectives.id', '=', 'objective_outcome.objective_id')
  233. ->where('outcome_id', $this->id);
  234. if (isset($this->program_id)) {
  235. $objectives = $objectives->join('objective_program', 'objective_program.objective_id', '=', 'objectives.id')
  236. ->where('program_id', $this->program_id);
  237. }
  238. return $objectives->get();
  239. }
  240. public function scopeObjectivesFromProgram($query, $programs)
  241. {
  242. return Objective::join('objective_program', 'objective_program.objective_id', '=', 'objectives.id')
  243. ->join('objective_outcome', 'objective_outcome.objective_id', '=', 'objectives.id')
  244. //->join('programs', 'programs.id', '=', 'objective_program.program_id')
  245. ->whereIn("program_id", $programs)
  246. ->where('outcome_id', $this->id)
  247. ->where('objective_program.objective_id', '<>', '0')
  248. ->select('objectives.*')
  249. ->groupBy('objectives.id');
  250. }
  251. // public function attempted($semester, $is_grad)
  252. // {
  253. // return DB::table('new_criteria')
  254. // ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'new_criteria.id')
  255. // ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  256. // ->join('courses', 'activities.course_id', '=', 'courses.id')
  257. // ->join('programs', 'programs.id', '=', 'courses.program_id')
  258. // ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'new_criteria.id')
  259. // ->where('criterion_objective_outcome.outcome_id','=',$this->id)
  260. // ->where('programs.is_graduate','=',$is_grad)
  261. // ->where('courses.semester_id','=',$semester)
  262. // ->count(DB::raw('DISTINCT new_criteria.id,activity_criterion.activity_id'))
  263. // ;
  264. //
  265. // }
  266. // public function attempted($semester, $is_grad)
  267. // {
  268. // $criteria=DB::table('new_criteria')
  269. // ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'new_criteria.id')
  270. // ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  271. // ->join('courses', 'activities.course_id', '=', 'courses.id')
  272. // ->join('programs', 'programs.id', '=', 'courses.program_id')
  273. // ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'new_criteria.id')
  274. // ->where('criterion_objective_outcome.outcome_id','=',$this->id)
  275. // ->where('programs.is_graduate','=',$is_grad)
  276. // ->where('courses.semester_id','=',$semester)
  277. // ->select('new_criteria.id','expected_percentage_students_achieving','activity_criterion.activity_id')
  278. // ->distinct()
  279. // ->get()
  280. // ;
  281. // $conteo=0;
  282. // foreach($criteria as $criterion)
  283. // {
  284. // $students_attempted=Criterion::students_attempted($criterion->id, $criterion->activity_id);
  285. // if($students_attempted)
  286. // {
  287. // $conteo++;
  288. // }
  289. // }
  290. // return $conteo;
  291. // }
  292. public static function active_by_semesters($selected_semesters, $level)
  293. {
  294. $min_start = "9000-01-01 00:00:00";
  295. $max_end = "1000-01-01 00:00:00";
  296. foreach ($selected_semesters as $semester) {
  297. if ($min_start > $semester->start) {
  298. $min_start = $semester->start;
  299. }
  300. if ($max_end < $semester->end) {
  301. $max_end = $semester->end;
  302. }
  303. }
  304. $outcomes = Outcome::where(function ($query) use ($min_start) {
  305. $query->where('deactivation_date', '>=', $min_start)
  306. ->orWhere('deactivation_date', null);
  307. })
  308. ->where('activation_date', '<=', $max_end)
  309. ->where(function ($query2) use ($level) {
  310. $query2->where("level", $level + 1)
  311. ->orWhere("level", 3);
  312. })
  313. ->orderBy('name', 'ASC')
  314. ->get();
  315. // return array('outcomes'=>$outcomes,'outcomes_attempted'=>$outcomes_attempted, 'outcomes_achieved'=>$outcomes_achieved, 'attemptedProgramsPerOutcome'=>$attemptedProgramsPerOutcome, 'achievedProgramsPerOutcome'=>$achievedProgramsPerOutcome,'participating_programs'=>$participating_programs);
  316. return $outcomes;
  317. }
  318. public function programs_attempted($semesters)
  319. {
  320. $semesters_array = [];
  321. foreach ($semesters as $semester) {
  322. $semesters_array[] = $semester->id;
  323. }
  324. // $programs=DB::table('programs')
  325. // ->join('courses', 'programs.id', '=', 'courses.program_id')
  326. // ->join('activities', 'activities.course_id', '=', 'courses.id')
  327. // ->join('activity_criterion', 'activity_criterion.activity_id', '=', 'activities.id')
  328. // ->join('new_criteria', 'activity_criterion.criterion_id', '=', 'new_criteria.id')
  329. // ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'new_criteria.id')
  330. // ->where('criterion_objective_outcome.outcome_id','=',$this->id)
  331. // ->whereIn('courses.semester_id',$semesters_array)
  332. // ->distinct()
  333. // ->select('programs.id')
  334. // ->get()
  335. // ;
  336. $programs = DB::table('programs')
  337. ->join('courses', 'programs.id', '=', 'courses.program_id')
  338. ->join('activities', 'activities.course_id', '=', 'courses.id')
  339. ->join('activity_criterion', 'activity_criterion.activity_id', '=', 'activities.id')
  340. ->join('criteria', 'activity_criterion.criterion_id', '=', 'criteria.id')
  341. ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'criteria.id')
  342. ->where('criterion_objective_outcome.outcome_id', '=', $this->id)
  343. ->whereIn('courses.semester_id', $semesters_array)
  344. ->distinct()
  345. ->select('programs.id')
  346. ->get();
  347. return $programs;
  348. }
  349. public function programs_attempted_in_school($semesters, $school_id)
  350. {
  351. $semesters_array = [];
  352. foreach ($semesters as $semester) {
  353. $semesters_array[] = $semester->id;
  354. }
  355. // $programs=DB::table('programs')
  356. // ->join('courses', 'programs.id', '=', 'courses.program_id')
  357. // ->join('activities', 'activities.course_id', '=', 'courses.id')
  358. // ->join('activity_criterion', 'activity_criterion.activity_id', '=', 'activities.id')
  359. // ->join('new_criteria', 'activity_criterion.criterion_id', '=', 'new_criteria.id')
  360. // ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'new_criteria.id')
  361. // ->where('criterion_objective_outcome.outcome_id','=',$this->id)
  362. // ->whereIn('courses.semester_id',$semesters_array)
  363. // ->distinct()
  364. // ->select('programs.id')
  365. // ->get()
  366. // ;
  367. $programs = DB::table('programs')
  368. ->join('courses', 'programs.id', '=', 'courses.program_id')
  369. ->join('activities', 'activities.course_id', '=', 'courses.id')
  370. ->join('activity_criterion', 'activity_criterion.activity_id', '=', 'activities.id')
  371. ->join('criteria', 'activity_criterion.criterion_id', '=', 'criteria.id')
  372. ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'criteria.id')
  373. ->where('criterion_objective_outcome.outcome_id', '=', $this->id)
  374. ->where('programs.school_id', '=', $school_id)
  375. ->whereIn('courses.semester_id', $semesters_array)
  376. ->distinct()
  377. ->select('programs.id')
  378. ->get();
  379. return $programs;
  380. }
  381. public function attempted($semesters, $is_grad)
  382. {
  383. $semesters_array = [];
  384. foreach ($semesters as $semester) {
  385. $semesters_array[] = $semester->id;
  386. }
  387. // $criteria=DB::table('new_criteria')
  388. // ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'new_criteria.id')
  389. // ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  390. // ->join('courses', 'activities.course_id', '=', 'courses.id')
  391. // ->join('programs', 'programs.id', '=', 'courses.program_id')
  392. // ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'new_criteria.id')
  393. // ->where('criterion_objective_outcome.outcome_id','=',$this->id)
  394. // ->where('programs.is_graduate','=',$is_grad)
  395. // ->whereIn('courses.semester_id',$semesters_array)
  396. // ->select('new_criteria.id','expected_percentage_students_achieving','activity_criterion.activity_id')
  397. // ->distinct()
  398. // ->get()
  399. // ;
  400. $criteria = DB::table('criteria')
  401. ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'criteria.id')
  402. ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  403. ->join('courses', 'activities.course_id', '=', 'courses.id')
  404. ->join('programs', 'programs.id', '=', 'courses.program_id')
  405. ->join('rubric_activity', 'activities.id', '=', 'rubric_activity.activity_id')
  406. ->join('rubrics', 'rubrics.id', '=', 'rubric_activity.rubric_id')
  407. ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'criteria.id')
  408. ->where('criterion_objective_outcome.outcome_id', '=', $this->id)
  409. ->where('programs.is_graduate', '=', $is_grad)
  410. ->whereIn('courses.semester_id', $semesters_array)
  411. ->select('criteria.id', 'expected_percentage', 'activity_criterion.activity_id')
  412. ->distinct()
  413. ->get();
  414. $conteo = 0;
  415. foreach ($criteria as $criterion) {
  416. $students_attempted = Criterion::students_attempted($criterion->id, $criterion->activity_id);
  417. if ($students_attempted) {
  418. $conteo++;
  419. }
  420. }
  421. // var_dump($conteo);
  422. // exit();
  423. return $conteo;
  424. }
  425. public function attempted_by_school($semesters, $school_id, $is_grad)
  426. {
  427. $semesters_array = [];
  428. foreach ($semesters as $semester) {
  429. $semesters_array[] = $semester->id;
  430. }
  431. // $criteria=DB::table('new_criteria')
  432. // ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'new_criteria.id')
  433. // ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  434. // ->join('courses', 'activities.course_id', '=', 'courses.id')
  435. // ->join('programs', 'programs.id', '=', 'courses.program_id')
  436. // ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'new_criteria.id')
  437. // ->where('criterion_objective_outcome.outcome_id','=',$this->id)
  438. // ->where('programs.is_graduate','=',$is_grad)
  439. // ->whereIn('courses.semester_id',$semesters_array)
  440. // ->select('new_criteria.id','expected_percentage_students_achieving','activity_criterion.activity_id')
  441. // ->distinct()
  442. // ->get()
  443. // ;
  444. $criteria = DB::table('criteria')
  445. ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'criteria.id')
  446. ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  447. ->join('courses', 'activities.course_id', '=', 'courses.id')
  448. ->join('programs', 'programs.id', '=', 'courses.program_id')
  449. ->join('rubric_activity', 'activities.id', '=', 'rubric_activity.activity_id')
  450. ->join('rubrics', 'rubrics.id', '=', 'rubric_activity.rubric_id')
  451. ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'criteria.id')
  452. ->where('criterion_objective_outcome.outcome_id', '=', $this->id)
  453. ->where('programs.is_graduate', '=', $is_grad)
  454. ->where('programs.school_id', '=', $school_id)
  455. ->whereIn('courses.semester_id', $semesters_array)
  456. ->select('criteria.id', 'expected_percentage', 'activity_criterion.activity_id')
  457. ->distinct()
  458. ->get();
  459. $conteo = 0;
  460. foreach ($criteria as $criterion) {
  461. $students_attempted = Criterion::students_attempted($criterion->id, $criterion->activity_id);
  462. if ($students_attempted) {
  463. $conteo++;
  464. }
  465. }
  466. // var_dump($conteo);
  467. // exit();
  468. return $conteo;
  469. }
  470. public function attempted_by_program($semesters, $program_id, $is_grad)
  471. {
  472. $semesters_array = [];
  473. foreach ($semesters as $semester) {
  474. $semesters_array[] = $semester->id;
  475. }
  476. // $criteria=DB::table('new_criteria')
  477. // ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'new_criteria.id')
  478. // ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  479. // ->join('courses', 'activities.course_id', '=', 'courses.id')
  480. // ->join('programs', 'programs.id', '=', 'courses.program_id')
  481. // ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'new_criteria.id')
  482. // ->where('criterion_objective_outcome.outcome_id','=',$this->id)
  483. // ->where('programs.is_graduate','=',$is_grad)
  484. // ->whereIn('courses.semester_id',$semesters_array)
  485. // ->select('new_criteria.id','expected_percentage_students_achieving','activity_criterion.activity_id')
  486. // ->distinct()
  487. // ->get()
  488. // ;
  489. $criteria = DB::table('criteria')
  490. ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'criteria.id')
  491. ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  492. ->join('courses', 'activities.course_id', '=', 'courses.id')
  493. ->join('programs', 'programs.id', '=', 'courses.program_id')
  494. ->join('rubric_activity', 'activities.id', '=', 'rubric_activity.activity_id')
  495. ->join('rubrics', 'rubrics.id', '=', 'rubric_activity.rubric_id')
  496. ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'criteria.id')
  497. ->where('criterion_objective_outcome.outcome_id', '=', $this->id)
  498. ->where('programs.is_graduate', '=', $is_grad)
  499. ->where('programs.id', '=', $program_id)
  500. ->whereIn('courses.semester_id', $semesters_array)
  501. ->select('criteria.id', 'expected_percentage', 'activity_criterion.activity_id')
  502. ->distinct()
  503. ->get();
  504. $conteo = 0;
  505. foreach ($criteria as $criterion) {
  506. $students_attempted = Criterion::students_attempted($criterion->id, $criterion->activity_id);
  507. if ($students_attempted) {
  508. $conteo++;
  509. }
  510. }
  511. // var_dump($conteo);
  512. // exit();
  513. return $conteo;
  514. }
  515. public function courses_attempted($courses)
  516. {
  517. $courses_array = [];
  518. foreach ($courses as $course) {
  519. // var_dump($course);
  520. // exit();
  521. $courses_array[] = $course->id;
  522. }
  523. // $criteria=DB::table('new_criteria')
  524. // ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'new_criteria.id')
  525. // ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  526. // ->join('courses', 'activities.course_id', '=', 'courses.id')
  527. // ->join('programs', 'programs.id', '=', 'courses.program_id')
  528. // ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'new_criteria.id')
  529. // ->where('criterion_objective_outcome.outcome_id','=',$this->id)
  530. // ->whereIn('courses.id',$courses_array)
  531. // ->select('new_criteria.id','expected_percentage_students_achieving','activity_criterion.activity_id')
  532. // ->distinct()
  533. // ->get()
  534. // ;
  535. $criteria = DB::table('criteria')
  536. ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'criteria.id')
  537. ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  538. ->join('courses', 'activities.course_id', '=', 'courses.id')
  539. ->join('programs', 'programs.id', '=', 'courses.program_id')
  540. ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'criteria.id')
  541. ->join('rubric_activity', 'rubric_activity.activity_id', '=', 'activities.id')
  542. ->join('rubrics', 'rubric_activity.rubric_id', '=', 'rubrics.id')
  543. ->where('criterion_objective_outcome.outcome_id', '=', $this->id)
  544. ->whereIn('courses.id', $courses_array)
  545. ->select('criteria.id', 'expected_percentage', 'activity_criterion.activity_id')
  546. ->distinct()
  547. ->get();
  548. $conteo = 0;
  549. foreach ($criteria as $criterion) {
  550. $students_attempted = Criterion::students_attempted($criterion->id, $criterion->activity_id);
  551. if ($students_attempted) {
  552. $conteo++;
  553. }
  554. }
  555. // var_dump($conteo);
  556. // exit();
  557. return $conteo;
  558. }
  559. public function courses_achieved($courses)
  560. {
  561. $courses_array = [];
  562. foreach ($courses as $course) {
  563. $courses_array[] = $course->id;
  564. }
  565. // $criteria=DB::table('new_criteria')
  566. // ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'new_criteria.id')
  567. // ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  568. // ->join('courses', 'activities.course_id', '=', 'courses.id')
  569. // ->join('programs', 'programs.id', '=', 'courses.program_id')
  570. // ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'new_criteria.id')
  571. // ->where('criterion_objective_outcome.outcome_id','=',$this->id)
  572. // ->whereIn('courses.id',$courses_array)
  573. // ->select('new_criteria.id','expected_percentage_students_achieving','activity_criterion.activity_id')
  574. // ->distinct()
  575. // ->get()
  576. // ;
  577. $criteria = DB::table('criteria')
  578. ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'criteria.id')
  579. ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  580. ->join('courses', 'activities.course_id', '=', 'courses.id')
  581. ->join('programs', 'programs.id', '=', 'courses.program_id')
  582. ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'criteria.id')
  583. ->join('rubric_activity', 'rubric_activity.activity_id', '=', 'activities.id')
  584. ->join('rubrics', 'rubric_activity.rubric_id', '=', 'rubrics.id')
  585. ->where('criterion_objective_outcome.outcome_id', '=', $this->id)
  586. ->whereIn('courses.id', $courses_array)
  587. ->select('criteria.id', 'expected_percentage as expected_percentage_students_achieving', 'activity_criterion.activity_id')
  588. ->distinct()
  589. ->get();
  590. $conteo = 0;
  591. foreach ($criteria as $criterion) {
  592. $students_attempted = Criterion::students_attempted($criterion->id, $criterion->activity_id);
  593. $students_achieved = Criterion::students_achieved($criterion->id, $criterion->activity_id);
  594. if ($students_attempted) {
  595. $percentage_students_who_achieved = 100.0 * $students_achieved / $students_attempted;
  596. } else {
  597. $percentage_students_who_achieved = 0;
  598. }
  599. if ($percentage_students_who_achieved >= $criterion->expected_percentage_students_achieving) {
  600. $conteo++;
  601. }
  602. }
  603. return $conteo;
  604. }
  605. public function achieved($semesters, $is_grad)
  606. {
  607. $semesters_array = [];
  608. foreach ($semesters as $semester) {
  609. $semesters_array[] = $semester->id;
  610. }
  611. // DB::enableQueryLog();
  612. // $criteria=DB::table('new_criteria')
  613. // ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'new_criteria.id')
  614. // ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  615. // ->join('courses', 'activities.course_id', '=', 'courses.id')
  616. // ->join('programs', 'programs.id', '=', 'courses.program_id')
  617. // ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'new_criteria.id')
  618. // ->where('criterion_objective_outcome.outcome_id','=',$this->id)
  619. // ->where('programs.is_graduate','=',$is_grad)
  620. // ->whereIn('courses.semester_id',$semesters_array)
  621. // ->select('new_criteria.id','expected_percentage_students_achieving','activity_criterion.activity_id')
  622. // ->distinct()
  623. // ->get()
  624. // ;
  625. $criteria = DB::table('criteria')
  626. ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'criteria.id')
  627. ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  628. ->join('courses', 'activities.course_id', '=', 'courses.id')
  629. ->join('programs', 'programs.id', '=', 'courses.program_id')
  630. ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'criteria.id')
  631. ->join('rubric_activity', 'rubric_activity.activity_id', '=', 'activities.id')
  632. ->join('rubrics', 'rubric_activity.rubric_id', '=', 'rubrics.id')
  633. ->where('criterion_objective_outcome.outcome_id', '=', $this->id)
  634. ->where('programs.is_graduate', '=', $is_grad)
  635. ->whereIn('courses.semester_id', $semesters_array)
  636. ->select('criteria.id', 'expected_percentage', 'activity_criterion.activity_id')
  637. ->distinct()
  638. ->get();
  639. // dd(DB::getQueryLog());
  640. $conteo = 0;
  641. foreach ($criteria as $criterion) {
  642. $students_attempted = Criterion::students_attempted($criterion->id, $criterion->activity_id);
  643. $students_achieved = Criterion::students_achieved($criterion->id, $criterion->activity_id);
  644. if ($students_attempted) {
  645. $percentage_students_who_achieved = 100.0 * $students_achieved / $students_attempted;
  646. } else {
  647. $percentage_students_who_achieved = 0;
  648. }
  649. if ($percentage_students_who_achieved >= $criterion->expected_percentage) {
  650. $conteo++;
  651. }
  652. }
  653. return $conteo;
  654. }
  655. public function achieved_by_school($semesters, $school_id, $is_grad)
  656. {
  657. $semesters_array = [];
  658. foreach ($semesters as $semester) {
  659. $semesters_array[] = $semester->id;
  660. }
  661. // DB::enableQueryLog();
  662. // $criteria=DB::table('new_criteria')
  663. // ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'new_criteria.id')
  664. // ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  665. // ->join('courses', 'activities.course_id', '=', 'courses.id')
  666. // ->join('programs', 'programs.id', '=', 'courses.program_id')
  667. // ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'new_criteria.id')
  668. // ->where('criterion_objective_outcome.outcome_id','=',$this->id)
  669. // ->where('programs.is_graduate','=',$is_grad)
  670. // ->whereIn('courses.semester_id',$semesters_array)
  671. // ->select('new_criteria.id','expected_percentage_students_achieving','activity_criterion.activity_id')
  672. // ->distinct()
  673. // ->get()
  674. // ;
  675. $criteria = DB::table('criteria')
  676. ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'criteria.id')
  677. ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  678. ->join('courses', 'activities.course_id', '=', 'courses.id')
  679. ->join('programs', 'programs.id', '=', 'courses.program_id')
  680. ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'criteria.id')
  681. ->join('rubric_activity', 'rubric_activity.activity_id', '=', 'activities.id')
  682. ->join('rubrics', 'rubric_activity.rubric_id', '=', 'rubrics.id')
  683. ->where('criterion_objective_outcome.outcome_id', '=', $this->id)
  684. ->where('programs.is_graduate', '=', $is_grad)
  685. ->where('programs.school_id', '=', $school_id)
  686. ->whereIn('courses.semester_id', $semesters_array)
  687. ->select('criteria.id', 'expected_percentage', 'activity_criterion.activity_id')
  688. ->distinct()
  689. ->get();
  690. // dd(DB::getQueryLog());
  691. $conteo = 0;
  692. foreach ($criteria as $criterion) {
  693. $students_attempted = Criterion::students_attempted($criterion->id, $criterion->activity_id);
  694. $students_achieved = Criterion::students_achieved($criterion->id, $criterion->activity_id);
  695. if ($students_attempted) {
  696. $percentage_students_who_achieved = 100.0 * $students_achieved / $students_attempted;
  697. } else {
  698. $percentage_students_who_achieved = 0;
  699. }
  700. if ($percentage_students_who_achieved >= $criterion->expected_percentage) {
  701. $conteo++;
  702. }
  703. }
  704. return $conteo;
  705. }
  706. public function achieved_by_program($semesters, $program_id, $is_grad)
  707. {
  708. $semesters_array = [];
  709. foreach ($semesters as $semester) {
  710. $semesters_array[] = $semester->id;
  711. }
  712. // DB::enableQueryLog();
  713. // $criteria=DB::table('new_criteria')
  714. // ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'new_criteria.id')
  715. // ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  716. // ->join('courses', 'activities.course_id', '=', 'courses.id')
  717. // ->join('programs', 'programs.id', '=', 'courses.program_id')
  718. // ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'new_criteria.id')
  719. // ->where('criterion_objective_outcome.outcome_id','=',$this->id)
  720. // ->where('programs.is_graduate','=',$is_grad)
  721. // ->whereIn('courses.semester_id',$semesters_array)
  722. // ->select('new_criteria.id','expected_percentage_students_achieving','activity_criterion.activity_id')
  723. // ->distinct()
  724. // ->get()
  725. // ;
  726. $criteria = DB::table('criteria')
  727. ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'criteria.id')
  728. ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  729. ->join('courses', 'activities.course_id', '=', 'courses.id')
  730. ->join('programs', 'programs.id', '=', 'courses.program_id')
  731. ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'criteria.id')
  732. ->join('rubric_activity', 'rubric_activity.activity_id', '=', 'activities.id')
  733. ->join('rubrics', 'rubric_activity.rubric_id', '=', 'rubrics.id')
  734. ->where('criterion_objective_outcome.outcome_id', '=', $this->id)
  735. ->where('programs.is_graduate', '=', $is_grad)
  736. ->where('programs.school_.semester_id', $semesters_array)
  737. ->select('criteria.id', 'expected_percentage', 'activity_criterion.activity_id')
  738. ->distinct()
  739. ->get();
  740. // dd(DB::getQueryLog());
  741. $conteo = 0;
  742. foreach ($criteria as $criterion) {
  743. $students_attempted = Criterion::students_attempted($criterion->id, $criterion->activity_id);
  744. $students_achieved = Criterion::students_achieved($criterion->id, $criterion->activity_id);
  745. if ($students_attempted) {
  746. $percentage_students_who_achieved = 100.0 * $students_achieved / $students_attempted;
  747. } else {
  748. $percentage_students_who_achieved = 0;
  749. }
  750. if ($percentage_students_who_achieved >= $criterion->expected_percentage) {
  751. $conteo++;
  752. }
  753. }
  754. return $conteo;
  755. }
  756. // public function achieved($semester, $is_grad)
  757. // {
  758. //
  759. // // DB::enableQueryLog();
  760. // $criteria=DB::table('criteria')
  761. // ->join('activity_criterion', 'activity_criterion.criterion_id', '=', 'criteria.id')
  762. // ->join('activities', 'activity_criterion.activity_id', '=', 'activities.id')
  763. // ->join('courses', 'activities.course_id', '=', 'courses.id')
  764. // ->join('programs', 'programs.id', '=', 'courses.program_id')
  765. // ->join('criterion_objective_outcome', 'criterion_objective_outcome.criterion_id', '=', 'criteria.id')
  766. // ->where('criterion_objective_outcome.outcome_id','=',$this->id)
  767. // ->where('programs.is_graduate','=',$is_grad)
  768. // ->where('courses.semester_id','=',$semester)
  769. // ->select('criteria.id','expected_percentage_students_achieving','activity_criterion.activity_id')
  770. // ->distinct()
  771. // ->get()
  772. // ;
  773. // // dd(DB::getQueryLog());
  774. //
  775. // $conteo=0;
  776. // foreach($criteria as $criterion)
  777. // {
  778. // $outcome_performance=DB::table('outcome_performance')
  779. // ->where('outcome_performance.outcome_id','=',$this->id)
  780. // ->where('outcome_performance.criterion_id','=',$criterion->id)
  781. // ->where('outcome_performance.semester_id','=',$semester)
  782. // ->where('outcome_performance.level','=',$is_grad)
  783. // ->select('students_attempted','students_achieved')
  784. // ->first();
  785. // if(!empty($outcome_performance) and $outcome_performance->students_attempted)
  786. // {
  787. // $percentage_students_who_achieved=100.0*$outcome_performance->students_achieved/$outcome_performance->students_attempted;
  788. // }
  789. // else
  790. // {
  791. // $students_attempted=Criterion::students_attempted($criterion->id, $criterion->activity_id);
  792. // $students_achieved=Criterion::students_achieved($criterion->id, $criterion->activity_id);
  793. //
  794. // if($students_attempted)
  795. // {
  796. // $percentage_students_who_achieved=100.0*$students_achieved/$students_attempted;
  797. // DB::table('outcome_performance')->insert(array('criterion_id'=>$criterion->id,'outcome_id'=>$this->id,'semester_id'=>$semester,
  798. // 'students_attempted' => $students_attempted,'students_achieved' => $students_achieved,'level'=>$is_grad));
  799. // }
  800. // else
  801. // {
  802. // $percentage_students_who_achieved=0;
  803. // }
  804. // }
  805. // if($percentage_students_who_achieved>=$criterion->expected_percentage_students_achieving)
  806. // {
  807. // $conteo++;
  808. // }
  809. // }
  810. // return $conteo;
  811. // }
  812. //
  813. public static function active()
  814. {
  815. //TODO: Check when semester doesnt exist or session is empty
  816. $selected_semester = Semester::find(Session::get('semesters_ids')[0]);
  817. return Outcome::withTrashed()->where('deactivation_date', '>=', $selected_semester->start)->orWhere('deactivation_date', null)->orderBy('name', 'ASC')->get();
  818. }
  819. }