暫無描述

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