説明なし

view-learning-outcomes-criteria.blade.php 86KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734
  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. <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">
  38. <div class="col-md-3">
  39. <input class="form-control" type="text" id="userInput" onkeyup="filterOutcomes()" placeholder="Search for Learning Outcomes..">
  40. <div class="list-group" id='list'>
  41. @foreach ($outcomes as $outcome)
  42. @foreach ($semesters as $semester)
  43. <?php Log::info($outcome->deactivation_date <= $semester->start)
  44. ; Log::info($outcome->deactivation_date);
  45. Log::info($semester->start) ?>
  46. @if(!$outcome->deleted_at && ( !$outcome->deactivation_date ||$outcome->deactivation_date >= $semester->start))
  47. <!--if(!$outcome->deleted_at && $outcome->activation_date >= $semester->start && $outcome->activation_date <= $semester->end)-->
  48. <li data-outcome-id="{{ $outcome->id }}"class="list-group-item">{{ $outcome->name }} [{{$semester->code}}]</li>
  49. @endif
  50. @endforeach
  51. @endforeach
  52. </div>
  53. </div>
  54. <div class="col-md-9">
  55. <div id="outcome-display" class="panel panel-default">
  56. <div class="panel-heading">
  57. <h4 class=" panel-title" style="cursor:auto!important;">
  58. </h4>
  59. </div>
  60. <div class="panel-body">
  61. <p class="outcome-definition "></p>
  62. <label for="">View Criterions with </label>
  63. <select class="view-scales input-sm" name=""></select>
  64. <label for="">Scales</label>
  65. {{-- <button type="button" name="button">Export All</button> --}}
  66. {{-- <div class=""> --}}
  67. <div class="dropdown show">
  68. <button class="btn btn-default buttons-collection" href="#" role="button" id="dropdownMenuLink" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  69. <span>Export All
  70. <span class="caret"></span>
  71. </span>
  72. </button>
  73. <div class="dropdown-menu" role="menu" aria-labelledby="dropdownMenuLink">
  74. {{-- <a class="export-all print-all" <a href="#" disabled>Print</a></a><br> --}}
  75. <a class="export-all excel-all" <a href="#">Excel</a></a><br>
  76. <a class="export-all pdf-all" <a href="#">PDF</a></a>
  77. </div>
  78. </div>
  79. <div class="table-responsive table-responsive-0">
  80. {{-- tables are appended here --}}
  81. {{-- <table id="example" class="table table-striped table-condensed" width="100%"></table> --}}
  82. </div>
  83. </div>
  84. </div>
  85. </div>
  86. <div class="col-md-9">
  87. <div class="no-outcome alert alert-info">
  88. <p>Select a Learning Outcome to view its information</p>
  89. </div>
  90. </div>
  91. </div>
  92. <div id="StatusModal" class="modal fade" tabindex="-1" data-criterion-id="0">
  93. <div class="modal-dialog">
  94. <div class="modal-content">
  95. <div class="modal-header">
  96. <h5 class="modal-title">Status</h5>
  97. <button type="button" class="close" data-dismiss="modal">&times;</button>
  98. </div>
  99. <div class="modal-body" id = "modalBody">
  100. <p></p>
  101. </div>
  102. <div class="modal-footer">
  103. <button type="button" class="btn btn-secondary" data-dismiss="modal" onclick="$('#temp_id').attr('id', '');">Cancel</button>
  104. <button type="button" class="btn btn-primary" onclick = 'statusChange()'>Yes</button>
  105. </div>
  106. </div>
  107. </div>
  108. </div>
  109. <script>
  110. function statusClick(link){
  111. var criterion_id = $(link).data('criterion-id');
  112. var text = $(link).text();
  113. if(text == "Active"){
  114. $('#modalBody').html('<p>Would you like to deactivate this criterion?</p>');
  115. }
  116. else $('#modalBody').html('<p>Would you like to activate this criterion?</p>');
  117. $(link).attr('id', 'temp_id');
  118. $('#StatusModal').data('criterion-id', criterion_id);
  119. $('#StatusModal').modal('show');
  120. }
  121. function statusChange(){
  122. criterion_id = $('#StatusModal').data('criterion-id');
  123. $.post(
  124. "{{ URL::action('CriteriaController@changeStatus') }}",
  125. { criterion_id: criterion_id,
  126. },
  127. function(changed)
  128. {
  129. $('#StatusModal').modal('hide');
  130. if(changed == "deleted")
  131. $('#temp_id').text('Deactivated');
  132. else
  133. $('#temp_id').text('Active');
  134. $('#temp_id').attr('id', '');
  135. });
  136. }
  137. $(document).ready(function()
  138. {
  139. // --------------------------------------------------------------------------
  140. // Page load
  141. // --------------------------------------------------------------------------
  142. // Hide accordion panel contents by default
  143. $('.panel-group .panel-body').hide();
  144. $('#outcome-display').parent().hide();
  145. // --------------------------------------------------------------------------
  146. // Functions
  147. // --------------------------------------------------------------------------
  148. // --------------------------------------------------------------------------
  149. // Events
  150. // --------------------------------------------------------------------------
  151. $('.view-scales').on('click', function()
  152. {
  153. var number_of_scales = this.value;
  154. $('.table-responsive').hide();
  155. $('.table-responsive-0').show();
  156. $('.table-'+number_of_scales).show();
  157. })
  158. // When export button is clicked, export all tables as PDF
  159. $(document).on('click', '.export-all', function() {
  160. var export_type = $(this).attr('class');
  161. console.log('export_type');
  162. console.log(export_type);
  163. var r = confirm("Are you sure you want to download all programs info as separate PDFs? \n It may take a moment to process.");
  164. if (r == true) {
  165. //var 'tables' is defined in master.blade.php
  166. console.log("export all");
  167. $('table').each(function( t ) {
  168. var table = $(this).DataTable();
  169. if(export_type =="export-all print-all"){
  170. $('.table-responsive').show();
  171. table.buttons('0-0').trigger();
  172. }
  173. else if (export_type =="export-all excel-all"){
  174. $('.table-responsive').show();
  175. table.buttons('0-1').trigger();
  176. }
  177. else if (export_type =="export-all pdf-all"){
  178. $('.table-responsive').show();
  179. table.buttons('0-2').trigger();
  180. }
  181. });
  182. var current = $('select').val();
  183. $('.table-responsive').hide();
  184. $('.table-responsive-0').show();
  185. $('.table-'+current).show();
  186. }
  187. });
  188. // When list item is clicked, load corresponding info
  189. $('.list-group-item').on('click', function()
  190. {
  191. var id = $(this).data('outcome-id');
  192. var tables = [];
  193. $.post(
  194. "{{ URL::action('OutcomesController@fetchOutcome') }}",
  195. { id: id,
  196. },
  197. function(data)
  198. {
  199. var outcome = data.outcome;
  200. var outcome_id = outcome.id;
  201. var name = outcome.name;
  202. var definition = outcome.definition;
  203. var criteria = outcome.criteria;
  204. $('#outcome-display').parent().show();
  205. $('.no-outcome').parent().hide();
  206. //Display title and definition
  207. $('#outcome-display .panel-title').html(name);
  208. $('#outcome-display .outcome-definition').html(definition);
  209. //Empty table
  210. $('.table-responsive-0').empty();
  211. // Add new criteria
  212. if(criteria.length>0){
  213. // populate the selector for viewing different levels
  214. var selector = $('.view-scales');
  215. selector.empty();
  216. $.each(criteria, function(index, criterion_info){
  217. var criterions_levels = criterion_info.amount_of_levels;
  218. var new_option = $('<option />');
  219. new_option.attr('value',criterions_levels).html(criterions_levels);
  220. new_option.appendTo(selector);
  221. });
  222. //escibir los valores del outcome seleccionado
  223. $.each(criteria, function(index, criterion_info){
  224. var dataset = Array();
  225. var criterions = criterion_info[0];
  226. var criterions_levels = criterion_info.amount_of_levels;
  227. $.each(criterions, function(index, criterion){
  228. //
  229. var row = Array();
  230. var criterion_name = criterion.name;
  231. var criterion_scales = criterion.scales;
  232. var criterion_programs = criterion.programs;
  233. var program_html = '';
  234. row.push(criterion_name);
  235. $.each(criterion_scales, function(index, scale){
  236. //
  237. // var title = scale.title;
  238. var description = scale.description;
  239. //var cell_text = description;
  240. row.push(description);
  241. });
  242. $.each(criterion_programs, function(index, program){
  243. program_html += (index+1) +'. '+program+'<br>\n';
  244. });
  245. row.push(program_html);
  246. if(!criterion.deleted_at) row.push('<a onclick = "statusClick(this)" data-criterion-id="'+criterion.id+'" href="#" class = "status">Active</a>');
  247. else row.push('<a href="#" onclick = "statusClick(this)" data-criterion-id="'+criterion.id+'" class = "status">Deactivated</a>');
  248. if(criterion_scales.length < criterions_levels){
  249. var i = criterion_scales.length;
  250. while (i < criterions_levels){
  251. //
  252. var description = ' ';
  253. row.push(description);
  254. i++;
  255. }
  256. }
  257. dataset.push(row);
  258. });
  259. var columns_titles = Array();
  260. columns_titles.push({title: "Criterion"})
  261. var i = 0;
  262. while(i < criterions_levels){
  263. columns_titles.push({title: "Level "+(i+1)})
  264. i++;
  265. }
  266. columns_titles.push({title: "Program"});
  267. columns_titles.push({title: "Status"});
  268. var table_id = 'table-'+criterions_levels;
  269. var new_table_div = $('<div />').attr('class','table-responsive table-div '+table_id);
  270. new_table_div.append('<hr>');
  271. new_table_div.append('<hr>');
  272. new_table_div.append('<p><b class="h3">Criterions with '+criterions_levels+' levels</b></p>');
  273. new_table_div.append('<table id="'+table_id+'" class="table table-striped table-condensed" width="100%"></table>');
  274. new_table_div.appendTo('.table-responsive-0');
  275. var table2 = $('#'+table_id).DataTable( {
  276. order : [[criterions_levels+2, "asc"]],
  277. buttons: [
  278. {
  279. lengthMenu: [5, 10, 25, 50],
  280. autoWidth: false,
  281. retrieve: true,
  282. pageLength: 10,
  283. extend: 'collection',
  284. text: 'Export <span class="caret"></span>',
  285. buttons: [
  286. {
  287. extend: 'print',
  288. exportOptions: {
  289. columns: ':visible'
  290. },
  291. text: 'Print',
  292. },
  293. {
  294. extend: 'excelHtml5',
  295. exportOptions: {
  296. columns: ':visible'
  297. }
  298. },
  299. {
  300. extend: 'pdfHtml5',
  301. exportOptions: {
  302. columns: ':visible',
  303. stripNewlines: false,
  304. },
  305. customize: function(doc){
  306. //$('#loadingModal').modal('show');
  307. doc.pageSize = 'LEGAL';
  308. doc.pageOrientation ='landscape';
  309. doc.defaultStyle.fontSize = 10;
  310. doc.styles.tableHeader.fillColor = '#E70033';
  311. // doc.content[1].layout= 'lightHorizontalLines';
  312. doc.content[1].layout = {
  313. hLineWidth: function (i, node) {
  314. if(i === 1){
  315. return 2;
  316. }
  317. else if(i > 1){
  318. return 1;
  319. }
  320. else {
  321. return 0;
  322. }
  323. },
  324. vLineWidth: function (i, node) {
  325. return 0;
  326. },
  327. hLineColor: function (i, node) {
  328. if(i === 1){
  329. return '#000';
  330. }
  331. else if(i > 1){
  332. return '#ccc';
  333. }
  334. else {
  335. return 'transparent';
  336. }
  337. },
  338. // vLineColor: function (i, node) {
  339. // return (i === 0 || i === node.table.widths.length) ? 'black' : 'gray';
  340. // },
  341. paddingLeft: function(i, node) { return 5; },
  342. paddingRight: function(i, node) { return 5; },
  343. paddingTop: function(i, node) { return 5; },
  344. paddingBottom: function(i, node) { return 5; }
  345. };
  346. doc.content.splice( 0, 0, {
  347. margin: [ 0, 0, 0, 12 ],
  348. alignment: 'center',
  349. width: 150,
  350. image: ''
  351. } );
  352. }
  353. },
  354. ]
  355. },
  356. {
  357. extend: 'colvis',
  358. columns: ':gt(0)',
  359. text: 'Column visibility <span class="caret"></span>',
  360. }
  361. ],
  362. data: dataset,
  363. columns: columns_titles,
  364. } );
  365. $('.col-sm-6:eq(0)', table2.table().container()).before(table2.buttons().container());
  366. $(document).on('click', '.buttons-columnVisibility', function(){
  367. console.log('visibility toggled');
  368. table2.columns.adjust().responsive.recalc();
  369. });
  370. tables.push(table2);
  371. });
  372. var first_table = '.table-'+criteria[0].amount_of_levels;
  373. $('.table-responsive').hide();
  374. $('.table-responsive-0').show();
  375. $(first_table).show();
  376. } // if
  377. //else
  378. //$('table').hide();
  379. // Update display
  380. {{-- table.draw(); --}}
  381. }
  382. );
  383. })
  384. });
  385. </script>
  386. @stop
  387. @section('included-js')
  388. @include('global._datatables_js')
  389. @stop
  390. @section('javascript')
  391. /*
  392. $(document).ready(function()
  393. {
  394. // --------------------------------------------------------------------------
  395. // Page load
  396. // --------------------------------------------------------------------------
  397. // Hide accordion panel contents by default
  398. $('.panel-group .panel-body').hide();
  399. $('#outcome-display').parent().hide();
  400. // --------------------------------------------------------------------------
  401. // Functions
  402. // --------------------------------------------------------------------------
  403. // --------------------------------------------------------------------------
  404. // Events
  405. // --------------------------------------------------------------------------
  406. $('.view-scales').on('click', function()
  407. {
  408. var number_of_scales = this.value;
  409. $('.table-responsive').hide();
  410. $('.table-responsive-0').show();
  411. $('.table-'+number_of_scales).show();
  412. })
  413. // When export button is clicked, export all tables as PDF
  414. $(document).on('click', '.export-all', function() {
  415. var export_type = $(this).attr('class');
  416. console.log('export_type');
  417. console.log(export_type);
  418. var r = confirm("Are you sure you want to download all programs info as separate PDFs? \n It may take a moment to process.");
  419. if (r == true) {
  420. //var 'tables' is defined in master.blade.php
  421. console.log("export all");
  422. $('table').each(function( t ) {
  423. var table = $(this).DataTable();
  424. if(export_type =="export-all print-all"){
  425. $('.table-responsive').show();
  426. table.buttons('0-0').trigger();
  427. }
  428. else if (export_type =="export-all excel-all"){
  429. $('.table-responsive').show();
  430. table.buttons('0-1').trigger();
  431. }
  432. else if (export_type =="export-all pdf-all"){
  433. $('.table-responsive').show();
  434. table.buttons('0-2').trigger();
  435. }
  436. });
  437. var current = $('select').val();
  438. $('.table-responsive').hide();
  439. $('.table-responsive-0').show();
  440. $('.table-'+current).show();
  441. }
  442. });
  443. // When list item is clicked, load corresponding info
  444. $('.list-group-item').on('click', function()
  445. {
  446. var id = $(this).data('outcome-id');
  447. var tables = [];
  448. $.post(
  449. "{{ URL::action('OutcomesController@fetchOutcome') }}",
  450. { id: id },
  451. function(data)
  452. {
  453. var outcome = data.outcome;
  454. var outcome_id = outcome.id;
  455. var name = outcome.name;
  456. var definition = outcome.definition;
  457. var criteria = outcome.criteria;
  458. $('#outcome-display').parent().show();
  459. $('.no-outcome').parent().hide();
  460. //Display title and definition
  461. $('#outcome-display .panel-title').html(name);
  462. $('#outcome-display .outcome-definition').html(definition);
  463. //Empty table
  464. $('.table-responsive-0').empty();
  465. // Add new criteria
  466. if(criteria.length>0){
  467. // populate the selector for viewing different levels
  468. var selector = $('.view-scales');
  469. selector.empty();
  470. $.each(criteria, function(index, criterion_info){
  471. var criterions_levels = criterion_info.amount_of_levels;
  472. var new_option = $('<option />');
  473. new_option.attr('value',criterions_levels).html(criterions_levels);
  474. new_option.appendTo(selector);
  475. });
  476. //escibir los valores del outcome seleccionado
  477. $.each(criteria, function(index, criterion_info){
  478. var dataset = Array();
  479. var criterions = criterion_info[0];
  480. var criterions_levels = criterion_info.amount_of_levels;
  481. $.each(criterions, function(index, criterion){
  482. //
  483. var row = Array();
  484. var criterion_name = criterion.name;
  485. var criterion_scales = criterion.scales;
  486. row.push(criterion_name);
  487. $.each(criterion_scales, function(index, scale){
  488. //
  489. var title = scale.title;
  490. var description = scale.description;
  491. var cell_text = '<b>'+title+'</b><br>\n'+description;
  492. row.push(cell_text);
  493. });
  494. if(criterion_scales.length < criterions_levels){
  495. var i = criterion_scales.length;
  496. while (i < criterions_levels){
  497. //
  498. var description = ' ';
  499. row.push(description);
  500. i++;
  501. }
  502. }
  503. dataset.push(row);
  504. });
  505. var columns_titles = Array();
  506. columns_titles.push({title: "Criterion"})
  507. var i = 0;
  508. while(i < criterions_levels){
  509. columns_titles.push({title: "Level "+(i+1)})
  510. i++;
  511. }
  512. var table_id = 'table-'+criterions_levels;
  513. var new_table_div = $('<div />').attr('class','table-responsive table-div '+table_id);
  514. new_table_div.append('<hr>');
  515. new_table_div.append('<hr>');
  516. new_table_div.append('<p><b class="h3">Criterions with '+criterions_levels+' levels</b></p>');
  517. new_table_div.append('<table id="'+table_id+'" class="table table-striped table-condensed" width="100%"></table>');
  518. new_table_div.appendTo('.table-responsive-0');
  519. var table2 = $('#'+table_id).DataTable( {
  520. buttons: [
  521. {
  522. lengthMenu: [5, 10, 25, 50],
  523. autoWidth: false,
  524. retrieve: true,
  525. pageLength: 10,
  526. extend: 'collection',
  527. text: 'Export <span class="caret"></span>',
  528. buttons: [
  529. {
  530. extend: 'print',
  531. exportOptions: {
  532. columns: ':visible'
  533. },
  534. text: 'Print',
  535. },
  536. {
  537. extend: 'excelHtml5',
  538. exportOptions: {
  539. columns: ':visible'
  540. }
  541. },
  542. {
  543. extend: 'pdfHtml5',
  544. exportOptions: {
  545. columns: ':visible',
  546. stripNewlines: false,
  547. },
  548. customize: function(doc){
  549. //$('#loadingModal').modal('show');
  550. doc.pageSize = 'LEGAL';
  551. doc.pageOrientation ='landscape';
  552. doc.defaultStyle.fontSize = 10;
  553. doc.styles.tableHeader.fillColor = '#E70033';
  554. // doc.content[1].layout= 'lightHorizontalLines';
  555. doc.content[1].layout = {
  556. hLineWidth: function (i, node) {
  557. if(i === 1){
  558. return 2;
  559. }
  560. else if(i > 1){
  561. return 1;
  562. }
  563. else {
  564. return 0;
  565. }
  566. },
  567. vLineWidth: function (i, node) {
  568. return 0;
  569. },
  570. hLineColor: function (i, node) {
  571. if(i === 1){
  572. return '#000';
  573. }
  574. else if(i > 1){
  575. return '#ccc';
  576. }
  577. else {
  578. return 'transparent';
  579. }
  580. },
  581. // vLineColor: function (i, node) {
  582. // return (i === 0 || i === node.table.widths.length) ? 'black' : 'gray';
  583. // },
  584. paddingLeft: function(i, node) { return 5; },
  585. paddingRight: function(i, node) { return 5; },
  586. paddingTop: function(i, node) { return 5; },
  587. paddingBottom: function(i, node) { return 5; }
  588. };
  589. doc.content.splice( 0, 0, {
  590. margin: [ 0, 0, 0, 12 ],
  591. alignment: 'center',
  592. width: 150,
  593. image: ''
  594. } );
  595. }
  596. },
  597. ]
  598. },
  599. {
  600. extend: 'colvis',
  601. columns: ':gt(0)',
  602. text: 'Column visibility <span class="caret"></span>',
  603. }
  604. ],
  605. data: dataset,
  606. columns: columns_titles,
  607. } );
  608. $('.col-sm-6:eq(0)', table2.table().container()).before(table2.buttons().container());
  609. $(document).on('click', '.buttons-columnVisibility', function(){
  610. console.log('visibility toggled');
  611. table.columns.adjust().responsive.recalc();
  612. });
  613. tables.push(table);
  614. });
  615. var first_table = '.table-'+criteria[0].amount_of_levels;
  616. $('.table-responsive').hide();
  617. $('.table-responsive-0').show();
  618. $(first_table).show();
  619. } // if
  620. //else
  621. //$('table').hide();
  622. // Update display
  623. {{-- table.draw(); --}}
  624. }
  625. );
  626. })
  627. });
  628. */
  629. @stop