version 1.27, 2004/11/08 15:21:38
|
version 1.30, 2005/02/02 18:53:32
|
Line 148 sub BuildStudentSubmissionsPage {
|
Line 148 sub BuildStudentSubmissionsPage {
|
} |
} |
} |
} |
|
|
|
## |
|
## get_headers: |
|
## return the proper headers for the given response |
|
sub get_headers { |
|
my ($prob,$partid,$respid,$resptype,$analysis,$output,$purpose, |
|
@basic_headers) = @_; |
|
my @headers; |
|
if ($resptype eq 'essay' && $purpose eq 'display' && |
|
($output eq 'html')) {# || scalar(@{$prob->parts})!=1)) { |
|
@headers = (); |
|
} elsif ($resptype =~ /^(option|match|rank)$/) { |
|
my $prefix = '_'; |
|
if ($purpose eq 'display') { |
|
$prefix = ''; |
|
} |
|
my @foils = |
|
map { |
|
$prefix.$_; |
|
} sort(keys(%{$analysis->{$partid.'.'.$respid}->{'_Foils'}})); |
|
if (scalar(@basic_headers) && $basic_headers[0] eq 'Correct') { |
|
@foils = map { ($_ , $_.' Correct') } @foils; |
|
shift(@basic_headers); # Get rid of 'Correct' |
|
} |
|
@headers = (@foils,@basic_headers); |
|
} else { |
|
@headers = ('Submission',@basic_headers); |
|
} |
|
return @headers; |
|
} |
|
|
######################################################### |
######################################################### |
######################################################### |
######################################################### |
## |
## |
Line 167 sub prepare_html_output {
|
Line 197 sub prepare_html_output {
|
} |
} |
# |
# |
# Compute the number of columns per response |
# Compute the number of columns per response |
my @response_headers = ('Submission'); |
my @extra_resp_headers; |
if ($ENV{'form.correctans'} eq 'true') { |
if ($ENV{'form.correctans'} eq 'true') { |
push(@response_headers,'Correct'); |
push(@extra_resp_headers,'Correct'); |
} |
} |
if ($ENV{'form.prob_status'} eq 'true') { |
if ($ENV{'form.prob_status'} eq 'true') { |
push(@response_headers,'Award Detail'); |
push(@extra_resp_headers,'Award Detail'); |
push(@response_headers,'Time'); |
push(@extra_resp_headers,'Time'); |
push(@response_headers,'Attempt'); |
push(@extra_resp_headers,'Attempt'); |
push(@response_headers,'Awarded'); |
push(@extra_resp_headers,'Awarded'); |
} |
} |
my $response_multiplier = scalar(@response_headers); |
my $response_multiplier = scalar(@extra_resp_headers); |
# |
# |
# Create the table header |
# Create the table header |
my @student_columns = ('username','domain','id'); |
my @student_columns = ('username','domain','id'); |
Line 192 sub prepare_html_output {
|
Line 222 sub prepare_html_output {
|
# we put the headers into the %headers hash |
# we put the headers into the %headers hash |
my $total_col = scalar(@student_columns); |
my $total_col = scalar(@student_columns); |
my $nonempty_part_headers = 0; |
my $nonempty_part_headers = 0; |
|
# |
|
my %problem_analysis; |
foreach my $prob (@$problems) { |
foreach my $prob (@$problems) { |
|
my $src = $prob->src; |
|
my %analysis = &Apache::lonstathelpers::get_problem_data($src); |
|
$problem_analysis{$prob->src}=\%analysis; |
|
# |
my $prob_span = 0; |
my $prob_span = 0; |
my $single_part = 0; |
my $single_part = 0; |
if (scalar(@{$prob->parts}) == 1) { |
if (scalar(@{$prob->parts}) == 1) { |
Line 203 sub prepare_html_output {
|
Line 239 sub prepare_html_output {
|
my $responses = [$prob->responseIds($partid)]; |
my $responses = [$prob->responseIds($partid)]; |
my $resptypes = [$prob->responseType($partid)]; |
my $resptypes = [$prob->responseType($partid)]; |
for (my $i=0;$i<scalar(@$responses);$i++) { |
for (my $i=0;$i<scalar(@$responses);$i++) { |
if ($resptypes->[$i] eq 'essay') { |
my $respid = $responses->[$i]; |
# do something clever, like shut up. |
my @headers = &get_headers($prob,$partid,$respid, |
} else { |
$resptypes->[$i], |
$total_col += scalar(@response_headers); |
$problem_analysis{$prob->src}, |
|
'html','display', |
|
@extra_resp_headers); |
|
if (scalar(@headers)>0) { |
|
$total_col += scalar(@headers); |
|
$part_span += scalar(@headers); |
$headers{'response'} .= |
$headers{'response'} .= |
'<th colspan="'.scalar(@response_headers).'">'. |
'<th colspan="'.scalar(@headers).'">'. |
&mt('Response [_1]',$responses->[$i]).'</th>'; |
&mt('Response [_1]',$responses->[$i]).'</th>'; |
$headers{'student'}.= '<th>'.join('</th><th>', |
$headers{'student'}.= '<th>'.join('</th><th><nobr>', |
@response_headers). |
@headers). |
'</th>'; |
'</nobr></th>'; |
$part_span += scalar(@response_headers); |
|
} |
} |
} |
} |
if (! $single_part) { |
if (! $single_part) { |
Line 257 sub prepare_html_output {
|
Line 297 sub prepare_html_output {
|
my $count; |
my $count; |
$r->print($/.$full_header.$/); |
$r->print($/.$full_header.$/); |
my $row_class = 'odd'; # css |
my $row_class = 'odd'; # css |
|
my $mycount = 10; |
foreach my $student (@$students) { |
foreach my $student (@$students) { |
|
last if ($mycount-- < 1); |
my $student_row_data; |
my $student_row_data; |
if ($count++ >= 30) { |
if ($count++ >= 30) { |
$r->print('</table>'.$/.$full_header.$/); |
$r->print('</table>'.$/.$full_header.$/); |
Line 271 sub prepare_html_output {
|
Line 313 sub prepare_html_output {
|
# |
# |
# Figure out what it is we need to output for this student |
# Figure out what it is we need to output for this student |
my @essays; |
my @essays; |
my %problem_data; |
my %prob_data; |
my $maxrow; |
my $maxrow; |
foreach my $prob (@$problems) { |
foreach my $prob (@$problems) { |
my $symb = $prob->symb; |
$prob_data{$prob->symb}={}; |
$problem_data{$symb}={}; |
|
foreach my $partid (@{$prob->parts}) { |
foreach my $partid (@{$prob->parts}) { |
my @responses = $prob->responseIds($partid); |
my @responses = $prob->responseIds($partid); |
my @response_type = $prob->responseType($partid); |
my @response_type = $prob->responseType($partid); |
for (my $i=0;$i<=$#responses;$i++) { |
for (my $i=0;$i<=$#responses;$i++) { |
my $respid = $responses[$i]; |
my $respid = $responses[$i]; |
my $resptype = $response_type[$i]; |
|
my $width = scalar(@response_headers); |
|
$problem_data{$symb}->{$partid}->{$respid}={}; |
|
my $resp_data = $problem_data{$symb}->{$partid}->{$respid}; |
|
$resp_data->{'fake'} = qq{<td colspan="$width"> </td>}; |
|
my $results = |
my $results = |
&Apache::loncoursedata::get_response_data_by_student |
&Apache::loncoursedata::get_response_data_by_student |
($student,$prob->symb(),$respid); |
($student,$prob->symb(),$respid); |
|
my $resptype = $response_type[$i]; |
|
my @headers = &get_headers($prob,$partid,$respid, |
|
$resptype, |
|
$problem_analysis{$prob->src}, |
|
'html','normal', |
|
@extra_resp_headers); |
|
my $width = scalar(@headers); |
|
my $resp_data; |
|
$resp_data->{'fake'} = qq{<td colspan="$width"> </td>}; |
if (! defined($results)) { |
if (! defined($results)) { |
$results = []; |
$results = []; |
} |
} |
# |
# |
if (scalar(@$results) > $maxrow && $resptype ne 'essay') { |
if (scalar(@$results) > $maxrow && $resptype ne 'essay') { |
$maxrow = scalar(@$results); |
$maxrow = scalar(@$results); |
} |
} |
for (my $j=scalar(@$results)-1;$j>=0;$j--) { |
for (my $j=scalar(@$results)-1;$j>=0;$j--) { |
my $response = $results->[$j]; |
|
if ($ENV{'form.all_sub'} ne 'true') { |
if ($ENV{'form.all_sub'} ne 'true') { |
next if ($j ne scalar(@$results)-1); |
next if ($j ne scalar(@$results)-1); |
} |
} |
|
my $response = &hashify_response($results->[$j], |
|
$prob, |
|
$student, |
|
$partid, |
|
$respid); |
if ($resptype eq 'essay') { |
if ($resptype eq 'essay') { |
push(@essays, |
push(@essays, |
&html_essay_results($student, |
&html_essay_results(\@headers, |
$prob,$partid,$respid, |
$prob,$partid,$respid, |
$response, |
$response, |
$single_response). |
$single_response). |
'</td>'); |
'</td>'); |
} else { |
} else { |
push(@{$resp_data->{'real'}}, |
push(@{$resp_data->{'real'}}, |
&html_results($student, |
&html_non_essay_results(\@headers, |
$prob,$partid,$respid, |
$prob,$partid,$respid, |
$response,$resptype)); |
$response,$resptype)); |
} |
} |
} |
} |
|
$prob_data{$prob->symb}->{$partid}->{$respid}=$resp_data; |
} # end of $i loop |
} # end of $i loop |
} # end of partid loop |
} # end of partid loop |
} # end of prob loop |
} # end of prob loop |
Line 333 sub prepare_html_output {
|
Line 383 sub prepare_html_output {
|
my $html; |
my $html; |
my $no_data = 1; |
my $no_data = 1; |
foreach my $prob (@$problems) { |
foreach my $prob (@$problems) { |
my $symb = $prob->symb; |
|
foreach my $partid (@{$prob->parts}) { |
foreach my $partid (@{$prob->parts}) { |
my @responses = $prob->responseIds($partid); |
my @responses = $prob->responseIds($partid); |
my @response_type = $prob->responseType($partid); |
my @response_type = $prob->responseType($partid); |
for (my $i=0;$i<=$#responses;$i++) { |
for (my $i=0;$i<=$#responses;$i++) { |
my $respid = $responses[$i]; |
my $respid = $responses[$i]; |
my $resp_data = |
my $resp_data = |
$problem_data{$symb}->{$partid}->{$respid}; |
$prob_data{$prob->symb}->{$partid}->{$respid}; |
next if ($response_type[$i] eq 'essay'); |
next if ($response_type[$i] eq 'essay'); |
if (defined($resp_data->{'real'}->[$rows_output])) { |
if (defined($resp_data->{'real'}->[$rows_output])) { |
$html .= $resp_data->{'real'}->[$rows_output]; |
$html .= $resp_data->{'real'}->[$rows_output]; |
Line 370 sub prepare_html_output {
|
Line 419 sub prepare_html_output {
|
return; |
return; |
} |
} |
|
|
|
sub hashify_response { |
|
my ($response,$prob,$student,$partid,$respid) =@_; |
|
my $resp_hash = {}; |
|
if ($ENV{'form.correctans'} eq 'true') { |
|
$resp_hash->{'Correct'} = |
|
&Apache::lonstathelpers::get_student_answer |
|
($prob,$student->{'username'},$student->{'domain'}, |
|
$partid,$respid); |
|
} |
|
$resp_hash->{'Submission'} = |
|
$response->[&Apache::loncoursedata::RDs_submission()]; |
|
$resp_hash->{'Award Detail'} = |
|
$response->[&Apache::loncoursedata::RDs_awarddetail()]; |
|
$resp_hash->{'Time'} = |
|
$response->[&Apache::loncoursedata::RDs_timestamp()]; |
|
$resp_hash->{'Attempt'} = |
|
$response->[&Apache::loncoursedata::RDs_tries()]; |
|
$resp_hash->{'Awarded'} = |
|
$response->[&Apache::loncoursedata::RDs_awarded()]; |
|
return $resp_hash; |
|
} |
|
|
##################################################### |
##################################################### |
## |
## |
## HTML helper routines |
## HTML helper routines |
## |
## |
##################################################### |
##################################################### |
sub html_essay_results { |
sub html_essay_results { |
my ($student,$prob,$partid,$respid,$response,$single_response)=@_; |
my ($headers,$prob,$partid,$respid,$response,$single_response)=@_; |
# |
if (! ref($headers) || ref($headers) ne 'ARRAY') { |
my $submission =$response->[&Apache::loncoursedata::RDs_submission()]; |
return ''; |
$submission = &html_format_sub($submission,'essay'); |
|
# |
|
my $correct = ''; |
|
if ($ENV{'form.correctans'} eq 'true') { |
|
$correct = &Apache::lonstathelpers::get_student_answer |
|
($prob,$student->{'username'},$student->{'domain'}, |
|
$partid,$respid); |
|
$correct = &html_format_sub($correct,'essay'); |
|
} |
} |
|
# Start of telling them what problem, part, and response |
my $Str; |
my $Str; |
if (! $single_response) { |
if (! $single_response) { |
my $id = $prob->compTitle; |
my $id = $prob->compTitle; |
Line 399 sub html_essay_results {
|
Line 463 sub html_essay_results {
|
} |
} |
$Str .= '<nobr>'.$id.'</nobr>'.(' 'x4); |
$Str .= '<nobr>'.$id.'</nobr>'.(' 'x4); |
} |
} |
if ($ENV{'form.prob_status'} eq 'true') { |
# |
$Str .= '<nobr>'; |
shift(@$headers); # Get rid of the Submission header |
$Str .= $response->[&Apache::loncoursedata::RDs_awarddetail()]. |
my $correct = ''; |
(' 'x4); |
if ($headers->[0] eq 'Correct') { |
$Str .= &mt('Attempt [_1]', |
$correct = &html_format_essay_sub($response->{'Correct'}); |
$response->[&Apache::loncoursedata::RDs_tries()]). |
shift(@$headers); |
(' 'x4); |
} |
$Str .= &Apache::lonlocal::locallocaltime |
$Str .= '<nobr>'. |
($response->[&Apache::loncoursedata::RDs_timestamp()]). |
join('', |
(' 'x4); |
map { |
$Str .= &mt('Awarded: [_1]', |
(' 'x4).&mt($_.': [_1]',$response->{$_}); |
$response->[&Apache::loncoursedata::RDs_awarded()]). |
} @$headers).'</nobr>'; |
(' 'x4); |
if (@$headers || ! $single_response) { |
$Str .= '</nobr><br />'; |
$Str .= '<br />'; |
} |
} |
$Str .= $submission; |
$Str .= &html_format_essay_sub($response->{'Submission'}); |
|
# |
if (defined($correct) && $correct !~ /^\s*$/) { |
if (defined($correct) && $correct !~ /^\s*$/) { |
$Str .= '<hr /><b>'.&mt('Correct').'</b>'.$correct |
$Str .= '<hr /><b>'.&mt('Correct').'</b>'.$correct |
} |
} |
return $Str; |
return $Str; |
} |
} |
|
|
sub html_results { |
sub html_format_essay_sub { |
my ($student,$prob,$partid,$respid,$response,$resptype) = @_; |
my ($submission) = @_; |
my $submission =$response->[&Apache::loncoursedata::RDs_submission()]; |
return '' if (! defined($submission) || $submission eq ''); |
$submission = &html_format_sub($submission,$resptype); |
$submission = &HTML::Entities::decode($submission); |
my $correct = ''; |
$submission =~ s/\\\"/\"/g; |
if ($ENV{'form.correctans'} eq 'true') { |
$submission =~ s/\\\'/\'/g; |
$correct = &Apache::lonstathelpers::get_student_answer |
$submission =~ s|\\r\\n|$/|g; |
($prob,$student->{'username'},$student->{'domain'}, |
$submission = &HTML::Entities::encode($submission,'<>&"'); |
$partid,$respid); |
$submission =~ s|$/\s*$/|$/</p><p>$/|g; |
$correct = &html_format_sub($correct,$resptype); |
$submission =~ s|\\||g; |
} |
$submission = '<p>'.$submission.'</p>'; |
my $Str; |
return $submission; |
$Str .= '<td valign="top">'.$submission.'</td>'; |
|
if ($ENV{'form.correctans'} eq 'true') { |
|
$Str .= '<td valign="top">'.$correct.'</td>'; |
|
} |
|
if ($ENV{'form.prob_status'} eq 'true') { |
|
$Str .= '<td valign="top">'. |
|
$response->[&Apache::loncoursedata::RDs_awarddetail()]. |
|
'</td>'; |
|
$Str .= '<td valign="top"><nobr>'. |
|
&Apache::lonlocal::locallocaltime |
|
($response->[&Apache::loncoursedata::RDs_timestamp()]). |
|
'</nobr></td>'; |
|
$Str .= '<td valign="top">'. |
|
$response->[&Apache::loncoursedata::RDs_tries()]. |
|
'</td>'; |
|
$Str .= '<td valign="top">'. |
|
$response->[&Apache::loncoursedata::RDs_awarded()]. |
|
'</td>'; |
|
} |
|
return $Str; |
|
} |
} |
|
|
sub html_format_sub { |
sub html_non_essay_results { |
my ($submission,$resptype) = @_; |
my ($headers,$prob,$partid,$respid,$response,$resptype) = @_; |
|
if (! ref($headers) || ref($headers) ne 'ARRAY' || ! scalar(@$headers)) { |
|
return ''; |
|
} |
|
# |
|
my $submission = &HTML::Entities::decode($response->{'Submission'}); |
return '' if (! defined($submission) || $submission eq ''); |
return '' if (! defined($submission) || $submission eq ''); |
$submission = &HTML::Entities::decode($submission); |
|
$submission =~ s/\\\"/\"/g; |
$submission =~ s/\\\"/\"/g; |
$submission =~ s/\\\'/\'/g; |
$submission =~ s/\\\'/\'/g; |
if ($resptype eq 'essay') { |
if ($resptype eq 'radiobutton') { |
$submission =~ s|\\r\\n|$/|g; |
|
$submission = &HTML::Entities::encode($submission,'<>&"'); |
|
$submission =~ s|$/\s*$/|$/</p><p>$/|g; |
|
$submission =~ s|\\||g; |
|
$submission = '<p>'.$submission.'</p>'; |
|
} elsif ($resptype eq 'radiobutton') { |
|
$submission = &HTML::Entities::encode($submission,'<>&"'); |
$submission = &HTML::Entities::encode($submission,'<>&"'); |
$submission =~ s/=([^=])$//; |
$submission =~ s/=([^=])$//; |
} elsif ($resptype =~ /^(option|match|rank)$/) { |
$submission = '<nobr>'.$submission.'</nobr>'; |
$submission = |
} |
'<ul class="sub_studentans">'. |
$response->{'Submission'} = $submission; |
'<li>'.join('</li><li>', |
# |
map { &HTML::Entities::encode($_,'<>&"'); |
my @values; |
} map { |
if ($resptype =~ /^(option|match|rank)$/) { |
&Apache::lonnet::unescape($_) ; |
my %submission = |
} sort split('&',$submission) |
map { |
). |
my ($foil,$value) = split('=',&Apache::lonnet::unescape($_)); |
'</li><ul>'; |
($foil,$value); |
|
} split('&',$response->{'Submission'}); |
|
my %correct; |
|
if (exists($response->{'Correct'})) { |
|
%correct = |
|
map { |
|
my ($foil,$value)=split('=',&Apache::lonnet::unescape($_)); |
|
($foil,$value); |
|
} split('&',$response->{'Correct'}); |
|
} |
|
# |
|
foreach my $original_header (@$headers) { |
|
if ($original_header =~ /^_/) { |
|
# '_' denotes a foil column |
|
my ($header) = ($original_header =~ m/^_(.*)$/); |
|
my $option = ''; |
|
if ( my ($foil) = ($header =~ /(.*) Correct$/)) { |
|
if (exists($correct{$foil})) { |
|
$option = $correct{$foil}; |
|
} |
|
} elsif (exists($submission{$header})) { |
|
$option = $submission{$header}; |
|
} |
|
push(@values,&HTML::Entities::encode($option)); |
|
} else { |
|
# A normal column |
|
push(@values,$response->{$original_header}); |
|
} |
|
} |
} else { |
} else { |
$submission = &HTML::Entities::encode($submission,'<>&"'); |
@values = map { $response->{$_}; } @$headers; |
} |
} |
return $submission; |
my $td = '<td valign="top">'; |
|
my $str = $td.join('</td>'.$td,@values).'</td>'; |
|
return $str; |
} |
} |
|
|
|
|
######################################################### |
######################################################### |
######################################################### |
######################################################### |
## |
## |
Line 654 sub prepare_excel_output {
|
Line 728 sub prepare_excel_output {
|
} |
} |
} |
} |
} |
} |
|
# Fill in the remaining rows with the students data |
|
for (my $row = $student_row+1;$row<=$max_row;$row++) { |
|
my $cols = 0; |
|
foreach my $field (@StudentColumns) { |
|
$worksheet->write($row,$cols++, |
|
$student->{$field}); |
|
} |
|
} |
$rows_output++; |
$rows_output++; |
&Apache::lonhtmlcommon::Increment_PrgWin($r,\%prog_state, |
&Apache::lonhtmlcommon::Increment_PrgWin($r,\%prog_state, |
'last student'); |
'last student'); |
Line 763 sub prepare_csv_output {
|
Line 845 sub prepare_csv_output {
|
} |
} |
# |
# |
# Compute the number of columns per response |
# Compute the number of columns per response |
my @response_headers = ('Submission'); |
my @extra_resp_headers; |
if ($ENV{'form.correctans'} eq 'true') { |
if ($ENV{'form.correctans'} eq 'true') { |
push(@response_headers,'Correct'); |
push(@extra_resp_headers,'Correct'); |
} |
} |
if ($ENV{'form.prob_status'} eq 'true') { |
if ($ENV{'form.prob_status'} eq 'true') { |
push(@response_headers,'Award Detail'); |
push(@extra_resp_headers,'Award Detail'); |
push(@response_headers,'Time'); |
push(@extra_resp_headers,'Time'); |
push(@response_headers,'Attempt'); |
push(@extra_resp_headers,'Attempt'); |
push(@response_headers,'Awarded'); |
push(@extra_resp_headers,'Awarded'); |
} |
} |
my $response_multiplier = scalar(@response_headers); |
my $response_multiplier = scalar(@extra_resp_headers); |
# |
# |
# Create the table header |
# Create the table header |
my @student_columns = ('username','domain','id'); |
my @student_columns = ('username','domain','id'); |
Line 799 sub prepare_csv_output {
|
Line 881 sub prepare_csv_output {
|
my $resp_idx = $prob_start_idx + $response_multiplier * $i; |
my $resp_idx = $prob_start_idx + $response_multiplier * $i; |
$headers{'response'}->[$resp_idx]= |
$headers{'response'}->[$resp_idx]= |
&mt('Response [_1]',$responses->[$i]); |
&mt('Response [_1]',$responses->[$i]); |
for (my $j=0;$j<=$#response_headers;$j++) { |
for (my $j=0;$j<=$#extra_resp_headers;$j++) { |
$headers{'student'}->[$resp_idx+$j]=$response_headers[$j]; |
$headers{'student'}->[$resp_idx+$j]=$extra_resp_headers[$j]; |
} |
} |
} |
} |
$part_start_idx += scalar(@$responses)*$response_multiplier; |
$part_start_idx += scalar(@$responses)*$response_multiplier; |
Line 884 sub prepare_csv_output {
|
Line 966 sub prepare_csv_output {
|
sub compile_response_data { |
sub compile_response_data { |
my ($response,$student,$prob,$partid,$respid) = @_; |
my ($response,$student,$prob,$partid,$respid) = @_; |
my @rowdata; |
my @rowdata; |
push(@rowdata,$response->[&Apache::loncoursedata::RDs_submission()]); |
push(@rowdata,&Apache::lonnet::unescape($response->[&Apache::loncoursedata::RDs_submission()])); |
if ($ENV{'form.correctans'} eq 'true') { |
if ($ENV{'form.correctans'} eq 'true') { |
my $correct = &Apache::lonstathelpers::get_student_answer |
my $correct = &Apache::lonstathelpers::get_student_answer |
($prob,$student->{'username'},$student->{'domain'}, |
($prob,$student->{'username'},$student->{'domain'}, |