Без опису

objectives.blade.php 31KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803
  1. @extends('layouts.master')
  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. @endif
  10. @stop
  11. @section('main')
  12. <div class="row">
  13. <div class="col-md-12" id='message'>
  14. </div>
  15. </div>
  16. <div class="row">
  17. <div class="col-md-6">
  18. <!-- Form to add a new objective -->
  19. <div class="panel panel-default panel-button">
  20. <div class="panel-heading">
  21. Create
  22. </div>
  23. <div class="panel-body">
  24. {{ Form::open(['action' => 'Objective2Controller@create']) }}
  25. <div id='outcomeGroup'>
  26. <label> Associated Learning Outcome</label>
  27. <div class="form-group col-md-11" id='outcomeForm'>
  28. <select id="outcome[0]" name="outcome[0]" class="form-control selectpicker createOutcome">
  29. @foreach ($outcomes as $outcome)
  30. <option value="{{ $outcome->id }}">
  31. {{ $outcome->name }}
  32. </option>
  33. @endforeach
  34. </select>
  35. </div>
  36. </div>
  37. <input type='hidden' name='counter' id='counter' value=1>
  38. <button id='button-add-outcome' class='btn btn-md btn-secondary' onclick='addOutcomeTest()'>
  39. <span class='glyphicon glyphicon-plus'>
  40. </span>
  41. Add another Learning Outcome
  42. </button>
  43. <!-- Associated Program -->
  44. <div class="form-group">
  45. {{ Form::label('program_id', 'Associated Program') }}<br>
  46. <br>
  47. @foreach ($programs as $program)
  48. <input type="checkbox" id="{{ $program->name }}" name="program_id[]"
  49. value="{{ $program->id }}">
  50. <label for="{{ $program->name }}"> {{ $program->name }}
  51. [{{ $program->school->name }}]</label><br>
  52. @endforeach
  53. </div>
  54. <div class="form-group">
  55. {{ Form::label('text', 'Text') }}
  56. {{ Form::text('text', '', ['class' => 'form-control']) }}
  57. </div>
  58. {{ Form::submit('Create', ['class' => 'btn btn-primary btn-block', 'id' => 'createObjectiveButton']) }}
  59. {{ Form::close() }}
  60. </div>
  61. </div>
  62. </div>
  63. <div class="col-md-6">
  64. <div class="panel panel-default panel-button">
  65. <div class="panel-heading">
  66. Edit
  67. </div>
  68. <div class="panel-body">
  69. <button class="btn btn-md btn-secondary filterButton">
  70. <span class="glyphicon glyphicon-minus">
  71. </span>
  72. Filters
  73. </button>
  74. <div class='filterSection'>
  75. {{ Form::open(['action' => 'Objective2Controller@update']) }}
  76. <div class="form-group">
  77. {{ Form::label('program_id2', 'Associated Program') }}
  78. <select id='select-program' class="form-control selectpicker"
  79. onchange='fetchAllObjectives("select-program", "assoc_outcomes_fetch")'>
  80. @foreach ($programs as $program)
  81. <option value='{{ $program->id }}' data-subtext="{{ $program->code }}">
  82. {{ $program->name }}</option>
  83. @endforeach
  84. </select>
  85. </div>
  86. <div class="form-group">
  87. <label>Associated Learning Outcome</label>
  88. {{-- Form::select('assoc_outcome_fetch', $outcomes, null, ['class'=>'form-control selectpicker', 'id'=>'assoc_outcomes_fetch', 'onchange'=>'fetchAllObjectives("select-program", "assoc_outcomes_fetch")']) --}}
  89. <select id="assoc_outcomes_fetch" name="assoc_outcome_fetch" class="form-control selectpicker"
  90. onchange="fetchAllObjectives('select-program', 'assoc_outcomes_fetch')">
  91. @foreach ($outcomes as $outcome)
  92. <option value="{{ $outcome->id }}">
  93. {{ $outcome->name }}
  94. </option>
  95. @endforeach
  96. </select>
  97. </div>
  98. </div>
  99. <hr>
  100. <div class="form-group">
  101. {{ Form::label('objective_id', 'Objectives') }}
  102. <select id="select-objective" name='id' class="form-control selectpicker">
  103. @foreach ($objectives as $objective)
  104. <option value="{{ $objective->id }}"
  105. data-subtext="
  106. @if ($objective->program) &nbsp;&nbsp;&nbsp;[{{ $objective->program->name }}] @endif
  107. ">
  108. {{ $objective->text }}
  109. </option>
  110. @endforeach
  111. </select>
  112. </div>
  113. <!-- Associated Outcome -->
  114. <div class="form-group">
  115. <div id='assocOutcomeGroup'>
  116. <label>Associated Learning Outcome</label>
  117. <div id="message_to_disconnect"></div>
  118. <select id="assoc_outcome0" name="assoc_outcome[]" class="form-control selectpicker">
  119. @foreach ($outcomes as $outcome)
  120. <option value="{{ $outcome->id }}">
  121. {{ $outcome->name }}
  122. </option>
  123. @endforeach
  124. </select>
  125. <br><br>
  126. </div>
  127. </div>
  128. <button id='button-add-assoc-outcome' class='btn btn-md btn-secondary' onclick='addAssoc()'>
  129. <span class='glyphicon glyphicon-plus'>
  130. </span>
  131. Add another Learning Outcome
  132. </button>
  133. <!-- Associated Program -->
  134. <div class="form-group">
  135. {{ Form::label('program_id', 'Associated Program') }}<br>
  136. <br>
  137. @foreach ($programs as $program)
  138. <input type="checkbox" id="assoc_program_id_{{ $program->id }}" name="assoc_program_id[]"
  139. value="{{ $program->id }}">
  140. <label for="assoc_program_id_{{ $program->id }}"> {{ $program->name }}
  141. <sub>[{{ $program->school->name }}]</sub></label><br>
  142. @endforeach
  143. </div>
  144. <!-- Status -->
  145. <div class="form-group">
  146. {{ Form::label('status', 'Status') }}
  147. <span data-toggle="tooltip" data-placement="top"
  148. title="Use this option to deactivate or reactivate objectives. Inactive objective will stay in the system, but will not be available to use in new rubrics."
  149. class="glyphicon glyphicon-question-sign"></span>
  150. <select id="status" name="status" class="form-control">
  151. <option value="1">Active</option>
  152. <option value="0">Inactive</option>
  153. </select>
  154. </div>
  155. <div class="form-group">
  156. {{ Form::label('text', 'Text') }}
  157. {{ Form::text('text', Input::old('text'), ['class' => 'form-control', 'id' => 'objective-text']) }}
  158. </div>
  159. <div id="text">
  160. </div>
  161. {{ Form::submit('Update', ['class' => 'btn btn-primary btn-block', 'id' => 'update_button_to_modal']) }}
  162. {{ Form::close() }}
  163. <form action="/deleteObjective" method="POST" id='deleteObj'>
  164. </form>
  165. </div>
  166. </div>
  167. </div>
  168. </div>
  169. <div id="ObjectiveAssocModal" class="modal fade" tabindex="-1" data-criterion-id="0">
  170. <div class="modal-dialog">
  171. <div class="modal-content">
  172. <div class="modal-header">
  173. <button type="button" class="close" data-dismiss="modal">&times;</button>
  174. <h5 class="modal-title">Would you like to pair these new Learning Outcomes to all the Criteria
  175. associated to
  176. this Objective?</h5>
  177. </div>
  178. <div class="modal-body" id="ObjectiveModalBody">
  179. </div>
  180. <div class="modal-footer">
  181. <button type="button" class="btn btn-secondary"
  182. onclick="pair_every_criteria_with_objective =0; $('#update_button').click()"
  183. data-dismiss="modal">No</button>
  184. <button type="button" onclick="pair_every_criteria_with_objective =1; $('#update_button').click()"
  185. class="btn btn-primary" data-dismiss="modal">Yes</button>
  186. <button type="hidden" style="display:none" id="update_button" class="btn btn-primary"></button>
  187. </div>
  188. </div>
  189. </div>
  190. </div>
  191. <script>
  192. $('.filterSection').show();
  193. $('.filterButton').on('click', function() {
  194. var span = $(this).find('span');
  195. if (span.attr('class') == 'glyphicon glyphicon-plus') {
  196. span.attr('class', 'glyphicon glyphicon-minus');
  197. } else {
  198. span.attr('class', 'glyphicon glyphicon-plus');
  199. }
  200. $('.filterSection').toggle(533);
  201. });
  202. var outcomeHTML = document.getElementById('outcomeGroup').innerHTML;
  203. var selectOptions = document.getElementById('outcome[0]').innerHTML;
  204. var ran = false;
  205. function fetchAllObjectives(program, outcome) {
  206. var program_id_fetch = $('#' + program).find(':selected').val();
  207. var outcome_fetch = $('#' + outcome).find(':selected').val();
  208. $.post(
  209. "{{ URL::action('Objective2Controller@fetchAllObjectives') }}", {
  210. program_fetch: program_id_fetch,
  211. outcome_fetch: outcome_fetch
  212. },
  213. function(json) {
  214. json_length = (json.objective.length);
  215. fullHTML = '';
  216. for (var i = 0; i < json_length; i++) {
  217. fullHTML += '<option value="' + json.objective[i].id + '">' + json.objective[i].text +
  218. '</option>';
  219. }
  220. $('#select-objective').html(fullHTML);
  221. $('#select-objective').selectpicker('refresh');
  222. fetchObjectiveForEditing();
  223. },
  224. 'json'
  225. );
  226. }
  227. var counter = 1;
  228. var counterAssoc = 0;
  229. //Add Another Outcome
  230. function changeOutcomeHtml() {
  231. var outcomeHTML = document.getElementById('outcomeGroup').innerHTML;
  232. outcomeHTML = outcomeHTML.replace('outcome[' + counter.toString() + ']', 'outcome[' + (counter + 1).toString() +
  233. ']');
  234. counter += 1;
  235. document.getElementById("outcomeGroup").innerHTML += outcomeHTML;
  236. document.getElementById('button-add-outcome').onclick = addOutcome;
  237. }
  238. function addOutcome() {
  239. outcomeHTML = outcomeHTML.replace('outcome[' + counter.toString() + ']', 'outcome[' + (counter + 1).toString() +
  240. ']');
  241. counter += 1;
  242. document.getElementById("outcomeGroup").innerHTML += outcomeHTML;
  243. }
  244. function addOutcomeTest() {
  245. var $select = $('<select/>', {
  246. 'class': "selectpicker form-control createOutcome",
  247. 'name': "outcome[" + counter.toString() + "]",
  248. 'data-live-search': 'true'
  249. });
  250. //holds both the select div and the button div
  251. var $containerdiv = $('<div/>', {
  252. 'id': 'outcomeContainer' + counter.toString(),
  253. });
  254. var $div = $('<div/>', {
  255. 'id': 'outcomeForm' + counter.toString(),
  256. 'class': 'form-group col-md-11'
  257. });
  258. var $divForButton = $('<div/>', {
  259. 'class': 'col-md-1',
  260. 'id': 'close' + counter.toString()
  261. });
  262. var $button = $('<button/>', {
  263. 'type': 'button',
  264. 'class': 'btn btn-primary',
  265. //send the counter to the function so it can tell which container to remove
  266. 'onclick': 'deleteLast(' + counter + ')',
  267. });
  268. $button.append('X');
  269. $divForButton.append($button);
  270. $containerdiv.appendTo('#outcomeGroup')
  271. $div.appendTo('#outcomeContainer' + counter.toString())
  272. $select.append(selectOptions);
  273. $select.appendTo('#outcomeForm' + counter.toString()).selectpicker('refresh');
  274. $divForButton.appendTo('#outcomeContainer' + counter.toString());
  275. counter += 1;
  276. $('#counter').val(counter);
  277. }
  278. //Recieves the counter variable so it can find the specific div and delete it
  279. function deleteLast(counter) {
  280. div = document.getElementById('outcomeContainer' + (counter).toString());
  281. div.remove();
  282. }
  283. function fetchObjectiveForEditing() {
  284. var id = $('#select-objective').find(':selected').val();
  285. $.post(
  286. "{{ URL::action('Objective2Controller@fetchObjectiveWithTrashed') }}", {
  287. id: id
  288. },
  289. function(json) {
  290. var text = json.objective[0].text;
  291. // Display info
  292. $('#objective-text').val(text);
  293. // Select associated outcome
  294. $(".removable-outcome").remove();
  295. $('.warning-objective').remove();
  296. $('#assoc_outcome0').val(json.outcome[0].outcome_id);
  297. disabled = 0;
  298. if (json.outcome[0].typ_semester_outcome_id != null || json.outcome[0].count_criterion_id != 0) {
  299. $('#assoc_outcome0').attr('disabled', true);
  300. disabled = 1;
  301. } else $('#assoc_outcome0').attr('disabled', false);
  302. counterAssoc = 0;
  303. $('#assoc_outcome0').selectpicker('refresh');
  304. for (var i = 1; i < json.outcome.length; i++) {
  305. counterAssoc = i;
  306. var $select = $('<select />', {
  307. 'class': "selectpicker form-control ",
  308. 'name': "assoc_outcome[]",
  309. 'data-live-search': 'true',
  310. 'id': 'assoc_outcome' + i.toString(),
  311. });
  312. var $div = $('<div />', {
  313. 'id': 'assocOutcomeForm' + i.toString(),
  314. 'class': 'form-group col-md-11 removable-outcome'
  315. });
  316. var $divForButton = $('<div />', {
  317. 'class': 'col-md-1 removable-outcome',
  318. 'id': 'closeAssoc' + i.toString()
  319. });
  320. var $button = $('<button />', {
  321. 'type': 'button',
  322. 'class': 'btn btn-primary removable-outcome',
  323. 'onclick': 'deleteLastAssoc(' + i + ')'
  324. });
  325. $button.append('X');
  326. $divForButton.append($button);
  327. $div.appendTo('#assocOutcomeGroup')
  328. $select.append(selectOptions);
  329. if (json.outcome[i].typ_semester_outcome_id != null || json.outcome[i].count_criterion_id !=
  330. 0) {
  331. $select.attr('disabled', true);
  332. $button.attr('disabled', true);
  333. disabled = 1;
  334. }
  335. $select.appendTo('#assocOutcomeForm' + i.toString()).selectpicker('refresh');
  336. $divForButton.appendTo('#assocOutcomeGroup');
  337. $('#assoc_outcome' + i.toString()).val(json.outcome[i].outcome_id);
  338. $('#assoc_outcome' + i.toString()).selectpicker('refresh');
  339. }
  340. if (disabled == 1) {
  341. alert = $('<div/>', {
  342. 'class': 'alert alert-danger alert-dismissible warning-objective',
  343. 'role': 'alert'
  344. })
  345. button = $('<button/>', {
  346. 'type': 'button',
  347. 'class': 'close',
  348. 'data-dismiss': 'alert',
  349. 'alert-label': 'close'
  350. }).html('<span aria-hidden="true">×</span>');
  351. alert.append(button);
  352. alert.append(
  353. '<strong>If you wish to edit the disabled Learning Outcomes you need to detach the Objective from every Criteria paired to it and this Objectvie cannot be in any annual plan with that Learning Outcome</strong>'
  354. )
  355. alert.appendTo($('#message_to_disconnect'))
  356. }
  357. var program_length = json.program.length;
  358. $('input[type=checkbox]').prop('checked', false);
  359. for (var i = 0; i < program_length; i++) {
  360. prog = json.program[i].program_id.toString();
  361. $('#assoc_program_id_' + prog).prop("checked", true);
  362. }
  363. // Select status
  364. if (json.objective[0].deleted_at)
  365. $('#status').val(0);
  366. else
  367. $('#status').val(1);
  368. typ_status = "";
  369. warning = "";
  370. if (json.typ_semester_objectives.length > 0 && json.assessment.length > 0) {
  371. warning =
  372. "<p>This objective is currently participating in an Assessment and it is paired to a Three Year Plan, therefore it cannot be deleted </p>";
  373. $("#deleteObj").html(warning);
  374. } else if (json.assessment.length > 0) {
  375. $('#deleteObj').html(
  376. "<p>This objective is currently participating in an Assessment, therefore it cannot be deleted</p>"
  377. );
  378. } else if (json.typ_semester_objectives.length > 0) {
  379. warning =
  380. "<p>This objective is currently paired to a Three Year Plan, therefore it cannot be deleted </p>";
  381. $("#deleteObj").html(
  382. warning
  383. );
  384. } else if (json.assoc_criteria.length > 0) {
  385. modal =
  386. '<button type="button" class="btn btn-primary btn-block" data-toggle="modal" data-target="#delete">' +
  387. 'Delete' +
  388. '</button>' +
  389. '<input type="hidden" value =' + json.objective[0].id + ' name="deleteObj">' +
  390. '<div class="modal fade" id="delete" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">' +
  391. '<div class="modal-dialog" role="document">' +
  392. '<div class="modal-content">' +
  393. ' <div class="modal-header">' +
  394. '<h5 class="modal-title" id="exampleModalLabel">Are you sure?</h5>' +
  395. '<button type="button" class="close" data-dismiss="modal" aria-label="Close">' +
  396. '<span aria-hidden="true">&times;</span>' +
  397. '</button>' +
  398. ' </div>' +
  399. '<div class="modal-body">' +
  400. "<p>This objective is associated to: <p>" +
  401. '<ul>';
  402. for (var i = 0; i < json.assoc_criteria.length; i++) {
  403. modal += "<li>" + json.assoc_criteria[i].name + '</li>';
  404. }
  405. modal += ' </ul>' +
  406. '<p>Do you still want to delete it?</p>' +
  407. '</div>' +
  408. '<div class="modal-footer">' +
  409. '<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>' +
  410. '<button type="submit" class="btn btn-primary">Delete</button>' +
  411. '</div>' +
  412. '</div>' +
  413. '</div>' +
  414. '</div>';
  415. $('#deleteObj').html(modal);
  416. } else {
  417. modal =
  418. '<button type="button" class="btn btn-primary btn-block" data-toggle="modal" data-target="#delete">' +
  419. 'Delete' +
  420. '</button>' +
  421. '<input type="hidden" value =' + json.objective[0].id + ' name="deleteObj">' +
  422. '<div class="modal fade" id="delete" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">' +
  423. '<div class="modal-dialog" role="document">' +
  424. '<div class="modal-content">' +
  425. ' <div class="modal-header">' +
  426. '<h5 class="modal-title" id="exampleModalLabel">Are you sure?</h5>' +
  427. '<button type="button" class="close" data-dismiss="modal" aria-label="Close">' +
  428. '<span aria-hidden="true">&times;</span>' +
  429. '</button>' +
  430. ' </div>' +
  431. '<div class="modal-body">' +
  432. "<p> Once deleted, there is no chance of getting it back.</p>";
  433. modal +=
  434. '<p>Do you still want to delete it?</p>' +
  435. '</div>' +
  436. '<div class="modal-footer">' +
  437. '<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>' +
  438. '<button type="submit" class="btn btn-primary">Delete</button>' +
  439. '</div>' +
  440. '</div>' +
  441. '</div>' +
  442. '</div>';
  443. $('#deleteObj').html(modal);
  444. }
  445. },
  446. 'json'
  447. );
  448. }
  449. function deleteLastAssoc(i) {
  450. div = document.getElementById('assocOutcomeForm' + (i).toString());
  451. div.remove();
  452. button = document.getElementById('closeAssoc' + (i).toString());
  453. button.remove();
  454. //counterAssoc -= 1;
  455. //$('#counterAssoc').val(counterAssoc);
  456. }
  457. function addAssoc() {
  458. counterAssoc += 1;
  459. var $select = $('<select />', {
  460. 'class': "selectpicker form-control ",
  461. 'name': "assoc_outcome[]",
  462. 'data-live-search': 'true',
  463. 'id': 'assoc_outcome' + counterAssoc.toString(),
  464. 'data-new-outcome': 'true'
  465. });
  466. var $div = $('<div />', {
  467. 'id': 'assocOutcomeForm' + counterAssoc.toString(),
  468. 'class': 'form-group col-md-11 removable-outcome'
  469. });
  470. var $divForButton = $('<div />', {
  471. 'class': 'col-md-1 removable-outcome',
  472. 'id': 'closeAssoc' + counterAssoc.toString()
  473. });
  474. var $button = $('<button />', {
  475. 'type': 'button',
  476. 'class': 'btn btn-primary',
  477. 'onclick': 'deleteLastAssoc(' + counterAssoc + ')'
  478. });
  479. $button.append('X');
  480. $divForButton.append($button);
  481. $div.appendTo('#assocOutcomeGroup')
  482. $select.append(selectOptions);
  483. $select.appendTo('#assocOutcomeForm' + counterAssoc.toString()).selectpicker('refresh');
  484. $divForButton.appendTo('#assocOutcomeGroup');
  485. ran = true;
  486. //counterAssoc += 1;
  487. $('#counterAssoc').val(counterAssoc);
  488. }
  489. $("#update_button_to_modal").on('click', function(e) {
  490. e.preventDefault();
  491. newOutcomes = [];
  492. $('#assocOutcomeGroup').find('select').each(function() {
  493. if ($(this).data('new-outcome') == true) {
  494. option = $(this).find(':selected');
  495. newOutcomes.push(option[0].text);
  496. }
  497. })
  498. if (newOutcomes.length > 0) {
  499. ul = $("<ul>");
  500. $.each(newOutcomes, function(id, text) {
  501. li = $("<li>").html(text)
  502. ul.append(li);
  503. });
  504. $("#ObjectiveModalBody").html(ul);
  505. $('#ObjectiveAssocModal').modal("toggle");
  506. } else {
  507. pair_every_criteria_with_objective = 0;
  508. $("#update_button").click();
  509. }
  510. })
  511. //Terrible notation but
  512. pair_every_criteria_with_objective = 0;
  513. $('#update_button').on('click', function(e) {
  514. e.preventDefault();
  515. outcome_id = []
  516. program_id = [];
  517. status = $('#status').val();
  518. text = $('#objective-text').val();
  519. id = $('#select-objective').val();
  520. $('#assocOutcomeGroup').find('select').each(function() {
  521. outcome_id.push($(this).val())
  522. })
  523. $('input[name="assoc_program_id[]"]').each(function() {
  524. if (this.checked)
  525. program_id.push($(this).val())
  526. });
  527. $.post(
  528. "{{ URL::action('Objective2Controller@update') }}", {
  529. assoc_outcome: outcome_id,
  530. program_id: program_id,
  531. status: status,
  532. text: text,
  533. id: id,
  534. pair_every_criteria_with_objective: pair_every_criteria_with_objective
  535. },
  536. function($array) {
  537. div = $('<div/>', {
  538. 'class': 'alert alert-dismissible alert-' + $array.status,
  539. 'role': 'alert'
  540. })
  541. button = $('<button/>', {
  542. 'class': 'close',
  543. 'type': 'button',
  544. 'data-dismiss': 'alert',
  545. 'aria-label': 'Close'
  546. }).html('<span aria-hidden="true">&times;</span>');
  547. div.append(button);
  548. if ($array.status == 'danger') {
  549. span = $('<span/>', {
  550. 'class': 'glyphicon glyphicon-remove-sign'
  551. });
  552. } else {
  553. span = $('<span/>', {
  554. 'class': 'glyphicon glyphicon-ok-sign'
  555. });
  556. }
  557. div.append(span);
  558. div.append($array.message);
  559. div.appendTo('#message');
  560. }
  561. )
  562. })
  563. </script>
  564. @stop
  565. @section('javascript')
  566. // --------------------------------------------------------------------------
  567. // Page load
  568. // --------------------------------------------------------------------------
  569. // Hide accordion panel contents by default
  570. $('.panel-group .panel-body').hide();
  571. $('#outcome-display').parent().hide();
  572. // fetchObjectiveForEditing();
  573. // setCriterionStatus();
  574. fetchAllObjectives("select-program", "assoc_outcomes_fetch")
  575. // --------------------------------------------------------------------------
  576. // Functions
  577. // --------------------------------------------------------------------------
  578. // Fetch criterion info for editing
  579. $('#button-add-outcome').on('click', function(e) {
  580. // Prevent the default action of the clicked item. In this case that is submit
  581. e.preventDefault();
  582. return false;
  583. });
  584. $('#button-add-assoc-outcome').on('click', function(e) {
  585. // Prevent the default action of the clicked item. In this case that is submit
  586. e.preventDefault();
  587. return false;
  588. });
  589. // --------------------------------------------------------------------------
  590. // Events
  591. // --------------------------------------------------------------------------
  592. // When panel heading is clicked, toggle it
  593. $('.panel-group .panel-heading').on('click', function()
  594. {
  595. $(this).next().stop().slideToggle();
  596. })
  597. // When list item is clicked, load corresponding info
  598. $('#select-objective').on('change', function()
  599. {
  600. fetchObjectiveForEditing();
  601. $('.selectpicker').selectpicker('refresh');
  602. });
  603. // When list item is clicked, load corresponding info
  604. $('.selectpicker').on('change', function()
  605. {
  606. //alert($(this).find(':selected').val());
  607. $('.selectpicker').selectpicker('refresh');
  608. });
  609. @stop