123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561 |
- @extends('layouts.master')
-
- @section('navigation')
- @if($role==1)
- @include('local.managers.admins._new_navigation')
- @elseif($role==2)
- @include('local.managers.sCoords._new_navigation')
- @elseif($role==3)
- @include('local.managers.pCoords._new_navigation')
- @else
- @include('local.professors._navigation')
- @endif
- @stop
-
- @section('main')
- <!-- View criterion info -->
- <div class="modal fade" id="modal-view-criterion">
- <div class="modal-dialog modal-lg">
- <div class="modal-content">
- <div class="modal-header">
- <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button>
- <h4 class="modal-title"></h4>
- </div>
- <div class="modal-body">
- <table class="table table-bordered">
- <thead>
- <th>Beginning (1-2)</th>
- <th>In Progress (3-4)</th>
- <th>Good (5-6)</th>
- <th>Excellent (7-8)</th>
- <th>Notes</th>
- </thead>
- <tbody>
- <tr></tr>
- </tbody>
- </table>
- </div>
- </div><!-- /.modal-content -->
- </div><!-- /.modal-dialog -->
- </div><!-- /.modal -->
-
-
- <div class="row">
- <div class="col-md-12">
- <div class="well">
- <button id="button-language" class="btn btn-default btn-sm pull-right">Change language / Cambiar idioma</button>
-
- <div id="english-instructions">
- <h4>Instructions:</h4>
- <ol>
- <li>Fill in the scores per criterion for each student. You can see the student's final score in the last column.</li>
- <li>Click 'Publish Assessment' if you are done. Click 'Save as Draft' if you have not finished assessing the activity. You can come back later if you need to make any updates.
- <li>Unpublished results will be isolated. That is, they <strong>will not</strong> be aggregated to other results.</li>
- </ol>
-
- <h4>Notes:</h4>
- <ul>
- <li>If a particular criterion cannot be assessed for a student, select "N/A" (Not Applicable). This <strong>will not</strong> affect the student's score.</li>
- <li>If a particular criterion was assessed but the student did not complete the necessary work, you must select "0". This <strong>will</strong> affect the student's score.</li>
- <li>If a student did not complete any work for this activity, select "0" for all columns in that student's row.</li>
- <li>If a student dropped the class, select "N/A" (Not Applicable) for all columns in that student's row.</li>
- <li>Cells with "N/A" <strong>will not</strong> be used to determine whether a criterion is achieved. Only scores from 0 to 8 will be considered for this purpose.</li>
- <li><strong>At least one score must be from 1-8.</strong> Otherwise, the 'Publish Assessment' and 'Save as Draft' buttons will be <strong>disabled</strong>. If you want to delete previously saved scores, go back to the activity and click the "Delete Assessment" button.</li>
-
- </ul>
- </div>
-
- <div id="spanish-instructions">
- <h4>Instrucciones:</h4>
- <ol>
- <li>Seleccione la puntuación por criterio para cada estudiante. Puede ver la puntuación final en la última columna.</li>
- <li>Oprima 'Publish Assessment' una vez termine. Si no ha terminado, oprima 'Save as Draft' (guardar como borrador). Puede volver a esta página luego si desea hacer cambios.</li>
- <li>Los resultados guardados como borrador estarán asilados. Es decir, <strong>no</strong> se agregarán a los demás resultados.</li>
-
- </ol>
-
- <h4>Notas:</h4>
- <ul>
- <li>Si un criterio particular no puede ser evaluado, seleccione "N/A" (No Aplica). Esto <strong>no</strong> afectará la puntuación final del estudiante.</li>
- <li>Si un criterio particular fue evaluado, pero el estudiante no completó el trabajo necesario, debe seleccionar "0". Esto <strong>sí</strong> afectará la puntuación final del estudiante.</li>
- <li>Si un estudiante no completó el trabajo para esta actividad, seleccione "0" en todas las columnas de la fila de ese estudiante.</li>
- <li>Si un estudiante se dio de baja, seleccione "N/A" (No Aplica) en todas las columnas de la fila de ese estudiante.</li>
- <li>Las celdas con "N/A" <strong>no</strong> serán utilizadas para determinar si un criterio se alcanzó o no. Solamente las puntuaciones del 0 al 8 serán consideradas.</li>
- <li><strong>Al menos una puntuación deber ser del 1 al 8.</strong> De otra manera, el botón para guardar <strong>se desactivará</strong>. Si quiere borrar los resultados del avalúo, vuelva a la actividad y oprima el botón que dice "Delete Assessment".</li>
-
-
- </ul>
- </div>
-
- </div>
-
- <p id="course">Course: {{{ $course->code }}} {{{ $course->number }}}</p>
- <p id="section">Section: {{{ $course->section }}}</p>
- {{ HTML::linkAction('ActivitiesController@show', 'Back to Activity', array($activity->id), array('class'=>'btn btn-default btn-sm pull-right')) }}
- <p id="activity" data-activity-id="{{{ $activity->id }}}">Activity: {{{ $activity->name}}} </p>
- <p>Passing Criteria: <span id="expected_percentage">{{{ $rubric->expected_percentage }}}% of students must obtain at least </span><span id="expected_points">{{{$rubric->expected_points}}}</span> points </p>
-
- <table data-rubric-id="{{{ $rubric->id }}}" id="assessment-table" class="table table-striped table-condensed table-bordered">
- <thead>
- <tr>
- <th>
- <div class="th-box">
- Student
- </div>
- </th>
- @foreach ($rubric_contents as $criterion)
- <th class="criterion-field" data-criterion-id="{{{ $criterion->id }}}"><div class="th-box">{{ $criterion->name}}</div></th>
- @endforeach
- <th>Student Percentage</th>
- <th>Comments</th>
- </tr>
- </thead>
- <tbody>
-
- <!-- If the activity was assessed, load the assessment. Otherwise load empty sheet -->
- @if(sizeof($assessments)!=0)
- <!-- For each assessment -->
- @foreach ($assessments as $assessment)
- <tr class="student-row">
- <!-- Fetch student name -->
- <td class="student-field" data-student-id="{{ $assessment->student_id }}">
- {{{ $assessment->name }}}
- </td>
-
- <!-- For each criterion in the rubric, there's a score field -->
- @for ($i = 0; $i<sizeof($rubric_contents); $i++)
- <td class="score-field" contenteditable="true" data-toggle="tooltip" data-placement="top" data-container="tr" title="{{{ $assessment->name }}}">
- {{ $scores_array[$assessment->id][$rubric_contents[$i]->id] }}
- </td>
- @endfor
- <td class="percentage">{{{ $assessment->percentage }}}</td>
- <td class="">
- <textarea class="comments full-textarea" placeholder="Max. 255 characters" maxLength="255" >{{ $assessment->comments }}</textarea>
- </td>
- </tr>
- @endforeach
- @else
- @foreach ($students as $student)
- <tr class="student-row">
- <td class="student-field" data-student-id={{ $student->id }}>{{{ $student->name }}}</td>
- @for ($i = 0; $i<sizeof($rubric_contents); $i++)
- <td class="score-field" contenteditable="true" data-toggle="tooltip" data-placement="top" data-container="tr" title="{{{ $student->name }}}">
- N/A
- </td>
- @endfor
- <td class="percentage"></td>
- <td class="comments"><textarea class="comments full-textarea" placeholder="Max. 255 characters" maxLength="255" ></textarea></td>
- </tr>
- @endforeach
- @endif
- </tbody>
- <tfoot>
- <tr>
- <td>
- <strong>Passed Criteria Percentage </strong>
- </td>
- @for ($i = 0; $i<sizeof($rubric_contents); $i++)
- <td class="total"><strong><span class="total-value"></span><span class="percent-sign">%</span></strong>
- </td>
- @endfor
- <td></td>
-
- </tr>
- </tfoot>
- </table>
-
- <div class="text-center">
- <button id="button-submit-assessment" class="btn btn-primary btn-lg publish">Publish Assessment</button>
- <button id="button-draft-assessment" class="btn btn-primary btn-lg draft">Save as Draft</button>
- </div>
- </div>
- </div>
-
- @stop
-
- @section('included-js')
-
- <!-- StickyTableHeaders js -->
- <script src="{{ asset('vendor/stickyTableHeaders/js/jquery.stickytableheaders.min.js') }}"></script>
-
- @stop
-
-
- @section ('javascript')
-
- // --------------------------------------------------------------------------
- // Page load
- // --------------------------------------------------------------------------
-
-
- // Enable fixed headers
- $('#assessment-table').stickyTableHeaders();
-
-
- // Hide spanish instructions by default
- $('#spanish-instructions').toggle();
-
-
- $('.total').each(function(index)
- {
- percentagePerCriterion(index+1);
- });
-
- $('.student-row').each(function(index)
- {
- percentagePerStudent($(this));
- });
-
- // Highlight student names on hover
- $('.student-row td').on('mouseover', function()
- {
- $('.student-field').css(
- {
- 'color': 'black',
- 'font-weight': 'normal'
- });
-
- $(this).siblings('.student-field').css(
- {
- 'color': '#DD0026',
- });
- });
-
- toggleSaveButton();
-
- // --------------------------------------------------------------------------
- // Functions
- // --------------------------------------------------------------------------
-
- // Calculate average of students that passed a specific criterion
- function percentagePerCriterion(columnIndex)
- {
- // Object to hold the score sum of each criterion
- var sum = 0 ;
- var total = 0;
-
- columnIndex+=1;
-
- // Iterate through rows of column
- $('table tbody tr td:nth-child('+columnIndex+')').each(function( index )
- {
- var val = parseInt($(this).text().trim());
-
- /* If N/A or 0 are chosen, they are ignored in the calculation. */
- if(val % 1 === 0)
- {
- if(val >= parseInt($('#expected_points').text()))
- {
- sum+=1;
- }
-
- total+=1;
- }
- });
-
- var percentage= (sum/total*100).toFixed(2);
-
- // If no criteria were assessed, set the percentage to 0.
- // This is to avoid show NaN%
- if(total==0)
- {
- percentage="N/A";
- $('.total:nth-child('+columnIndex+') span.total-value').html(percentage);
- $('.total:nth-child('+columnIndex+') span.percent-sign').hide();
- }
- else
- {
- $('.total:nth-child('+columnIndex+') span.total-value').html(percentage);
- $('.total:nth-child('+columnIndex+') span.percent-sign').show();
- }
- }
-
- // Calculate total for a specific student
- function percentagePerStudent(row)
- {
- // Object to hold the score student's total score
- var sum = 0 ;
- var total = 0;
- var percentage = 0;
-
- row.find('td.score-field').each(function(index)
- {
- var val = parseInt($(this).text().trim());
- if(val % 1 === 0) //If number is integer
- {
- sum += val;
- total+=1;
- }
- });
-
- percentage =((sum/(total*8))*100).toFixed(2);
-
- //If percentage is not a number, set it to 0.
- if(isNaN(percentage))
- {
- percentage="N/A";
- row.find('.percentage').html('<strong>'+percentage+'</strong>');
- }
- else
- {
- row.find('.percentage').html('<strong>'+percentage+'%</strong>');
- }
- }
-
- function toggleSaveButton()
- {
- // Check at least one total criterion percentage is not zero
- var all_zeros_criteria = true;
-
- $('.total-value').each(function(index)
- {
- if(Number($(this).text())>0.00)
- all_zeros_criteria = false;
- });
-
-
- // Check at least one total student percentage is not zero
- var all_zeros_students = true;
-
- $('.percentage').each(function(index)
- {
- var value = $(this).text().replace('%', '');
- if(Number(value)>0.00)
- all_zeros_students = false;
- });
-
-
- if(all_zeros_criteria && all_zeros_students)
- {
- $('#button-submit-assessment').prop('disabled', true);
- $('#button-draft-assessment').prop('disabled', true);
- }
- else
- {
- $('#button-submit-assessment').prop('disabled', false);
- $('#button-draft-assessment').prop('disabled', false);
- }
-
- return;
- }
-
-
- // --------------------------------------------------------------------------
- // Events
- // --------------------------------------------------------------------------
- $('td.score-field').on('focus', function()
- {
- $(this).addClass('active');
-
- // See http://stackoverflow.com/a/6150060/145346
- var cell = this;
- var range, selection;
- if (document.body.createTextRange) {
- range = document.body.createTextRange();
- range.moveToElementText(cell);
- range.select();
- } else if (window.getSelection) {
- selection = window.getSelection();
- range = document.createRange();
- range.selectNodeContents(cell);
- selection.removeAllRanges();
- selection.addRange(range);
- }
- });
-
- // When any score changes, calculate percentages
- $('td.score-field').on('blur', function()
- {
- var value = $(this).text().trim();
- var allowed_values = ['0', '1', '2', '3', '4', '5', '6', '7', '8', 'N/A'];
-
- console.log(value);
-
- if(allowed_values.indexOf(value) === -1)
- {
- $(this).text('N/A');
- }
- else
- {
- $(this).text(value);
- }
-
- $(this).removeClass('active');
-
- percentagePerCriterion($(this).index());
- percentagePerStudent($(this).closest('tr'));
- toggleSaveButton();
-
- });
-
-
- // Submit button is clicked
- $('#button-submit-assessment, #button-draft-assessment').on('click', function(e)
- {
-
- var draft = 0;
-
- if($(this).hasClass('draft'))
- draft = 1;
-
- var expected_points = parseInt($('#expected_points').text());
- var expected_percentage = parseInt($('#expected_percentage').text());
-
- //Prevent page refresh
- e.preventDefault();
-
- // Row in the database
- var activity_id = $('#activity').data('activity-id');
-
- // Object to hold the score sum of each criterion
- var criteriaSumObject = new Object();
-
- // Object to hold % of students that passed each criterion
- var CriteriaAchievedPercentage = new Object();
-
- // Object to hold all student evaluations
- var studentAssessments = new Array();
-
- // Iterate through all students
- $('#assessment-table tbody tr').each(function( index )
- {
- var ScoresObject = new Object(); // Scores column in database
- var CriterionObject = new Object(); // Objects inside ScoresObject
- var SingleStudentAssessment = new Object();
- SingleStudentAssessment.student_id = $(this).find('.student-field').data('student-id');
-
- // For each criterion, store the score in array
- $(this).children('td.score-field').each(function(index)
- {
- // Table cell with a score
- var scoreField = $(this);
-
- // Criterion being evaluated in current iteration
- var criterion_id = $('.criterion-field').eq(index).data('criterion-id');
-
- // Score in the cell
- var score = scoreField.text().trim();
-
- // Store the score in the scores Object
- ScoresObject[criterion_id]=score;
-
- // Initialize the index for the sum object, if it's undefined
- if(typeof(criteriaSumObject[criterion_id]) == 'undefined')
- {
- criteriaSumObject[criterion_id]=0;
- }
-
- // Add to this criterion's total
- criteriaSumObject[criterion_id]+=parseInt(score);
- });
-
- SingleStudentAssessment.scores = ScoresObject;
- SingleStudentAssessment.percentage = $(this).find('.percentage').text();
- SingleStudentAssessment.comments = $.trim($(this).find('.comments').val());
- console.log('comment '+index+': '+SingleStudentAssessment.comments);
- // console.log('student object: '+JSON.stringify(SingleStudentAssessment));
-
- var clone = jQuery.extend({}, SingleStudentAssessment);
- studentAssessments.push(clone);
-
-
- });
-
- // console.log('students: '+JSON.stringify(studentAssessments));
- // console.log('total points per criteria: '+JSON.stringify(criteriaSumObject));
-
- // Iterate through all evaluated criteria, determining which were achieved
- // by comparing the completion percentage to the expected percentage
- var CriteriaAchievedResults = new Object();
-
-
- $('.total').each(function(index)
- {
- var id = $('.criterion-field').eq(index).data('criterion-id');
-
- CriteriaAchievedPercentage[id] = parseFloat($(this).find('span').text());
-
- //Set whether criterion was achieved (1) or not (0)
- if(CriteriaAchievedPercentage[id] >= expected_percentage)
- {
- CriteriaAchievedResults[id]=1;
- }
- else if (CriteriaAchievedPercentage[id] < expected_percentage)
- {
- CriteriaAchievedResults[id]=0;
- }
- else
- {
- CriteriaAchievedResults[id]=null;
- }
-
- });
-
- // console.log('criteria percentages: '+JSON.stringify(CriteriaAchievedPercentage));
- // console.log('criteria achieved results: '+JSON.stringify(CriteriaAchievedResults));
-
-
- // Save activity to the database
- $.post
- (
- "{{ URL::action('ActivitiesController@saveAssessment') }}",
- {
- activity_id: activity_id,
- draft: draft,
- criteria_achieved_percentage: JSON.stringify(CriteriaAchievedPercentage),
- criteria_achievement: JSON.stringify(CriteriaAchievedResults),
- student_scores: JSON.stringify(studentAssessments),
- },
- function(data)
- {
- location.reload();
- }
- );
-
- });
-
- // Language button is clicked
- $('#button-language').on('click', function(e)
- {
- $('#english-instructions').stop().toggle();
- $('#spanish-instructions').stop().toggle();
-
- });
-
- // Criterion name is clicked
- $('.criterion-field').on('click', function()
- {
- $.ajax({
- type: 'POST',
- url: "{{ URL::action('RubricsController@fetchRubricCriterion') }}",
- data: {
- rubric_id: $(this).closest('table').data('rubric-id'),
- criterion_id: $(this).data('criterion-id'),
- },
- success: function(data)
- {
- data = JSON.parse(data);
- $('.modal-title').html(data.name);
-
- $('.modal-body tbody tr').empty();
- $('.modal-body tbody tr').append
- (
- '<td>'+data.description12+'</td>'
- +'<td>'+data.description34+'</td>'
- +'<td>'+data.description56+'</td>'
- +'<td>'+data.description78+'</td>'
- );
-
- if(data.notes!=null)
- $('.modal-body tbody tr').append('<td>'+data.notes+'</td>');
- else
- $('.modal-body tbody tr').append('<td></td>');
-
- },
- async:true
- });
- $('#modal-view-criterion').modal();
- });
-
-
- @stop
|