No Description

view_formative.blade.php 51KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468
  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. <script type="text/javascript">
  19. function filterOutcomes() {
  20. // Declare variables
  21. var input, filter, div, li, i, outcomeText;
  22. input = document.getElementById('userInput');
  23. filter = input.value.toUpperCase();
  24. div = document.getElementById("list");
  25. li = div.getElementsByTagName('li');
  26. // Loop through all list items, and hide those who don't match the search query
  27. for (i = 0; i < li.length; i++) {
  28. outcomeText = li[i].textContent;
  29. if (outcomeText.toUpperCase().indexOf(filter) > -1) {
  30. li[i].style.display = "";
  31. } else {
  32. li[i].style.display = "none";
  33. }
  34. }
  35. }
  36. </script>
  37. <div class="row" style="display: flex;">
  38. <div class="category">
  39. <label for="school">School</label>
  40. <div class="select">
  41. <select class="selectpicker" data-live-search='true' name="school" id="school">
  42. @foreach ($schools as $school)
  43. <option value="{{ $school->id }}">{{ $school->name }}</option>
  44. @endforeach
  45. </select>
  46. </div>
  47. </div>
  48. <div class="category">
  49. <label for="program">Academic Program</label>
  50. <div class="select">
  51. <select class="selectpicker" data-live-search='true' name="program" id="program">
  52. @foreach ($programs as $program)
  53. <option value="{{ $program->id }}">{{ $program->name }}</option>
  54. @endforeach
  55. </select>
  56. </div>
  57. </div>
  58. <div class="category">
  59. <label for="semesters">Semester</label>
  60. <div class="select">
  61. <select class="selectpicker" data-live-search='true' name="semesters" id="semesters">
  62. @foreach ($semesters as $semester)
  63. <option value="{{ $semester->id }}">{{ $semester->name }}</option>
  64. @endforeach
  65. </select>
  66. </div>
  67. </div>
  68. </div>
  69. <br>
  70. <div class="row">
  71. <div class="col-md-3">
  72. <input class="form-control" type="text" id="userInput" onkeyup="filterOutcomes()"
  73. placeholder="Search for Learning Outcomes..">
  74. <div class="list-group" id='list'>
  75. @foreach ($outcomes as $outcome)
  76. <li data-outcome-id="{{ $outcome->id }}" class="list-group-item"
  77. onclick="fetchData($(this),$('#semesters'), $('#program') )">{{ $outcome->name }} </li>
  78. @endforeach
  79. </div>
  80. </div>
  81. <div class="col-md-9">
  82. <div id="transformative-display">
  83. </div>
  84. <!--<div id="outcome-display" class="panel panel-default">
  85. <div class="panel-heading">
  86. <h4 class=" panel-title" style="cursor:auto!important;">
  87. </h4>
  88. </div>
  89. <div class="panel-body">
  90. <p class="outcome-definition "></p>
  91. <div class="table-responsive table-responsive-0">
  92. {{-- tables are appended here --}}
  93. {{-- <table id="example" class="table table-striped table-condensed" width="100%"></table> --}}
  94. </div>
  95. </div>
  96. </div>-->
  97. </div>
  98. <div class="col-md-9">
  99. <div class="no-outcome alert alert-info">
  100. <p>Select a Learning Outcome to view its information</p>
  101. </div>
  102. </div>
  103. </div>
  104. <script>
  105. function createDataTable(table1) {
  106. title1 = table1[0].dataset.title
  107. table = $(table1).DataTable({
  108. lengthMenu: [5, 10, 25, 50],
  109. autoWidth: false,
  110. retrieve: true,
  111. pageLength: 10,
  112. // //fixed cols
  113. // fixedColumns: {
  114. // leftColumns: 1,
  115. // },
  116. // scrollY: "600px",
  117. // scrollX: true,
  118. // scrollCollapse: true,
  119. columnDefs: [{
  120. width: 200,
  121. targets: 0
  122. }],
  123. fixedColumns: true,
  124. bSortCellsTop: true, // To apply sort using top row only
  125. order: [
  126. [0, "asc"]
  127. ],
  128. dom: 'Bflrtip',
  129. buttons: [{
  130. extend: 'collection',
  131. text: 'Export <span class="caret"></span>',
  132. buttons: [{
  133. extend: 'print',
  134. exportOptions: {
  135. columns: ':visible'
  136. },
  137. text: 'Print',
  138. },
  139. {
  140. extend: 'excelHtml5',
  141. exportOptions: {
  142. columns: ':visible'
  143. }
  144. },
  145. {
  146. extend: 'pdfHtml5',
  147. exportOptions: {
  148. columns: ':visible',
  149. stripNewlines: false,
  150. title: title1,
  151. text: title1,
  152. },
  153. customize: function(doc, dt) {
  154. //$('#loadingModal').modal('show');
  155. tableCopy = doc.content[1];
  156. doc.content[1] = {
  157. text: dt.exportOptions.text,
  158. style: 'title',
  159. margin: [0, 0, 0, 12]
  160. };
  161. doc.content[2] = tableCopy;
  162. doc.content[2].table.widths = ['20%', '20%', '20%', '20%', '20%']
  163. doc.pageSize = 'LEGAL';
  164. doc.pageOrientation = 'landscape';
  165. doc.defaultStyle.fontSize = 10;
  166. doc.styles.tableHeader.fillColor = '#E70033';
  167. // doc.content[1].layout= 'lightHorizontalLines';
  168. doc.content[2].layout = {
  169. hLineWidth: function(i, node) {
  170. if (i === 1) {
  171. return 2;
  172. } else if (i > 1) {
  173. return 1;
  174. } else {
  175. return 0;
  176. }
  177. },
  178. vLineWidth: function(i, node) {
  179. return 0;
  180. },
  181. hLineColor: function(i, node) {
  182. if (i === 1) {
  183. return '#000';
  184. } else if (i > 1) {
  185. return '#ccc';
  186. } else {
  187. return 'transparent';
  188. }
  189. },
  190. // vLineColor: function (i, node) {
  191. // return (i === 0 || i === node.table.widths.length) ? 'black' : 'gray';
  192. // },
  193. paddingLeft: function(i, node) {
  194. return 5;
  195. },
  196. paddingRight: function(i, node) {
  197. return 5;
  198. },
  199. paddingTop: function(i, node) {
  200. return 5;
  201. },
  202. paddingBottom: function(i, node) {
  203. return 5;
  204. }
  205. };
  206. doc.content.splice(0, 0, {
  207. margin: [0, 0, 0, 12],
  208. alignment: 'center',
  209. width: 150,
  210. image: ''
  211. });
  212. //$('#loadingModal').modal('hide');
  213. }
  214. },
  215. ]
  216. },
  217. {
  218. extend: 'colvis',
  219. columns: ':gt(0)',
  220. text: 'Column visibility <span class="caret"></span>',
  221. }
  222. ],
  223. });
  224. // tables.push(table);
  225. // Apply the search
  226. table.columns().every(function() {
  227. // Search by keyword
  228. var column = this;
  229. $('input.column-search-bar', column.footer()).on('keyup change', function() {
  230. if (column.search() !== this.value) {
  231. console.log(this.value)
  232. column
  233. .search(this.value)
  234. .draw();
  235. }
  236. });
  237. // Search by dropdown menu
  238. column.data().unique().sort().each(function(d, j) {
  239. $('select.column-search-select', column.footer()).append('<option value="' + d + '">' +
  240. d + '</option>');
  241. });
  242. $('.column-search-select', column.footer()).on('change', function() {
  243. var val = $.fn.dataTable.util.escapeRegex($(this).val());
  244. column
  245. .search(val ? '^' + val + '$' : '', true, false)
  246. .draw();
  247. });
  248. });
  249. table.buttons().container()
  250. .appendTo($('.col-sm-6:eq(0)', table.table().container()));
  251. $(document).on('click', '.buttons-columnVisibility', function() {
  252. console.log('visibility toggled');
  253. table.columns.adjust().responsive.recalc();
  254. });
  255. return table;
  256. }
  257. function fetchData(outcome, semester, program) {
  258. //$('.list-group-item').on('click', function()
  259. // {
  260. var id = outcome.data('outcome-id');
  261. var semesters = semester.val();
  262. var programs = program.val();
  263. $.post(
  264. "{{ URL::action('TransformativeActionsController@fetchCourses') }}", {
  265. id: id,
  266. programs: programs,
  267. semesters: semesters,
  268. },
  269. function(data) {
  270. $('#transformative-display').html('');
  271. if (data.length) {
  272. var ul = $('<ul/>', {
  273. 'id': 'levelTabs',
  274. 'class': 'nav nav-tabs',
  275. 'role': 'tablist'
  276. });
  277. var divContent = $("<div/>", {
  278. 'class': 'tab-content'
  279. });
  280. if_course_exists = false;
  281. $.each(data, function(index, groupedCourse) {
  282. if (!groupedCourse.outcome_assessed) {
  283. return;
  284. }
  285. if_course_exists = true;
  286. var li = $('<li/>', {
  287. 'role': 'presentation',
  288. })
  289. var a = $('<a/>', {
  290. 'onclick': "$(this).tab('show')",
  291. "data-toggle": "tab",
  292. 'href': '#' + groupedCourse.code + '-' + groupedCourse.number,
  293. 'aria-controls': groupedCourse.code + '-' + groupedCourse.number,
  294. 'role': 'tab'
  295. }).html(groupedCourse.code + ' ' + groupedCourse.number);
  296. li.append(a);
  297. ul.append(li);
  298. divPanel = $('<div/>', {
  299. 'role': 'tabpanel',
  300. 'class': 'tab-pane',
  301. 'id': groupedCourse.code + '-' + groupedCourse.number
  302. });
  303. $table = $('<table/>', {
  304. "class": "table table-striped table-condensed datatable",
  305. //"style": "table-layout: fixed",
  306. "id": 'allTablesToExport' + index,
  307. "data-title": groupedCourse.code + '-' + groupedCourse.number
  308. });
  309. $thead = $('<thead/>').html(
  310. "<tr><th>Formative Actions</th><th>Section</th><th>Objectives and Criteria Associated </th><th>Activity</th></tr>"
  311. );
  312. $tbody = $('<tbody/>');
  313. $table.append($thead);
  314. $table.append($tbody);
  315. divPanel.append($table);
  316. $table = createDataTable($table);
  317. $.each(groupedCourse.sections, function(index2, sections) {
  318. courseHTML = sections.section;
  319. $.each(sections.activities, function(index3, activities) {
  320. TransInfo = '<p><strong>' + activities.at_text +
  321. ': </strong>' + activities.description + '</p>'
  322. //If the objective_id is inside this dictionary, then the objective is inside the html already,
  323. doesObjectiveExist = {};
  324. $.each(activities.criterion_with_objective, function(index4,
  325. criterion) {
  326. if (doesObjectiveExist[criterion
  327. .objective_id] === undefined) {
  328. doesObjectiveExist[criterion.objective_id] =
  329. "<li><p><strong>" + criterion.text +
  330. '</strong></p><ul>';
  331. }
  332. doesObjectiveExist[criterion.objective_id] +=
  333. '<li>' + criterion.name + '</li>';
  334. }
  335. )
  336. criterion_objective_html = '<ol>';
  337. $.each(doesObjectiveExist, function(index4, string) {
  338. criterion_objective_html += string + '</ul>'
  339. })
  340. criterion_objective_html += '</ol>'
  341. $table.row.add([
  342. TransInfo,
  343. courseHTML,
  344. criterion_objective_html,
  345. activities.name
  346. ])
  347. })
  348. $table.draw();
  349. });
  350. divContent.append(divPanel);
  351. })
  352. if (if_course_exists) {
  353. $('#transformative-display').append(ul);
  354. $('#transformative-display').append(divContent);
  355. $("a[role='tab']").first().tab('show');
  356. } else {
  357. $('#transformative-display').html(
  358. '<h2 style="text-align: center">There is no course in this program that assessed the outcome on the selected semester </h2><br>'
  359. )
  360. }
  361. } else {
  362. $('#transformative-display').html(
  363. '<h2 style="text-align: center">There is no course in this program that assessed on this semester </h2><br>'
  364. )
  365. $('.no-outcome').hide();
  366. }
  367. $('.no-outcome').hide();
  368. }
  369. );
  370. //})
  371. }
  372. $(document).ready(function() {
  373. // --------------------------------------------------------------------------
  374. // Page load
  375. // --------------------------------------------------------------------------
  376. // Hide accordion panel contents by default
  377. $('.panel-group .panel-body').hide();
  378. $('#outcome-display').parent().hide();
  379. // --------------------------------------------------------------------------
  380. // Functions
  381. // --------------------------------------------------------------------------
  382. // --------------------------------------------------------------------------
  383. // Events
  384. // --------------------------------------------------------------------------
  385. // When export button is clicked, export all tables as PDF
  386. // When list item is clicked, load corresponding info
  387. });
  388. </script>
  389. @stop
  390. @section('included-js')
  391. @include('global._datatables_js')
  392. @stop
  393. @section('javascript')
  394. @stop