No Description

annual_report.blade.php 36KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841
  1. @extends('layouts.master-2')
  2. @section('navigation')
  3. @if (Auth::user()->role == 1)
  4. @include('local.managers.admins._navigation')
  5. @elseif(Auth::user()->role == 2)
  6. @include('local.managers.sCoords._navigation')
  7. @elseif(Auth::user()->role == 3)
  8. @include('local.managers.pCoords._navigation')
  9. @elseif(Auth::user()->role == 4)
  10. @include('local.professors._navigation')
  11. @endif
  12. @stop
  13. @section('main')
  14. {{-- TODO: look where to place this script.
  15. if placed inside .ready() or before it,
  16. an error that the function is not defined occurs. --}}
  17. {{-- TODO: no reconoce acentos --}}
  18. <div class="row">
  19. <div class="col-md-3">
  20. <select class="form-control selectpicker" id="annual_plan" onchange="fetchInfo('annual_plan')">
  21. <option value='0'> Nothing Selected</option>
  22. @foreach ($annual_plans as $an_plan)
  23. <option value={{ $an_plan->annual_id }}>Plan {{ $an_plan->academic_year }}</option>
  24. @endforeach
  25. </select>
  26. <br>
  27. <div id='allOutcomes'>
  28. </div>
  29. </div>
  30. <div class="col-md-9">
  31. <div id="outcome-display" class="panel panel-default">
  32. <div class="panel-heading">
  33. <h4 class=" panel-title" style="cursor:auto!important;">
  34. Primer Semestre 2019-2020
  35. </h4>
  36. </div>
  37. <div class="panel-body">
  38. <div id='outcomeInfo'>
  39. </div>
  40. <div id="tableOutcome">
  41. </div>
  42. <ul id="levelTabs" class="nav nav-tabs" role="tablist">
  43. <li role = "presentation" id = 'transformative_for_outcome'>
  44. <a data-toggle="tab" id="a_for_ta_outcome" href="#transformative_actions" role="tab" aria-expanded="true">Transformative Actions</a>
  45. </li>
  46. </ul>
  47. <div id="allLists" class="tab-content">
  48. <div role="tabpanel" class="tab-pane active" id="transformative_actions">
  49. </div>
  50. </div>
  51. <!-- <div class="table-responsive">
  52. <table class="table table-striped table-condensed datatable" style="table-layout: fixed ; width : 100%">
  53. <thead><tr><th>Objectives for courses</th><th>Criteria per Course</th><th>Transformative Actions</th></tr></thead>
  54. <tbody>
  55. </tbody>
  56. </table>
  57. </div>-->
  58. </div>
  59. </div>
  60. </div>
  61. <div class="col-md-9">
  62. <div class="no-outcome alert alert-info">
  63. <p>Select a Learning Outcome to view its information</p>
  64. </div>
  65. </div>
  66. </div>
  67. <div class="modal fade" id="modal-status-trans">
  68. <div class="modal-dialog modal-lg">
  69. <div class="modal-content">
  70. <div class="modal-header">
  71. <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span
  72. aria-hidden="true">&times;</span></button>
  73. <h3 class="modal-title"></h3>
  74. </div>
  75. <div class="modal-body">
  76. <h5 id="was_it_implemented"> </h5>
  77. <label class="radio-inline">
  78. <input type="radio" name="implemented" value = "1">Yes</label>
  79. <label class="radio-inline">
  80. <input type="radio" name="implemented" value = "0">No</label>
  81. <br>
  82. <div id='useful_radio_div'>
  83. <h5>Was this transformative action helpful to achieve the learning expectation?</h5>
  84. <label class="radio-inline">
  85. <input type="radio" name="useful" value = "1">Yes</label>
  86. <label class="radio-inline">
  87. <input type="radio" name="useful" value = "0">No</label>
  88. </div>
  89. <br>
  90. <div id='comment_div'>
  91. <label id="implement_textarea" for='comments'></label>
  92. <textarea class="form-control" id='comments'>
  93. </textarea>
  94. </div>
  95. </div>
  96. <div class='modal-footer'>
  97. <button type="button" class="btn btn-secondary" data-dismiss="modal" >Cancel</button>
  98. <button type="button" class="btn btn-primary" id ="save_transformative_info" onclick ='saveTransReport()'>Save</button>
  99. </div><!-- /.modal-content -->
  100. </div><!-- /.modal-dialog -->
  101. </div><!-- /.modal -->
  102. <script>
  103. function nextChar(c) {
  104. return String.fromCharCode(c.charCodeAt(0) + 1);
  105. }
  106. changed = false;
  107. $(document).ready(function() {
  108. // --------------------------------------------------------------------------
  109. // Page load
  110. // --------------------------------------------------------------------------
  111. $('#comment_div').hide();
  112. $('input[name="implemented"]').change(function(){
  113. //was implemented
  114. if(!parseInt($(this).val())){
  115. $('#useful_radio_div').hide();
  116. $('#comment_div').show();
  117. $('#comments').val(' ');
  118. $('#implement_textarea').html("Explain briefly why this transformative action was not implemented");
  119. }
  120. else{
  121. $('#useful_radio_div').show();
  122. $('#comment_div').show();
  123. $('#implement_textarea').html("Explain briefly details about the implementation of this transformative action");
  124. }
  125. })
  126. // Hide accordion panel contents by default
  127. $('.panel-group .panel-body').hide();
  128. $('#outcome-display').parent().hide();
  129. // --------------------------------------------------------------------------
  130. // Functions
  131. // --------------------------------------------------------------------------
  132. // --------------------------------------------------------------------------
  133. // Events
  134. // --------------------------------------------------------------------------
  135. // When list item is clicked, load corresponding info
  136. });
  137. // Create everything
  138. function draw_transformative_actions(transforming_actions, semester_id){
  139. if(!transforming_actions.length){
  140. $("#transformative_for_outcome").hide();
  141. }
  142. else{
  143. $('#levelTabs').prepend('<li role = "presentation" id = "transformative_for_outcome">'+
  144. '<a data-toggle="tab" id="a_for_ta_outcome" href="#transformative_actions" role="tab" >Transformative Actions</a>'+
  145. '</li>');
  146. $('#allLists').prepend('<div role="tabpanel" class="tab-pane" id="transformative_actions"></div>');
  147. $('#transformative_actions').html('<h3>Tranformative actions for Learning Outcome')
  148. $.each(transforming_actions, function(index, trans_action){
  149. div = $("<div>", {
  150. 'id':'div_trans_id_'+trans_action.trans_id
  151. }).html('<p><strong>'+(index+1)+'. '+trans_action.at_text+': </strong>'+trans_action.description+'</p>'+
  152. '<p><strong>Category: </strong> '+trans_action.type_of_TA+'</p>');
  153. div.append('<label>Results: </label>')
  154. input_results = $("<textarea>", {
  155. 'class':'form-control',
  156. 'id':'results_for_'+trans_action.trans_id
  157. });
  158. div.append(input_results)
  159. div.append('<h5>Was this transformative action helpful to achieve the learning expectation?</h5>'+
  160. '<label class="radio-inline">'+
  161. '<input type="radio" name="useful_for_'+trans_action.trans_id+'" value = "1">Yes</label>'+
  162. '<label class="radio-inline">'+
  163. '<input type="radio" name="useful_for_'+trans_action.trans_id+'" value = "0">No</label>');
  164. comments = $('<textarea>',{
  165. 'id':'comments_for_'+trans_action.trans_id,
  166. 'class':'form-control'
  167. });
  168. div.append('<br><label>Explain briefly details about the implementation</label>');
  169. div.append(comments);
  170. button = $('<button>',{
  171. "type":"button",
  172. "class":"btn btn-primary",
  173. "onclick":'saveTransReport('+trans_action.trans_id+', '+semester_id+')',
  174. 'style':'float: right'
  175. }).html('Save');
  176. div.append('<br>');
  177. div.append(button);
  178. div.append('<br>');
  179. div.append('<hr>');
  180. $('#transformative_actions').append(div);
  181. $('#results_for_'+trans_action.trans_id).val(trans_action.results);
  182. $('#comments_for_'+trans_action.trans_id).val(trans_action.comments);
  183. $('input[name="useful_for_'+trans_action.trans_id+'"][value="'+trans_action.it_was_useful + '"]').prop('checked', true);
  184. })
  185. }
  186. }
  187. function fetchEverything(li) {
  188. var outcome_id = $(li).data('outcome-id');
  189. var name = $(li).data('outcome-name');
  190. var semester_id = $(li).data('semester-id');
  191. var annual_plan_id = $(li).data('annual-plan');
  192. var typ_semester_outcome_id = $(li).data('typ-semester-outcome-id');
  193. $('#theChange').data('annual-plan', annual_plan);
  194. $.post(
  195. "{{ URL::action('AnnualPlansController@fetchReportWithOutcome') }}", {
  196. semester_id: semester_id,
  197. outcome_id: outcome_id,
  198. program_id: {{ $program->id }},
  199. annual_plan_id: annual_plan_id,
  200. typ_semester_outcome_id: typ_semester_outcome_id
  201. },
  202. function(outcome) {
  203. if (outcome.objectives) {
  204. $('table').show();
  205. $('#outcome-display').parent().show();
  206. $('#outcome-display .panel-title').html(name);
  207. $('#allLists').empty();
  208. $('#levelTabs').empty();
  209. $('.no-outcome').hide();
  210. if (outcome.outcome_program_goal) {
  211. outcome.outcome_program_goal = outcome.outcome_program_goal.expected_target;
  212. } else {
  213. outcome.outcome_program_goal = 'It has not been defined';
  214. }
  215. var outcomeHTML = "<h4>Performance of Students by Learning Outcome</h4>" +
  216. '<h5 style = "display: inline; margin:30px;">Target learning by learning outcome: </h5>' +
  217. '<p style = "display: inline;"> <i>>= ' + outcome.expected_outcome +
  218. ' of the attempts</i>' + '</p>' +
  219. '<br><h5 style = "display: inline; margin:30px;">Expected percent of students achieving the target by learning outcome: </h5>' +
  220. '<p style = "display: inline;"> <i>' + outcome.outcome_program_goal + '</i></p>';
  221. $('#outcomeInfo').html('<p class="outcome-definition">' + outcome.definition + '</p>' +
  222. outcomeHTML);
  223. //theStudentOutcomeTable = $("<table/>");
  224. //theStudentOutcomeTable.hide();
  225. ///$('#outcomeInfo').append(theStudentOutcomeTable);
  226. wholeDict = {};
  227. tableStudent = $('<table/>', {
  228. 'class': 'table table-striped table-condensed datatable'
  229. });
  230. tableStudent.html('<thead><tr>' +
  231. '<th>Student</th>' +
  232. '<th>Criteria Attempted</th>' +
  233. '<th>Criteria Achieved</th>' +
  234. '<th>Percentage</th>' +
  235. '<th>Outcome Achieved</th>' +
  236. '</tr></thead><tbody></tbody>');
  237. first_objective_id = outcome.objectives[0].id;
  238. $.each(outcome.objectives, function(index, objective) {
  239. li = $('<li/>', {
  240. 'role': 'presentation',
  241. 'id':'li_for_'+objective.id
  242. });
  243. a = $('<a/>', {
  244. 'data-toggle': 'tab',
  245. 'id': 'a_for_'+objective.id,
  246. 'href': '#' + objective.id,
  247. 'role': 'tab'
  248. }).html('Objective ' + (index + 1));
  249. li.append(a);
  250. $('#levelTabs').append(li);
  251. objective_title = "<h3>" + objective.text + '</h3>';
  252. div = $('<div/>', {
  253. 'role': 'tabpanel',
  254. 'class': 'tab-pane',
  255. 'id': objective.id
  256. }).html(objective_title);
  257. div.appendTo($('#allLists'))
  258. div.append(
  259. '<p>The following results are from the courses in the selected semester with the focused criteria in the selected annual plan</p>'
  260. );
  261. if (objective.courses) {
  262. $.each(objective.courses, function(index, course_code) {
  263. if (course_code.criteria.length) {
  264. $.each(course_code.students, function(index, student) {
  265. if (wholeDict[student.student_id] === undefined) {
  266. wholeDict[student.student_id] = {
  267. 'student': student.student_id,
  268. 'criteria_attempted': 0,
  269. 'criteria_achieved': 0
  270. }
  271. }
  272. wholeDict[student.student_id][
  273. "criteria_attempted"
  274. ] += student
  275. .criteria_attempted;
  276. wholeDict[student.student_id][
  277. "criteria_achieved"
  278. ] += student
  279. .criteria_achieved;
  280. });
  281. /*div.append(
  282. '<p>The following results are from the courses in the selected semester with the focused criteria in the selected annual plan</p>'
  283. );*/
  284. table = $('<table/>', {
  285. 'class': 'table table-striped table-condensed datatable'
  286. }).html('<thead><th>Criterion</th><th>' +
  287. 'Number of Students Assessed </th>' +
  288. '<th>Number of students that achieved the target</th></thead>'
  289. );
  290. tbody = $('<tbody/>')
  291. $.each(course_code.criteria, function(index, criterion) {
  292. tr = $('<tr/>').append(
  293. "<td>" + criterion.name + "</td>" +
  294. "<td>" + criterion.criteria_attempted +
  295. "</td>" +
  296. "<td>" + criterion.criteria_achieved +
  297. "</td>"
  298. );
  299. tbody.append(tr);
  300. });
  301. table.append(tbody);
  302. Course_section = '<h3>' + course_code.code + ' ' +
  303. course_code.number + '</h3><hr>';
  304. div.append(Course_section)
  305. div.append('<h4> Criteria Assessed in '+course_code.code+' '+course_code.number+'</h4>')
  306. div.append(table);
  307. if (course_code.transforming_actions.length) {
  308. table_for_transformative_actions = $('<table>',{
  309. 'class': 'table table-striped table-condensed datatable'
  310. }).html('<thead><th>Transformative Actions Proposed in Annual Plan</th>' +
  311. '<th>Follow up </th>' +
  312. '</thead>'
  313. );
  314. tbody_for_transformative_actions = $('<tbody>');
  315. $.each(course_code.transforming_actions, function(index,
  316. transformative_action) {
  317. button_for_followup = $('<button>',{
  318. 'class':'btn btn-secondary',
  319. 'onclick':'give_follow_up_questions('+transformative_action.id+', "'+outcome.semester_info.code+'", '+outcome.semester_info.id+')'
  320. }).html('Follow Up Questions');
  321. table_row = "<tr>"+
  322. '<td><p><strong>'+transformative_action.at_text +': </strong>'+
  323. transformative_action.description+'</p></td>'+
  324. '<td>'+button_for_followup.prop('outerHTML')+'</td></tr>';
  325. tbody_for_transformative_actions.append(table_row)
  326. })
  327. table_for_transformative_actions.append(tbody_for_transformative_actions);
  328. div.append('<hr><h4>Transformative actions for '+course_code.code+' '+course_code.number+'</h4>')
  329. div.append(table_for_transformative_actions);
  330. //table_for_transformative_actions.DataTable();
  331. }
  332. table.DataTable();
  333. }
  334. })
  335. } else {
  336. div.append('<div class="no-outcome alert alert-info"' +
  337. '<p>No Course in plan has assessed yet</p>' +
  338. '</div>')
  339. }
  340. })
  341. draw_transformative_actions(outcome.transforming_actions, outcome.semester_info.id)
  342. //$('#a_for_'+first_objective_id).click();
  343. theArray = [];
  344. $('#tableOutcome').html(tableStudent);
  345. //tableStudent.appendTo($('#outcomeInfo'));
  346. tableStudent = tableStudent.DataTable({
  347. dom: 'Bfrtip',
  348. buttons: [
  349. 'csv', 'excel', 'pdf', 'print'
  350. ]
  351. });
  352. students_attempted = 0;
  353. students_achieved = 0;
  354. $.each(wholeDict, function(key, dict) {
  355. if (dict.criteria_attempted) {
  356. students_attempted += 1;
  357. percentage = ((dict.criteria_achieved / dict.criteria_attempted) * 100).toFixed(
  358. 2);
  359. if (parseFloat(percentage) >= parseFloat(outcome.expected_outcome)) {
  360. achieved = "Yes"
  361. students_achieved += 1;
  362. } else achieved = "No"
  363. } else {
  364. percentage = "N/A"
  365. achieved = "N/A"
  366. }
  367. tableStudent.row.add([
  368. dict.student,
  369. dict.criteria_attempted,
  370. dict.criteria_achieved,
  371. percentage,
  372. achieved
  373. ]);
  374. })
  375. tableStudent.draw();
  376. if (students_attempted) {
  377. studentPercentage = ((students_achieved / students_attempted) * 100).toFixed(2);
  378. if (parseFloat(studentPercentage) >= parseFloat(outcome.outcome_program_goal)) {
  379. FinalReport = "<br><p><strong>The students achieved the Learning Outcome with " +
  380. studentPercentage + "% of students achieving.</strong></p>";
  381. } else {
  382. FinalReport = "<br><p><strong>The students did not achieve the Learning Outcome with " +
  383. studentPercentage + "% of students achieving.</strong></p>";
  384. }
  385. }
  386. $("#outcomeInfo").append(FinalReport)
  387. /* table.row.add([
  388. objectivesHTML,
  389. courseshtml,
  390. courseTAhtml
  391. ]);
  392. table.draw();
  393. */
  394. } else {
  395. $('table').hide();
  396. }
  397. }
  398. );
  399. }
  400. function give_follow_up_questions(trans_id, semester_code, semester_id){
  401. $.ajax({
  402. type: 'POST',
  403. url: "{{ URL::action('TransformativeActionsController@fetchStatus') }}",
  404. data: {
  405. trans_id:trans_id,
  406. semester_id:semester_id
  407. },
  408. success: function(transformative_action_with_status) {
  409. transformative_action = transformative_action_with_status[0];
  410. $('.modal-title').html('<strong>'+transformative_action.at_text+'</strong>: '+transformative_action.description);
  411. $('input[name="implemented"]').prop('checked',false);
  412. $('input[name="useful"]').prop('checked',false);
  413. $('#comments').val(' ');
  414. $('#useful_radio_div').hide();
  415. $('#comment_div').hide();
  416. if(transformative_action['status']){
  417. transformative_action['status'].accomplished;
  418. $('input[name="implemented"][value="'+ transformative_action['status'].accomplished + '"]').prop('checked', true);
  419. if(transformative_action['status'].accomplished){
  420. $('#useful_radio_div').show();
  421. $('input[name="useful"][value="'+ transformative_action['status'].it_was_useful + '"]').prop('checked', true);
  422. }
  423. $('#comment_div').show();
  424. $('#comments').val(transformative_action['status'].comments);
  425. }
  426. $('#was_it_implemented').html('Was this transformative action implemented during Semester '+semester_code);
  427. $('#modal-status-trans').modal();
  428. $('#save_transformative_info').attr('onclick', 'saveTransReport('+trans_id+','+semester_id+',"modal")');
  429. },
  430. async: true
  431. });
  432. }
  433. function saveTransReport(trans_id, semester_id, type_of_input){
  434. if(type_of_input=='modal'){
  435. comments = $('#comments').val();
  436. accomplished = parseInt($('input[name="implemented"]:checked').val());
  437. if(accomplished)
  438. was_it_useful = $('input[name="useful"]:checked').val();
  439. else was_it_useful =0;
  440. results = "";
  441. }
  442. else{
  443. comments = $('#comments_for_'+trans_id).val();
  444. accomplished = 1;
  445. was_it_useful = $('input[name="useful_for_'+trans_id+'"]:checked').val();
  446. results = $('#results_for_'+trans_id).val();
  447. }
  448. $.post(
  449. "{{URL::action('TransformativeActionsController@saveTransStatus')}}",
  450. {
  451. semester_id:semester_id,
  452. trans_id:trans_id,
  453. results:results,
  454. comments:comments,
  455. accomplished:accomplished,
  456. was_it_useful:was_it_useful,
  457. },
  458. function(message){
  459. alert(message);
  460. }
  461. )
  462. }
  463. function posttoTransAnnual(annual_id, selectTransId, typ_course_id) {
  464. ta = $("#" + selectTransId).val();
  465. old_ta = $("#" + selectTransId).data('old-TA');
  466. if (ta == "0") return;
  467. $.post("../annual-plan-postTA", {
  468. annual_id: annual_id,
  469. TA_id: ta,
  470. typ_course_id: typ_course_id,
  471. old_ta: old_ta
  472. },
  473. function(message) {
  474. $("#" + selectTransId).data('old-TA', ta);
  475. }
  476. )
  477. }
  478. function addTAselect(options, master_div, annual_plan_id, objective_id, typ_course_id, selected_ta) {
  479. var $div = $('<div/>', {
  480. 'class': 'form-group '
  481. });
  482. counter = parseInt($('#' + master_div).data('amount-ta'));
  483. var selectTA = $('<select/>', {
  484. 'class': "selectpicker form-control",
  485. 'data-live-search': 'true',
  486. 'data-old-TA': '0',
  487. 'data-width': '180px',
  488. 'id': 'transformativeForObjective' + master_div + '_' + counter,
  489. 'onchange': 'posttoTransAnnual(' + annual_plan_id + ', "transformativeForObjective' + master_div +
  490. '_' + counter + '", ' + typ_course_id + ')'
  491. });
  492. selectTA.append(options);
  493. selectTA.appendTo($div);
  494. selectTA.val(selected_ta);
  495. selectTA.data('old-TA', selected_ta);
  496. selectTA.selectpicker('refresh');
  497. $span = $('<span/>', {
  498. 'id': 'close',
  499. 'onclick': ' postDeleteTA(' + annual_plan_id + ', "transformativeForObjective' + master_div + '_' +
  500. counter + '", ' + typ_course_id +
  501. '); this.parentNode.parentNode.removeChild(this.parentNode);return false;'
  502. }).html('x');
  503. $span.appendTo($div);
  504. $div.append("<br><br>");
  505. $('#' + master_div).append("<br>");
  506. $div.appendTo($('#' + master_div));
  507. $('#' + master_div).data('amount-ta', counter + 1);
  508. }
  509. function postDeleteTA(annual_id, selectTransId, typ_course_id) {
  510. ta = $("#" + selectTransId).val();
  511. if (ta == "0") return;
  512. $.post("../annual-plan-deleteTA", {
  513. annual_id: annual_id,
  514. TA_id: ta,
  515. typ_id: typ_course_id,
  516. });
  517. parent = $("#" + selectTransId).parent().parent().parent();
  518. counter = parseInt(parent.data('amount-ta'));
  519. parent.data('amount-ta', counter - 1);
  520. }
  521. function postToAnnualPlans(typ_course_id, criteria_select) {
  522. var criteria = $('#' + criteria_select).val();
  523. var oldCriteria = $('#' + criteria_select).data('old-criteria');
  524. var criteriaNode = document.getElementById(criteria_select).parentNode.parentNode.parentNode;
  525. var annual = criteriaNode.dataset.annualPlan;
  526. $.post("../annual-plan-postOnChange", {
  527. criteria: criteria,
  528. typ_course_id: typ_course_id,
  529. annual_plan: annual,
  530. old_criteria: oldCriteria
  531. },
  532. function(message) {
  533. if (message == "Duplicate entry, please choose another criteria.") {
  534. alert(message)
  535. } else {
  536. $('#' + criteria_select).data('old-criteria', criteria);
  537. changed = true;
  538. }
  539. })
  540. }
  541. function addCriteriaTest(div, new_id_for_select, typ_course_id, i = null, options) {
  542. if (!i) amount_select = $('#' + div).data("amount-select");
  543. else amount_select = i;
  544. $select = $('<select/>', {
  545. 'class': "selectpicker form-control",
  546. 'data-live-search': 'true',
  547. 'data-old-criteria': '0',
  548. 'data-width': '180px',
  549. 'id': 'criteriaFor' + new_id_for_select + '_' + amount_select,
  550. 'onchange': 'postToAnnualPlans(' + typ_course_id + ', "criteriaFor' + new_id_for_select + '_' +
  551. amount_select + '")'
  552. })
  553. var $div = $('<div/>', {
  554. 'id': 'courseSelect_' + new_id_for_select + '_' + amount_select,
  555. 'class': 'form-group '
  556. });
  557. $select.append(options);
  558. $select.appendTo($div);
  559. $span = $('<span/>', {
  560. 'id': 'close',
  561. 'onclick': ' postDelete(' + typ_course_id + ', "criteriaFor' + new_id_for_select + '_' +
  562. amount_select + '"); this.parentNode.parentNode.removeChild(this.parentNode);return false;'
  563. }).html('x');
  564. $div.append($span);
  565. $div.append("<br><br>")
  566. $('#' + div).append("<br>");
  567. $div.appendTo($("#" + div));
  568. $select.selectpicker('refresh');
  569. $("#" + div).data("amount-select", amount_select + 1);
  570. }
  571. $('#allOutcomes').hide();
  572. function postDelete(typ_course_id, criteria_select) {
  573. var criteria = $('#' + criteria_select).val();
  574. var oldCriteria = $('#' + criteria_select).data('old-criteria');
  575. var criteriaNode = document.getElementById(criteria_select).parentNode.parentNode.parentNode;
  576. var annual = criteriaNode.dataset.annualPlan;
  577. $.post("../annual-plan-deleteCriteria", {
  578. criteria: criteria,
  579. typ_course_id: typ_course_id,
  580. annual_plan: annual,
  581. old_criteria: oldCriteria
  582. });
  583. }
  584. function fetchInfo(id) {
  585. annual_id = $("#" + id).val();
  586. program_id = {{ $program->id }};
  587. $.post("{{ URL::action('AnnualPlansController@fetchInfo') }}", {
  588. id: annual_id,
  589. program_id: program_id
  590. },
  591. function(json) {
  592. div = $('<div/>', {
  593. 'class': 'list-group',
  594. 'id': 'list'
  595. });
  596. if (json.outcomes.first) {
  597. header5 = $('<h5/>', {
  598. 'style': "padding-left: 10px"
  599. }).html("First Semester");
  600. div.append(header5);
  601. list = '';
  602. for (outcome in json.outcomes.first) {
  603. list +=
  604. "<li style='padding-left: 25px' onclick = 'fetchEverything(this)' data-annual-plan = '" +
  605. json.annual_plans.id + "' data-typ-semester-outcome-id ='" + json.outcomes.first[
  606. outcome].typ_semester_outcome_id + "' data-semester-id = '" + json.allSemesterOrder
  607. .first.id +
  608. "' data-outcome-id='" + json.outcomes.first[outcome].id + "' data-outcome-name ='" +
  609. json
  610. .outcomes.first[outcome].name + "' class='list-group-item' >" + json.outcomes.first[
  611. outcome]
  612. .name + " </li>";
  613. }
  614. div.append(list);
  615. }
  616. if (json.outcomes.second) {
  617. header4 = $('<h5/>', {
  618. 'style': "padding-left: 10px"
  619. }).html("Second Semester");
  620. div.append(header4);
  621. list = '';
  622. for (outcome in json.outcomes.second) {
  623. list +=
  624. "<li style='padding-left: 25px' onclick = 'fetchEverything(this)' data-annual-plan = '" +
  625. json.annual_plans.id + "' data-typ-semester-outcome-id ='" + json.outcomes.second[
  626. outcome].typ_semester_outcome_id + "'data-semester-id = '" + json.allSemesterOrder
  627. .second.id +
  628. "' data-outcome-id='" + json.outcomes.second[outcome].id + "' data-outcome-name ='" +
  629. json
  630. .outcomes.second[outcome].name + "' class='list-group-item' >" + json.outcomes.second[
  631. outcome].name + " </li>";
  632. }
  633. div.append(list);
  634. }
  635. html = div[0].innerHTML;
  636. $("#allOutcomes").html(div[0].innerHTML);
  637. $("#allOutcomes").show();
  638. },
  639. "json",
  640. );
  641. }
  642. function deleteObjective(objectiveSelectDiv, closeObj) {
  643. $('#' + objectiveSelectDiv).remove();
  644. $('#' + closeObj).remove();
  645. $('#' + div).data("amount-select", $('#' + div).data("amount-select") - 1);
  646. }
  647. </script>
  648. @stop
  649. @section('included-js')
  650. @include('global._datatables_js')
  651. @stop