Без опису

view-annual-plans.blade.php 196KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556
  1. @extends('layouts.master-2')
  2. @section('navigation')
  3. @if (Auth::user()->role == 1)
  4. @include('local.managers.admins._new_navigation')
  5. @elseif(Auth::user()->role == 2)
  6. @include('local.managers.sCoords._new_navigation')
  7. @elseif(Auth::user()->role == 3)
  8. @include('local.managers.pCoords._new_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" id="here">
  20. <select class="form-control selectpicker" id="annual_plan" onchange="createAllTables('annual_plan')">
  21. <option value='0'> Nothing Selected</option>
  22. @foreach ($annual_plans as $an_plan)
  23. <option value={{ $an_plan->id }}>Plan {{ $an_plan->academic_year }}</option>
  24. @endforeach
  25. </select>
  26. <br>
  27. <div id="here2">
  28. </div>
  29. </div>
  30. <div class="col-md-9" id="allTables">
  31. <div class="no-outcome alert alert-info">
  32. <p>Select an Annual Plan to view its information</p>
  33. </div>
  34. </div>
  35. </div>
  36. <!-- Modal -->
  37. <div class="modal fade" id="modal_inform" tabindex="-1" role="dialog" aria-labelledby="title" aria-hidden="true">
  38. <div class="modal-dialog" role="document">
  39. <div class="modal-content">
  40. <div class="modal-header">
  41. <h5 class="modal-title" id="title">Generating Report</h5>
  42. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  43. <span aria-hidden="true">&times;</span>
  44. </button>
  45. </div>
  46. <div class="modal-body" id="theReport">
  47. ...
  48. </div>
  49. <div class="modal-footer">
  50. <button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
  51. <button type="button" class="btn btn-primary"
  52. onclick=" postToTransformativeReport(); fetchInfoTrans();">Save changes</button>
  53. </div>
  54. </div>
  55. </div>
  56. </div>
  57. <script>
  58. counter = 0;
  59. json_to_use = [];
  60. function triggerForYear() {
  61. $('#print_BUTTON').click();
  62. }
  63. function changeOutput(show, hide) {
  64. // console.log($(show).selector);#firstSemester
  65. if ($(show).selector == "#secondSemester") {
  66. $('#first_semester_button')[0].className = "btn btn-secondary";
  67. $('#second_semester_button')[0].className = "btn btn-primary";
  68. }
  69. if ($(show).selector == "#firstSemester") {
  70. $('#first_semester_button')[0].className = "btn btn-primary";
  71. $('#second_semester_button')[0].className = "btn btn-secondary";
  72. }
  73. $(show).show();
  74. $(hide).hide();
  75. }
  76. function postToTransformativeReport() {
  77. program_id = {{ $program_id }};
  78. an_id = $("#annual_plan").val();
  79. realized = [];
  80. logrado = [];
  81. continued = [];
  82. semester = [];
  83. typ_objective = [];
  84. transformative = [];
  85. comments = [];
  86. for (i = 0; i < counter; i++) {
  87. realized.push($('input[name="seHizo' + i + '"]:checked').val());
  88. logrado.push($('input[name="logro' + i + '"]:checked').val());
  89. continued.push($('input[name="continued' + i + '"]:checked').val());
  90. typ_objective.push($('input[name="objective_' + i + '"]').val());
  91. semester.push($('input[name="what_semester_' + i + '"]').val());
  92. transformative.push($('input[name="transformative_' + i + '"]').val());
  93. comments.push($('textarea[name="comment2' + i + '"]').val())
  94. }
  95. $.post("{{ URL::action('AnnualPlansController@postReport') }}", {
  96. program_id: program_id,
  97. realized: realized,
  98. logrado: logrado,
  99. continued: continued,
  100. semester: semester,
  101. typ_objective: typ_objective,
  102. transformative: transformative,
  103. annual_id: an_id,
  104. comments: comments
  105. })
  106. }
  107. function fetchInfoTrans() {
  108. an_id = $("#annual_plan").val();
  109. $.post("{{ URL::action('AnnualPlansController@transformativeReport') }}", {
  110. an_id: an_id
  111. },
  112. function(json) {
  113. json_to_use = json;
  114. $('#report_print').click();
  115. $('#trans_print').click();
  116. },
  117. 'json'
  118. );
  119. }
  120. amount_of_TA_per_objective = [];
  121. function createAllTables(id) {
  122. id = $('#' + id).val();
  123. program_id = {{ $program_id }}
  124. $.post("{{ URL::action('AnnualPlansController@fetchAllTables') }}", {
  125. id: id,
  126. program_id: program_id
  127. },
  128. function(json) {
  129. counter = 0;
  130. $('#allTables').empty();
  131. $('#buttonForAll').remove();
  132. $buttonAll = $('<button/>', {
  133. 'class': 'btn btn-secondary',
  134. 'type': 'button',
  135. 'onclick': 'triggerForYear()',
  136. 'id': "buttonForAll"
  137. }).html('Export whole year');
  138. /*
  139. $buttonForInform = $('<button/>', {
  140. 'class':'btn btn-secondary',
  141. 'type':'button',
  142. 'data-toggle':'modal',
  143. 'data-target':'#modal_inform'
  144. }).html('Report annual plan');*/
  145. $('#here2').html($buttonAll);
  146. $('#here2').append("<br><br>");
  147. /*
  148. $('#here2').append($buttonForInform);*/
  149. $button = $('<button/>', {
  150. 'id': 'first_semester_button',
  151. 'class': 'btn btn-primary',
  152. 'type': 'button',
  153. 'style': 'width: 50%',
  154. 'onclick': 'changeOutput("#firstSemester","#secondSemester")'
  155. }).html('First Semester');
  156. $button2 = $('<button/>', {
  157. 'id': 'second_semester_button',
  158. 'class': 'btn btn-secondary',
  159. 'type': 'button',
  160. 'style': 'float:right; width:50%',
  161. 'onclick': 'changeOutput("#secondSemester","#firstSemester")'
  162. }).html('Second Semester');
  163. $button.appendTo('#allTables');
  164. $button2.appendTo('#allTables');
  165. plan = $("#annual_plan option:selected").text();
  166. $divForAll = $('<div/>', {
  167. 'id': "forExportAllTable"
  168. });
  169. $tableForAll = $('<table/>', {
  170. "class": "table table-striped table-condensed datatable",
  171. "style": "table-layout: fixed",
  172. "id": 'allTablesToExport',
  173. "data-title": plan
  174. });
  175. $thead = $('<thead/>').html(
  176. "<tr><th>Objectives for courses</th><th>Criteria per course</th><th>Transformative Actions</th></tr>"
  177. );
  178. $tbody = $('<tbody/>');
  179. $tableForAll.append($thead);
  180. $tableForAll.append($tbody);
  181. $tableForAll.appendTo($divForAll);
  182. $divForAll.appendTo("#allTables")
  183. $tableForAll = createTheReportAll($tableForAll);
  184. $('#forExportAllTable').hide();
  185. $divForReport = $('<div/>', {
  186. 'id': "forReportAllTable"
  187. });
  188. $tableForAll = $('<table/>', {
  189. "class": "table table-striped table-condensed datatable",
  190. "style": "table-layout: fixed",
  191. "id": 'allReportToExport',
  192. "data-title": plan
  193. });
  194. $thead = $('<thead/>').html(
  195. "<tr><th>Objectives for courses</th><th>Criteria per Courses</th><th>Transformative Actions</th></tr>"
  196. );
  197. $tbody = $('<tbody/>');
  198. $tableForAll.append($thead);
  199. $tableForAll.append($tbody);
  200. $tableForAll.appendTo($divForAll);
  201. $divForAll.appendTo("#allTables")
  202. $tableForAll = createTheExportAll($tableForAll);
  203. $('#forReportAllTable').hide();
  204. $('#theReport').empty();
  205. $divForTrans = $('<div/>', {
  206. 'id': "forTransAllTable"
  207. });
  208. $tableForTrans = $('<table/>', {
  209. "class": "table table-striped table-condensed datatable",
  210. "style": "table-layout: fixed",
  211. "id": 'allTransToExport',
  212. "data-title": plan
  213. });
  214. $theadTrans = $('<thead/>').html(
  215. "<tr><th>Objectives evaluated</th><th>Date Proposed</th><th>Proposed by</th><th>Phase</th><th>Semester it was carried out</th><th>Comments</th></tr>"
  216. );
  217. $tbodyTrans = $('<tbody/>');
  218. $tableForTrans.append($theadTrans);
  219. $tableForTrans.append($tbodyTrans);
  220. $tableForTrans.appendTo($divForTrans);
  221. $divForTrans.appendTo("#allTables")
  222. $tableForTrans = createTheTrans($tableForTrans);
  223. $('#forTransAllTable').hide();
  224. //First semester
  225. $divForFirstSemester = $('<div/>', {
  226. 'id': "firstSemester"
  227. });
  228. $divForFirstSemester.appendTo('#allTables');
  229. index_per_objective = 0;
  230. for (outcome in json.first.outcomes) {
  231. $panel = $('<div/>', {
  232. 'id': 'outcome_' + json.first.outcomes[outcome].id,
  233. 'class': 'panel panel-default'
  234. });
  235. $div = $('<div/>', {
  236. 'class': 'panel-heading'
  237. });
  238. $h4 = $('<h4/>', {
  239. 'class': 'panel-title',
  240. 'style': "cursor:auto!important;"
  241. }).html(json.first.outcomes[outcome].name);
  242. $('#theReport').append('<h4>' + json.first.outcomes[outcome].name + '</h4>');
  243. $div.append($h4);
  244. $panel.append($div);
  245. $div = $('<div/>', {
  246. 'class': 'panel-body'
  247. });
  248. $divTable = $('<div/>', {
  249. "class": "table-responsive"
  250. })
  251. $table = $('<table/>', {
  252. "class": "table table-striped table-condensed datatable",
  253. "style": "table-layout: fixed",
  254. "id": json.first.outcomes[outcome].id + 'first',
  255. "data-title": json.first.outcomes[outcome].name
  256. })
  257. $thead = $('<thead/>').html(
  258. "<tr><th>Objectives for courses</th><th>Criteria per Course</th><th>Transformative Actions</th></tr>"
  259. )
  260. $table.append($thead);
  261. $table.append($('<tbody/>'));
  262. $divTable.append($table);
  263. $div.append($divTable);
  264. $panel.append($div);
  265. $panel.appendTo($divForFirstSemester);
  266. $table = createDataTable($table);
  267. var outcomeID = json.first.outcomes[outcome].id;
  268. var nextLetter = 'A';
  269. for (objective in json.first.objectives[outcomeID]) {
  270. var theObj = json.first.objectives[outcomeID][objective];
  271. var objHTML = '<strong> ' + nextLetter + '. ' + theObj.text + '</strong>';
  272. nextLetter = nextChar(nextLetter);
  273. var courseHTML = '';
  274. var courseTAhtml = '';
  275. for (course in json.first.courses[theObj.id]) {
  276. var theCourse = json.first.courses[theObj.id][course];
  277. courseHTML += '&#8226; ' + theCourse.code + " " + theCourse.number + '\n\n\n<br>';
  278. courseTAhtml += '&#8226; ' + theCourse.code + " " + theCourse.number + '\n\n\n<br>';
  279. // console.log(json.first.criteria[theObj.id][theCourse.course_id]);
  280. for (criterion in json.first.criteria[theObj.id][theCourse.typ_course_id]) {
  281. // for(criterion in json.first.criteria[theObj.id][theCourse.course_id]){
  282. theCrit = json.first.criteria[theObj.id][theCourse.typ_course_id][criterion];
  283. // theCrit = json.first.criteria[theObj.id][theCourse.course_id][criterion];
  284. courseHTML += '\t&nbsp;&nbsp; ' + (parseInt(criterion) + 1) + ". " + theCrit.name +
  285. '\n\n<br>';
  286. }
  287. for (trans in json.first.trans_actions[theObj.id][theCourse.typ_course_id]) {
  288. theTA = json.first.trans_actions[theObj.id][theCourse.typ_course_id][trans]
  289. courseTAhtml += '\t&nbsp;&nbsp; ' + (parseInt(trans) + 1) + ". " + theTA
  290. .description + '\n\n<br>';
  291. }
  292. }
  293. //courseHTML += '</ul>';
  294. // var criteriaHTML = '';
  295. // for(criterion in json.first.criteria[theObj.id]){
  296. // crit = json.first.criteria[theObj.id][criterion];
  297. // criteriaHTML += '&#8226; '+crit.name+'\n<br>';
  298. //}
  299. /*var trans_html ='';
  300. number = 1;
  301. amount_of_TA_per_objective[index_per_objective]= [];
  302. for(trans in json.first.trans_actions[theObj.id]){
  303. transformative = json.first.trans_actions[theObj.id][trans];
  304. trans_html+= '<p>'+number.toString()+'. '+transformative.at_text+'\n\n<p>';
  305. number++;
  306. //criteriaHTML+= '';
  307. $('#theReport').append('<h5>For the objective: "<strong>'+theObj.text+'</strong>: <br><br> The transformative action: "<strong>'+json.first.trans_actions[theObj.id][trans].at_text+'</strong>": <h5><br>');
  308. form = $("<form/>",{
  309. 'id':'form'+counter,
  310. 'class':"form-for-ta"
  311. })
  312. $('#theReport').append("1. Was the transformative action done?: <br>");
  313. form.append('<label class="radio-inline"><input type="radio" id="hizo-trans-'+json.first.trans_actions[theObj.id][trans].id+'_typ-'+json.first.typ_objective_id[theObj.id].id+'-1" name="seHizo'+counter+'" value = "1">Yes</label>');
  314. form.append('<label class="radio-inline"><input type="radio" id="hizo-trans-'+json.first.trans_actions[theObj.id][trans].id+'_typ-'+json.first.typ_objective_id[theObj.id].id+'-0" name="seHizo'+counter+'" value = "0">No</label>');
  315. form.append('<br>2. Was the transformative action useful?<br>');
  316. form.append('<label class="radio-inline"><input type="radio" id="logro-trans-'+json.first.trans_actions[theObj.id][trans].id+'_typ-'+json.first.typ_objective_id[theObj.id].id+'-1" name="logro'+counter+'" value = "1">Yes</label>');
  317. form.append('<label class="radio-inline"><input type="radio" id="logro-trans-'+json.first.trans_actions[theObj.id][trans].id+'_typ-'+json.first.typ_objective_id[theObj.id].id+'-0" name="logro'+counter+'" value = "0">No</label>');
  318. form.append('<br>3. Is the transformative action going to be continued?<br>');
  319. form.append('<label class="radio-inline"><input type="radio" id="continued-trans-'+json.first.trans_actions[theObj.id][trans].id+'_typ-'+json.first.typ_objective_id[theObj.id].id+'-1" name="continued'+counter+'" value = "1">Yes</label>');
  320. form.append('<label class="radio-inline"><input type="radio" id="continued-trans-'+json.first.trans_actions[theObj.id][trans].id+'_typ-'+json.first.typ_objective_id[theObj.id].id+'-0" name="continued'+counter+'" value = "0">No</label>');
  321. form.append('<br><label for="comment2'+counter+'">Comments about TA:</label><textarea class="form-control" rows="3" name="comment2'+counter+'"></textarea>');
  322. form.append('<input class="hidden" name= "what_semester_'+counter+'"value = "'+json.first.semester.id+'"> ');
  323. $('#theReport').append(form);
  324. form.append('<input class="hidden" name= "transformative_'+counter+'"value = "'+json.first.trans_actions[theObj.id][trans].id+'"> ');
  325. form.append('<input class="hidden" name= "objective_'+counter+'"value = "'+json.first.typ_objective_id[theObj.id].id+'"> ');
  326. theTypId = json.first.typ_objective_id[theObj.id].id;
  327. /*for(fill_info in json.fill_info[theTypId]){
  328. theInfo = json.fill_info[theTypId][fill_info];
  329. $('#hizo-trans-'+fill_info+'_typ-'+theTypId+'-'+((theInfo.cycle_of_life)-1)).prop("checked", true);
  330. $('#logro-trans-'+fill_info+'_typ-'+theTypId+'-'+theInfo.accomplished).prop("checked", true);
  331. continuedSem = 1;
  332. if(!theInfo.semester_continue) continuedSem =0;
  333. $('#continued-trans-'+fill_info+'_typ-'+theTypId+'-'+continuedSem).prop("checked", true);
  334. }*/
  335. /*
  336. amount_of_TA_per_objective[index_per_objective].push(counter);
  337. counter+=1;
  338. }*/
  339. //$('#theReport').append()
  340. $table.row.add([
  341. objHTML,
  342. courseHTML,
  343. courseTAhtml
  344. ]);
  345. index_per_objective += 1;
  346. }
  347. $table.draw();
  348. }
  349. $divForSecondSemester = $('<div/>', {
  350. 'id': "secondSemester"
  351. });
  352. //Second Semester
  353. $divForSecondSemester.appendTo('#allTables');
  354. for (outcome in json.second.outcomes) {
  355. $panel = $('<div/>', {
  356. 'id': 'outcome_' + json.second.outcomes[outcome].id,
  357. 'class': 'panel panel-default'
  358. });
  359. $div = $('<div/>', {
  360. 'class': 'panel-heading'
  361. });
  362. $h4 = $('<h4/>', {
  363. 'class': 'panel-title',
  364. 'style': "cursor:auto!important;"
  365. }).html(json.second.outcomes[outcome].name);
  366. $('#theReport').append('<h4>' + json.second.outcomes[outcome].name + '</h4>');
  367. $div.append($h4);
  368. $panel.append($div);
  369. $div = $('<div/>', {
  370. 'class': 'panel-body'
  371. });
  372. $divTable = $('<div/>', {
  373. "class": "table-responsive"
  374. })
  375. $table = $('<table/>', {
  376. "class": "table table-striped table-condensed datatable",
  377. "style": "table-layout: fixed",
  378. "id": json.second.outcomes[outcome].id + 'second',
  379. "data-title": json.second.outcomes[outcome].name
  380. })
  381. $thead = $('<thead/>').html(
  382. "<tr><th>Objectives for courses</th><th>Criteria per Course</th><th>Transformative Actions</th></tr>"
  383. )
  384. $table.append($thead);
  385. $table.append($('<tbody/>'));
  386. $divTable.append($table);
  387. $div.append($divTable);
  388. $panel.append($div);
  389. $panel.appendTo($divForSecondSemester);
  390. $table = createDataTable($table);
  391. var outcomeID = json.second.outcomes[outcome].id;
  392. var nextLetter = 'A';
  393. for (objective in json.second.objectives[outcomeID]) {
  394. var theObj = json.second.objectives[outcomeID][objective];
  395. var objHTML = '<strong> ' + nextLetter + '. ' + theObj.text + '</strong>';
  396. nextLetter = nextChar(nextLetter);
  397. var courseHTML = '';
  398. var courseTAhtml = '';
  399. for (course in json.second.courses[theObj.id]) {
  400. var theCourse = json.second.courses[theObj.id][course];
  401. courseHTML += '&#8226' + theCourse.code + " " + theCourse.number + '\n\n\n<br>';
  402. courseTAhtml += '&#8226; ' + theCourse.code + " " + theCourse.number + '\n\n\n<br>';
  403. console.log(theCourse);
  404. console.log(json.second.criteria[theObj.id][theCourse.course_id]);
  405. // for(criterion in json.second.criteria[theObj.id][theCourse.typ_course_id]){
  406. for (criterion in json.second.criteria[theObj.id][theCourse.course_id]) {
  407. theCrit = json.second.criteria[theObj.id][theCourse.course_id][criterion];
  408. // theCrit = json.second.criteria[theObj.id][theCourse.typ_course_id][criterion];
  409. courseHTML += '&nbsp;&nbsp; ' + (parseInt(criterion) + 1) + ". " + theCrit.name +
  410. '\n\n<br>';
  411. }
  412. for (trans in json.second.trans_actions[theObj.id][theCourse.typ_course_id]) {
  413. theTA = json.second.trans_actions[theObj.id][theCourse.typ_course_id][trans]
  414. courseTAhtml += '\t&nbsp;&nbsp; ' + (parseInt(trans) + 1) + ". " + theTA
  415. .description + '\n\n<br>';
  416. }
  417. }
  418. //courseHTML += '</ul>';
  419. /*var criteriaHTML = '';
  420. for(criterion in json.second.criteria[theObj.id]){
  421. crit = json.second.criteria[theObj.id][criterion];
  422. criteriaHTML += '&#8226; '+crit.name+'\n<br>';
  423. }
  424. var trans_html ='';
  425. number = 1;
  426. amount_of_TA_per_objective[index_per_objective]= [];
  427. for(trans in json.second.trans_actions[theObj.id]){
  428. transformative = json.second.trans_actions[theObj.id][trans];
  429. trans_html+= '<p>'+number.toString() +'. '+transformative.at_text+'<p>\n\n';
  430. number++;
  431. $('#theReport').append('<h5>For the objective: "<strong>'+theObj.text+'</strong>: <br><br> The transformative action: "<strong>'+json.second.trans_actions[theObj.id][trans].at_text+'</strong>": <h5><br>');
  432. form = $("<form/>",{
  433. 'id':"form"+counter,
  434. 'class':"form-for-ta"
  435. })
  436. $('#theReport').append("1. Was the transformative action done?: <br>");
  437. form.append('<label class="radio-inline"><input type="radio" id="hizo-trans-'+json.second.trans_actions[theObj.id][trans].id+'_typ-'+json.second.typ_objective_id[theObj.id].id+'-1" name="seHizo'+counter+'" value = "1">Yes</label>');
  438. form.append('<label class="radio-inline"><input type="radio" id="hizo-trans-'+json.second.trans_actions[theObj.id][trans].id+'_typ-'+json.second.typ_objective_id[theObj.id].id+'-0" name="seHizo'+counter+'" value = "0">No</label>');
  439. form.append('<br>2. Was the transformative action useful?<br>');
  440. form.append('<label class="radio-inline"><input type="radio" id="logro-trans-'+json.second.trans_actions[theObj.id][trans].id+'_typ-'+json.second.typ_objective_id[theObj.id].id+'-1" name="logro'+counter+'" value = "1">Yes</label>');
  441. form.append('<label class="radio-inline"><input type="radio" id="logro-trans-'+json.second.trans_actions[theObj.id][trans].id+'_typ-'+json.second.typ_objective_id[theObj.id].id+'-0" name="logro'+counter+'" value = "0">No</label>');
  442. form.append('<br>3. Is the transformative action going to be continued?<br>');
  443. form.append('<label class="radio-inline"><input type="radio" id="continued-trans-'+json.second.trans_actions[theObj.id][trans].id+'_typ-'+json.second.typ_objective_id[theObj.id].id+'-1" name="continued'+counter+'" value = "1">Yes</label>');
  444. form.append('<label class="radio-inline"><input type="radio" id="continued-trans-'+json.second.trans_actions[theObj.id][trans].id+'_typ-'+json.second.typ_objective_id[theObj.id].id+'-0" name="continued'+counter+'" value = "0">No</label>');
  445. form.append('<br><label for="comment">Comments about TA:</label><textarea class="form-control" rows="3" name="comment2'+counter+'"></textarea>');
  446. form.append('<input class="hidden" name= "what_semester_'+counter+'"value = "'+json.second.semester.id+'"> ');
  447. form.append('<input class="hidden" name= "transformative_'+counter+'"value = "'+json.second.trans_actions[theObj.id][trans].id+'"> ');
  448. form.append('<input class="hidden" name= "objective_'+counter+'"value = "'+json.second.typ_objective_id[theObj.id].id+'"> ');
  449. $('#theReport').append(form);
  450. theTypId = json.second.typ_objective_id[theObj.id].id;
  451. /*
  452. for(fill_info in json.fill_info[theTypId]){
  453. theInfo = json.fill_info[theTypId][fill_info];
  454. $('#hizo-trans-'+fill_info+'_typ-'+theTypId+'-'+((theInfo.cycle_of_life)-1)).prop("checked", true);
  455. $('#logro-trans-'+fill_info+'_typ-'+theTypId+'-'+theInfo.accomplished).prop("checked", true);
  456. continuedSem = 1;
  457. if(!theInfo.semester_continue) continuedSem =0;
  458. $('#continued-trans-'+fill_info+'_typ-'+theTypId+'-'+continuedSem).prop("checked", true);
  459. }
  460. amount_of_TA_per_objective[index_per_objective].push(counter);
  461. counter+=1;
  462. }*/
  463. index_per_objective += 1;
  464. $table.row.add([
  465. objHTML,
  466. courseHTML,
  467. courseTAhtml
  468. ]);
  469. }
  470. $table.draw();
  471. }
  472. $('#secondSemester').hide();
  473. },
  474. 'json'
  475. )
  476. }
  477. function nextChar(c) {
  478. return String.fromCharCode(c.charCodeAt(0) + 1);
  479. }
  480. function createDataTable(table1) {
  481. title1 = table1[0].dataset.title
  482. table = $(table1).DataTable({
  483. lengthMenu: [5, 10, 25, 50],
  484. autoWidth: false,
  485. retrieve: true,
  486. pageLength: 10,
  487. // //fixed cols
  488. // fixedColumns: {
  489. // leftColumns: 1,
  490. // },
  491. // scrollY: "600px",
  492. // scrollX: true,
  493. // scrollCollapse: true,
  494. bSortCellsTop: true, // To apply sort using top row only
  495. order: [
  496. [0, "asc"]
  497. ],
  498. dom: 'Bflrtip',
  499. buttons: [{
  500. extend: 'collection',
  501. text: 'Export <span class="caret"></span>',
  502. buttons: [{
  503. extend: 'print',
  504. exportOptions: {
  505. columns: ':visible'
  506. },
  507. text: 'Print',
  508. },
  509. {
  510. extend: 'excelHtml5',
  511. exportOptions: {
  512. columns: ':visible'
  513. }
  514. },
  515. {
  516. extend: 'pdfHtml5',
  517. exportOptions: {
  518. columns: ':visible',
  519. stripNewlines: false,
  520. title: title1,
  521. text: title1,
  522. },
  523. customize: function(doc, dt) {
  524. //$('#loadingModal').modal('show');
  525. tableCopy = doc.content[1];
  526. doc.content[1] = {
  527. text: dt.exportOptions.text,
  528. style: 'title',
  529. margin: [0, 0, 0, 12]
  530. };
  531. doc.content[2] = tableCopy;
  532. doc.content[2].table.widths = ['33%', '33%', '34%']
  533. doc.pageSize = 'LEGAL';
  534. doc.pageOrientation = 'landscape';
  535. doc.defaultStyle.fontSize = 10;
  536. doc.styles.tableHeader.fillColor = '#E70033';
  537. // doc.content[1].layout= 'lightHorizontalLines';
  538. doc.content[2].layout = {
  539. hLineWidth: function(i, node) {
  540. if (i === 1) {
  541. return 2;
  542. } else if (i > 1) {
  543. return 1;
  544. } else {
  545. return 0;
  546. }
  547. },
  548. vLineWidth: function(i, node) {
  549. return 0;
  550. },
  551. hLineColor: function(i, node) {
  552. if (i === 1) {
  553. return '#000';
  554. } else if (i > 1) {
  555. return '#ccc';
  556. } else {
  557. return 'transparent';
  558. }
  559. },
  560. // vLineColor: function (i, node) {
  561. // return (i === 0 || i === node.table.widths.length) ? 'black' : 'gray';
  562. // },
  563. paddingLeft: function(i, node) {
  564. return 5;
  565. },
  566. paddingRight: function(i, node) {
  567. return 5;
  568. },
  569. paddingTop: function(i, node) {
  570. return 5;
  571. },
  572. paddingBottom: function(i, node) {
  573. return 5;
  574. }
  575. };
  576. doc.content.splice(0, 0, {
  577. margin: [0, 0, 0, 12],
  578. alignment: 'center',
  579. width: 150,
  580. image: ''
  581. });
  582. //$('#loadingModal').modal('hide');
  583. }
  584. },
  585. ]
  586. },
  587. {
  588. extend: 'colvis',
  589. columns: ':gt(0)',
  590. text: 'Column visibility <span class="caret"></span>',
  591. }
  592. ],
  593. });
  594. // tables.push(table);
  595. // Apply the search
  596. table.columns().every(function() {
  597. // Search by keyword
  598. var column = this;
  599. $('input.column-search-bar', column.footer()).on('keyup change', function() {
  600. if (column.search() !== this.value) {
  601. console.log(this.value)
  602. column
  603. .search(this.value)
  604. .draw();
  605. }
  606. });
  607. // Search by dropdown menu
  608. column.data().unique().sort().each(function(d, j) {
  609. $('select.column-search-select', column.footer()).append('<option value="' + d + '">' +
  610. d + '</option>');
  611. });
  612. $('.column-search-select', column.footer()).on('change', function() {
  613. var val = $.fn.dataTable.util.escapeRegex($(this).val());
  614. column
  615. .search(val ? '^' + val + '$' : '', true, false)
  616. .draw();
  617. });
  618. });
  619. table.buttons().container()
  620. .appendTo($('.col-sm-6:eq(0)', table.table().container()));
  621. $(document).on('click', '.buttons-columnVisibility', function() {
  622. console.log('visibility toggled');
  623. table.columns.adjust().responsive.recalc();
  624. });
  625. return table;
  626. }
  627. function createTheExportAll(table1) {
  628. title1 = table1[0].dataset.title
  629. table = $(table1).DataTable({
  630. lengthMenu: [5, 10, 25, 50],
  631. autoWidth: false,
  632. retrieve: true,
  633. pageLength: 10,
  634. // //fixed cols
  635. // fixedColumns: {
  636. // leftColumns: 1,
  637. // },
  638. // scrollY: "600px",
  639. // scrollX: true,
  640. // scrollCollapse: true,
  641. bSortCellsTop: true, // To apply sort using top row only
  642. order: [
  643. [0, "asc"]
  644. ],
  645. dom: 'Bflrtip',
  646. buttons: [{
  647. extend: 'pdfHtml5',
  648. attr: {
  649. id: 'print_BUTTON'
  650. },
  651. exportOptions: {
  652. columns: ':visible',
  653. stripNewlines: false,
  654. title: title1,
  655. text: title1,
  656. },
  657. customize: function(doc, dt) {
  658. //$('#loadingModal').modal('show');
  659. $('.panel').each(function(index, element) {
  660. title = this.children[0].innerText;
  661. table = this.children[1].children[0].children[0].children[3];
  662. theadTR = table.children[0].children[0];
  663. body1 = [];
  664. body2 = [];
  665. $(theadTR).children('th').each(function(ind, el) {
  666. text1 = this.innerText;
  667. style1 = "tableHeader";
  668. body2.push({
  669. text: text1,
  670. style: style1
  671. })
  672. });
  673. body1.push(body2);
  674. tbody = table.children[1];
  675. $(tbody).children('tr').each(function() {
  676. body2 = [];
  677. $(this).children('td').each(function(ind, el) {
  678. text1 = this.innerText;
  679. style1 = (ind % 2 == 0) ? "tableBodyEven" :
  680. "tableBodyOdd";
  681. body2.push({
  682. text: text1,
  683. style: style1
  684. });
  685. });
  686. body1.push(body2);
  687. });
  688. layout1 = "noBorders";
  689. doc.content.push({
  690. text: title,
  691. style: "title",
  692. margin: [0, 0, 0, 12],
  693. });
  694. doc.content.push({
  695. table: {
  696. body: body1,
  697. headerRows: 1,
  698. widths: ['33%', '33%', '34%']
  699. },
  700. layout: "noBorders",
  701. pageBreak: 'after'
  702. });
  703. })
  704. doc.content[1] = {
  705. text: "Annual Plan ",
  706. style: 'title',
  707. margin: [0, 0, 0, 12]
  708. };
  709. doc.pageSize = 'LEGAL';
  710. doc.pageOrientation = 'landscape';
  711. doc.defaultStyle.fontSize = 10;
  712. doc.styles.tableHeader.fillColor = '#E70033';
  713. // doc.content[1].layout= 'lightHorizontalLines';
  714. for (j = 3; j < doc.content.length; j += 2) {
  715. doc.content[j].layout = {
  716. hLineWidth: function(i, node) {
  717. if (i === 1) {
  718. return 2;
  719. } else if (i > 1) {
  720. return 1;
  721. } else {
  722. return 0;
  723. }
  724. },
  725. vLineWidth: function(i, node) {
  726. return 0;
  727. },
  728. hLineColor: function(i, node) {
  729. if (i === 1) {
  730. return '#000';
  731. } else if (i > 1) {
  732. return '#ccc';
  733. } else {
  734. return 'transparent';
  735. }
  736. },
  737. // vLineColor: function (i, node) {
  738. // return (i === 0 || i === node.table.widths.length) ? 'black' : 'gray';
  739. // },
  740. paddingLeft: function(i, node) {
  741. return 5;
  742. },
  743. paddingRight: function(i, node) {
  744. return 5;
  745. },
  746. paddingTop: function(i, node) {
  747. return 5;
  748. },
  749. paddingBottom: function(i, node) {
  750. return 5;
  751. }
  752. };
  753. }
  754. doc.content.splice(0, 0, {
  755. margin: [0, 0, 0, 12],
  756. alignment: 'center',
  757. width: 150,
  758. image: ''
  759. });
  760. //$('#loadingModal').modal('hide');
  761. }
  762. }
  763. ],
  764. });
  765. // tables.push(table);
  766. // Apply the search
  767. table.columns().every(function() {
  768. // Search by keyword
  769. var column = this;
  770. $('input.column-search-bar', column.footer()).on('keyup change', function() {
  771. if (column.search() !== this.value) {
  772. console.log(this.value)
  773. column
  774. .search(this.value)
  775. .draw();
  776. }
  777. });
  778. // Search by dropdown menu
  779. column.data().unique().sort().each(function(d, j) {
  780. $('select.column-search-select', column.footer()).append('<option value="' + d + '">' +
  781. d + '</option>');
  782. });
  783. $('.column-search-select', column.footer()).on('change', function() {
  784. var val = $.fn.dataTable.util.escapeRegex($(this).val());
  785. column
  786. .search(val ? '^' + val + '$' : '', true, false)
  787. .draw();
  788. });
  789. });
  790. table.buttons().container()
  791. .appendTo($('.col-sm-6:eq(0)', table.table().container()));
  792. $(document).on('click', '.buttons-columnVisibility', function() {
  793. console.log('visibility toggled');
  794. table.columns.adjust().responsive.recalc();
  795. });
  796. return table;
  797. }
  798. function createTheReportAll(table1) {
  799. title1 = table1[0].dataset.title
  800. table = $(table1).DataTable({
  801. lengthMenu: [5, 10, 25, 50],
  802. autoWidth: false,
  803. retrieve: true,
  804. pageLength: 10,
  805. // //fixed cols
  806. // fixedColumns: {
  807. // leftColumns: 1,
  808. // },
  809. // scrollY: "600px",
  810. // scrollX: true,
  811. // scrollCollapse: true,
  812. bSortCellsTop: true, // To apply sort using top row only
  813. order: [
  814. [0, "asc"]
  815. ],
  816. dom: 'Bflrtip',
  817. buttons: [{
  818. extend: 'pdfHtml5',
  819. attr: {
  820. id: 'report_print'
  821. },
  822. exportOptions: {
  823. columns: ':visible',
  824. stripNewlines: false,
  825. title: title1,
  826. text: title1,
  827. },
  828. customize: function(doc, dt) {
  829. //$('#loadingModal').modal('show');
  830. counterTable = 0;
  831. $('.panel').each(function(index, element) {
  832. title = this.children[0].innerText;
  833. table = this.children[1].children[0].children[0].children[3];
  834. theadTR = table.children[0].children[0];
  835. body1 = [];
  836. body2 = [];
  837. $(theadTR).children('th').each(function(ind, el) {
  838. text1 = this.innerText;
  839. style1 = "tableHeader";
  840. body2.push({
  841. text: text1,
  842. style: style1
  843. })
  844. });
  845. style1 = "tableHeader";
  846. body2.push({
  847. text: "Was the transformative action achieved?",
  848. style: style1
  849. })
  850. body2.push({
  851. text: "Was it useful?",
  852. style: style1
  853. });
  854. body2.push({
  855. text: "Is it going to be continued next semester?",
  856. style: style1
  857. });
  858. body2.push({
  859. text: "Comments about TA",
  860. style: style1
  861. });
  862. body1.push(body2);
  863. tbody = table.children[1];
  864. $(tbody).children('tr').each(function() {
  865. body2 = [];
  866. indexFor = 0
  867. $(this).children('td').each(function(ind, el) {
  868. text1 = this.innerText;
  869. indexFor = ind;
  870. style1 = (ind % 2 == 0) ? "tableBodyEven" :
  871. "tableBodyOdd";
  872. body2.push({
  873. text: text1,
  874. style: style1
  875. });
  876. });
  877. $()
  878. if ($('input[name="seHizo' + amount_of_TA_per_objective[
  879. counterTable][0] + '"]:checked').val() == "1") {
  880. ta_done = '1. Yes';
  881. } else {
  882. ta_done = '1. No';
  883. }
  884. if ($('input[name="logro' + amount_of_TA_per_objective[
  885. counterTable][0] + '"]:checked').val() == "1") {
  886. ta_logr = "1. Yes";
  887. } else {
  888. ta_logr = "1. No";
  889. }
  890. paragraph2 = '1. ' + $('textarea[name="comment2' +
  891. amount_of_TA_per_objective[counterTable][0] +
  892. '"]').val();
  893. if ($('input[name="continued' +
  894. amount_of_TA_per_objective[counterTable][0] +
  895. '"]:checked').val() == "1") {
  896. ta_continued = "1. Yes";
  897. } else {
  898. ta_continued = "1. No";
  899. }
  900. for (j = 1; j < amount_of_TA_per_objective[counterTable]
  901. .length; j++) {
  902. if ($('input[name="seHizo' +
  903. amount_of_TA_per_objective[counterTable][
  904. j] + '"]:checked').val() == "1") {
  905. ta_done += '\n\n' + (j + 1) + '. Yes';
  906. } else {
  907. ta_done += '\n\n' + (j + 1) + '. No';
  908. }
  909. if ($('input[name="logro' +
  910. amount_of_TA_per_objective[counterTable][
  911. j] + '"]:checked').val() == "1") {
  912. ta_logr += '\n\n' + (j + 1) + '. Yes';
  913. } else {
  914. ta_logr += '\n\n' + (j + 1) + '. No';
  915. }
  916. paragraph2 += '\n\n' + (j + 1) + '. ' + $(
  917. 'textarea[name="comment2' +
  918. amount_of_TA_per_objective[counterTable][
  919. j] + '"]').val();
  920. if ($('input[name="continued' +
  921. amount_of_TA_per_objective[counterTable][
  922. j] + '"]:checked').val() == "1") {
  923. ta_continued += '\n\n' + (j + 1) + '. Yes';
  924. } else {
  925. ta_continued += '\n\n' + (j + 1) + '. No';
  926. }
  927. }
  928. indexFor += 1;
  929. style1 = (indexFor % 2 == 0) ? "tableBodyEven" :
  930. "tableBodyOdd";
  931. indexFor += 1;
  932. style2 = (indexFor % 2 == 0) ? "tableBodyEven" :
  933. "tableBodyOdd";
  934. indexFor += 1;
  935. style3 = (indexFor % 2 == 0) ? "tableBodyEven" :
  936. "tableBodyOdd";
  937. indexFor += 1;
  938. style4 = (indexFor % 2 == 0) ? "tableBodyEven" :
  939. "tableBodyOdd";
  940. body2.push({
  941. text: ta_done,
  942. style: style1
  943. });
  944. body2.push({
  945. text: ta_logr,
  946. style: style2
  947. });
  948. body2.push({
  949. text: ta_continued,
  950. style: style3
  951. });
  952. body2.push({
  953. text: paragraph2,
  954. style: style4
  955. });
  956. body1.push(body2);
  957. counterTable += 1;
  958. });
  959. layout1 = "noBorders";
  960. doc.content.push({
  961. text: title,
  962. style: "title",
  963. margin: [0, 0, 0, 12],
  964. });
  965. doc.content.push({
  966. table: {
  967. body: body1,
  968. headerRows: 1,
  969. widths: ['12.5%', '12.5%', '12.5%', '12.5%',
  970. '12.5%', '12.5%', '12.5%', '12.5%'
  971. ]
  972. },
  973. layout: "noBorders",
  974. pageBreak: 'after'
  975. });
  976. })
  977. doc.content[1] = {
  978. text: "Annual Plan",
  979. style: 'title',
  980. margin: [0, 0, 0, 12]
  981. };
  982. doc.pageSize = 'LEGAL';
  983. doc.pageOrientation = 'landscape';
  984. doc.defaultStyle.fontSize = 10;
  985. doc.styles.tableHeader.fillColor = '#E70033';
  986. // doc.content[1].layout= 'lightHorizontalLines';
  987. for (j = 3; j < doc.content.length; j += 2) {
  988. doc.content[j].layout = {
  989. hLineWidth: function(i, node) {
  990. if (i === 1) {
  991. return 2;
  992. } else if (i > 1) {
  993. return 1;
  994. } else {
  995. return 0;
  996. }
  997. },
  998. vLineWidth: function(i, node) {
  999. return 0;
  1000. },
  1001. hLineColor: function(i, node) {
  1002. if (i === 1) {
  1003. return '#000';
  1004. } else if (i > 1) {
  1005. return '#ccc';
  1006. } else {
  1007. return 'transparent';
  1008. }
  1009. },
  1010. // vLineColor: function (i, node) {
  1011. // return (i === 0 || i === node.table.widths.length) ? 'black' : 'gray';
  1012. // },
  1013. paddingLeft: function(i, node) {
  1014. return 5;
  1015. },
  1016. paddingRight: function(i, node) {
  1017. return 5;
  1018. },
  1019. paddingTop: function(i, node) {
  1020. return 5;
  1021. },
  1022. paddingBottom: function(i, node) {
  1023. return 5;
  1024. }
  1025. };
  1026. }
  1027. doc.content.splice(0, 0, {
  1028. margin: [0, 0, 0, 12],
  1029. alignment: 'center',
  1030. width: 150,
  1031. image: ''
  1032. });
  1033. //$('#loadingModal').modal('hide');
  1034. }
  1035. }
  1036. ],
  1037. });
  1038. // tables.push(table);
  1039. // Apply the search
  1040. table.columns().every(function() {
  1041. // Search by keyword
  1042. var column = this;
  1043. $('input.column-search-bar', column.footer()).on('keyup change', function() {
  1044. if (column.search() !== this.value) {
  1045. console.log(this.value)
  1046. column
  1047. .search(this.value)
  1048. .draw();
  1049. }
  1050. });
  1051. // Search by dropdown menu
  1052. column.data().unique().sort().each(function(d, j) {
  1053. $('select.column-search-select', column.footer()).append('<option value="' + d + '">' +
  1054. d + '</option>');
  1055. });
  1056. $('.column-search-select', column.footer()).on('change', function() {
  1057. var val = $.fn.dataTable.util.escapeRegex($(this).val());
  1058. column
  1059. .search(val ? '^' + val + '$' : '', true, false)
  1060. .draw();
  1061. });
  1062. });
  1063. table.buttons().container()
  1064. .appendTo($('.col-sm-6:eq(0)', table.table().container()));
  1065. $(document).on('click', '.buttons-columnVisibility', function() {
  1066. console.log('visibility toggled');
  1067. table.columns.adjust().responsive.recalc();
  1068. });
  1069. return table;
  1070. }
  1071. function createTheTrans(table1) {
  1072. title1 = table1[0].dataset.title
  1073. table = $(table1).DataTable({
  1074. lengthMenu: [5, 10, 25, 50],
  1075. autoWidth: false,
  1076. retrieve: true,
  1077. pageLength: 10,
  1078. // //fixed cols
  1079. // fixedColumns: {
  1080. // leftColumns: 1,
  1081. // },
  1082. // scrollY: "600px",
  1083. // scrollX: true,
  1084. // scrollCollapse: true,
  1085. bSortCellsTop: true, // To apply sort using top row only
  1086. order: [
  1087. [0, "asc"]
  1088. ],
  1089. dom: 'Bflrtip',
  1090. buttons: [{
  1091. extend: 'pdfHtml5',
  1092. attr: {
  1093. id: 'trans_print'
  1094. },
  1095. exportOptions: {
  1096. columns: ':visible',
  1097. stripNewlines: false,
  1098. title: title1,
  1099. text: title1,
  1100. },
  1101. customize: function(doc, dt) {
  1102. //$('#loadingModal').modal('show');
  1103. this_is_the_json = json_to_use.Trans_act;
  1104. table = $('#allTransToExport');
  1105. for (trans in this_is_the_json) {
  1106. if (json_to_use.suggested && json_to_use.suggested[trans]) {
  1107. suggested = json_to_use.suggested[trans][0];
  1108. } else suggested = 0;
  1109. title_trans = this_is_the_json[trans].description;
  1110. json_outcomes = json_to_use.outcomes[trans];
  1111. if (suggested) {
  1112. doc.content.push({
  1113. text: '\n\n' + title_trans + '[' + suggested.surnames +
  1114. ', ' + suggested.first_name + ']',
  1115. style: "title",
  1116. margin: [0, 0, 0, 12],
  1117. });
  1118. } else {
  1119. doc.content.push({
  1120. text: '\n\n' + title_trans,
  1121. style: "title",
  1122. margin: [0, 0, 0, 12],
  1123. });
  1124. }
  1125. for (outcome_index in json_outcomes) {
  1126. outcome = json_outcomes[outcome_index];
  1127. title_outcome = outcome.name;
  1128. theadTR = table[0].children[0].children[0];
  1129. body1 = [];
  1130. body2 = [];
  1131. $(theadTR).children('th').each(function(ind, el) {
  1132. text1 = this.innerText;
  1133. style1 = "tableHeader";
  1134. body2.push({
  1135. text: text1,
  1136. style: style1
  1137. })
  1138. });
  1139. body1.push(body2);
  1140. doc.content.push({
  1141. text: '\n\n' + title_outcome + '\n',
  1142. style: "title",
  1143. margin: [0, 0, 0, 12],
  1144. });
  1145. counter = 0;
  1146. for (typ_index in json_to_use.typ_objective[outcome.id][trans]) {
  1147. body2 = [];
  1148. typ = json_to_use.typ_objective[outcome.id][trans][typ_index];
  1149. objective = json_to_use.objective[outcome.id][typ.id][trans];
  1150. coordinator = json_to_use.coordinator[outcome.id][typ.id][trans];
  1151. proposed_date = json_to_use.proposed_date[outcome.id][typ.id][trans]
  1152. .proposed_date;
  1153. all_info = json_to_use.all_info_report[outcome.id][typ.id][trans];
  1154. if (all_info.cycle_of_life == 2) {
  1155. cycle = "Realized";
  1156. } else {
  1157. cycle = "Proposed";
  1158. }
  1159. if (all_info.semester_continue) {
  1160. cycle += " and continued";
  1161. } else {
  1162. cycle += "and discontinued";
  1163. }
  1164. semester_used = all_info.name;
  1165. style1 = (counter % 2 == 0) ? "tableBodyEven" : "tableBodyOdd";
  1166. body2.push({
  1167. text: objective.text,
  1168. style: style1
  1169. });
  1170. counter += 1;
  1171. style1 = (counter % 2 == 0) ? "tableBodyEven" : "tableBodyOdd";
  1172. body2.push({
  1173. text: proposed_date.substr(0, 10),
  1174. style: style1
  1175. });
  1176. counter += 1;
  1177. style1 = (counter % 2 == 0) ? "tableBodyEven" : "tableBodyOdd";
  1178. body2.push({
  1179. text: coordinator.surnames + ', ' + coordinator
  1180. .first_name,
  1181. style: style1
  1182. });
  1183. counter += 1;
  1184. style1 = (counter % 2 == 0) ? "tableBodyEven" : "tableBodyOdd";
  1185. body2.push({
  1186. text: cycle,
  1187. style: style1
  1188. });
  1189. counter += 1;
  1190. style1 = (counter % 2 == 0) ? "tableBodyEven" : "tableBodyOdd";
  1191. body2.push({
  1192. text: semester_used,
  1193. style: style1
  1194. });
  1195. counter += 1;
  1196. style1 = (counter % 2 == 0) ? "tableBodyEven" : "tableBodyOdd";
  1197. body2.push({
  1198. text: '',
  1199. style: style1
  1200. });
  1201. body1.push(body2);
  1202. }
  1203. doc.content.push({
  1204. table: {
  1205. body: body1,
  1206. headerRows: 1,
  1207. widths: ['30%', '12%', '14%', '14%', '10%', '20%']
  1208. },
  1209. layout: "noBorders"
  1210. });
  1211. }
  1212. }
  1213. doc.content[1] = {
  1214. text: "Transformative Actions Report",
  1215. style: 'title',
  1216. margin: [0, 0, 0, 12]
  1217. };
  1218. doc.pageSize = 'LEGAL';
  1219. doc.pageOrientation = 'landscape';
  1220. doc.defaultStyle.fontSize = 10;
  1221. doc.styles.tableHeader.fillColor = '#E70033';
  1222. // doc.content[1].layout= 'lightHorizontalLines';
  1223. for (j = 3; j < doc.content.length; j += 2) {
  1224. doc.content[j].layout = {
  1225. hLineWidth: function(i, node) {
  1226. if (i === 1) {
  1227. return 2;
  1228. } else if (i > 1) {
  1229. return 1;
  1230. } else {
  1231. return 0;
  1232. }
  1233. },
  1234. vLineWidth: function(i, node) {
  1235. return 0;
  1236. },
  1237. hLineColor: function(i, node) {
  1238. if (i === 1) {
  1239. return '#000';
  1240. } else if (i > 1) {
  1241. return '#ccc';
  1242. } else {
  1243. return 'transparent';
  1244. }
  1245. },
  1246. // vLineColor: function (i, node) {
  1247. // return (i === 0 || i === node.table.widths.length) ? 'black' : 'gray';
  1248. // },
  1249. paddingLeft: function(i, node) {
  1250. return 5;
  1251. },
  1252. paddingRight: function(i, node) {
  1253. return 5;
  1254. },
  1255. paddingTop: function(i, node) {
  1256. return 5;
  1257. },
  1258. paddingBottom: function(i, node) {
  1259. return 5;
  1260. }
  1261. };
  1262. }
  1263. doc.content.splice(0, 0, {
  1264. margin: [0, 0, 0, 12],
  1265. alignment: 'center',
  1266. width: 150,
  1267. image: ''
  1268. });
  1269. //$('#loadingModal').modal('hide');
  1270. }
  1271. }
  1272. ],
  1273. });
  1274. // tables.push(table);
  1275. // Apply the search
  1276. table.columns().every(function() {
  1277. // Search by keyword
  1278. var column = this;
  1279. $('input.column-search-bar', column.footer()).on('keyup change', function() {
  1280. if (column.search() !== this.value) {
  1281. console.log(this.value)
  1282. column
  1283. .search(this.value)
  1284. .draw();
  1285. }
  1286. });
  1287. // Search by dropdown menu
  1288. column.data().unique().sort().each(function(d, j) {
  1289. $('select.column-search-select', column.footer()).append('<option value="' + d + '">' +
  1290. d + '</option>');
  1291. });
  1292. $('.column-search-select', column.footer()).on('change', function() {
  1293. var val = $.fn.dataTable.util.escapeRegex($(this).val());
  1294. column
  1295. .search(val ? '^' + val + '$' : '', true, false)
  1296. .draw();
  1297. });
  1298. });
  1299. table.buttons().container()
  1300. .appendTo($('.col-sm-6:eq(0)', table.table().container()));
  1301. $(document).on('click', '.buttons-columnVisibility', function() {
  1302. console.log('visibility toggled');
  1303. table.columns.adjust().responsive.recalc();
  1304. });
  1305. return table;
  1306. }
  1307. </script>
  1308. @stop
  1309. @section('included-js')
  1310. @include('global._datatables_js')
  1311. @stop