version 1.15, 2004/09/01 21:13:04
|
version 1.16, 2004/09/02 21:02:54
|
Line 46 my @SubmitButtons = ({ name => 'PrevProb
|
Line 46 my @SubmitButtons = ({ name => 'PrevProb
|
{ name => 'SelectAnother', |
{ name => 'SelectAnother', |
text => 'Choose a different Problem' }, |
text => 'Choose a different Problem' }, |
{ name => 'Generate', |
{ name => 'Generate', |
text => 'Generate Spreadsheet'}, |
text => 'Generate Report'}, |
); |
); |
|
|
sub BuildStudentSubmissionsPage { |
sub BuildStudentSubmissionsPage { |
Line 131 sub BuildStudentSubmissionsPage {
|
Line 131 sub BuildStudentSubmissionsPage {
|
my $ProblemData = $Data{$current_problem->{'part'}. |
my $ProblemData = $Data{$current_problem->{'part'}. |
'.'. |
'.'. |
$current_problem->{'respid'}}; |
$current_problem->{'respid'}}; |
&prepare_html_output($r,$current_problem, |
if ($ENV{'form.output'} eq 'excel') { |
$ProblemData,\@Students); |
&prepare_excel_output($r,$current_problem, |
# &prepare_excel_output($r,$current_problem, |
$ProblemData,\@Students); |
# $ProblemData,\@Students); |
} else { |
|
&prepare_html_output($r,$current_problem, |
|
$ProblemData,\@Students); |
|
} |
} |
} |
$r->print('<hr />'); |
$r->print('<hr />'); |
} else { |
} else { |
Line 148 sub BuildStudentSubmissionsPage {
|
Line 151 sub BuildStudentSubmissionsPage {
|
|
|
######################################################### |
######################################################### |
######################################################### |
######################################################### |
|
|
|
my @DefaultColumns = |
|
( |
|
{name=>'username', |
|
display=>'Student'}, |
|
{name=>'domain', |
|
display=>'Domain'}, |
|
{name => 'id', |
|
display => 'Id'}, |
|
{name => 'time', |
|
display =>'Time'}, |
|
{name => 'attempt', |
|
display =>'Attempt'}, |
|
{name => 'awarddetail', |
|
display =>'Awarddetail'}, |
|
{name => 'grading', |
|
display =>'Score'}, |
|
); |
|
|
|
######################################################### |
|
######################################################### |
## |
## |
## prepare_html_output |
## prepare_html_output |
## |
## |
Line 159 sub prepare_html_output {
|
Line 183 sub prepare_html_output {
|
my ($resource,$respid,$partid) = ($problem->{'resource'}, |
my ($resource,$respid,$partid) = ($problem->{'resource'}, |
$problem->{'respid'}, |
$problem->{'respid'}, |
$problem->{'part'}); |
$problem->{'part'}); |
$r->print('<h2>'.&mt('Student Responses').'</h2>'); |
|
# |
# |
if ($ENV{'form.correctans'} eq 'true') { |
if ($ENV{'form.correctans'} eq 'true') { |
|
$r->print('<h2>'.&mt('Generating Correct Answers').'</h2>'); |
&Apache::lonstathelpers::GetStudentAnswers($r,$problem,$Students, |
&Apache::lonstathelpers::GetStudentAnswers($r,$problem,$Students, |
'Statistics', |
'Statistics', |
'stats_status'); |
'stats_status'); |
} |
} |
# |
# |
|
$r->print('<h2>'.&mt('Student Responses').'</h2>'); |
|
# |
$r->rflush(); |
$r->rflush(); |
my $response_type; |
my $response_type; |
for (my $i=0; |
for (my $i=0; |
Line 182 sub prepare_html_output {
|
Line 208 sub prepare_html_output {
|
$r->print('<h2>'.&mt('Unable to determine response type').'</h2>'); |
$r->print('<h2>'.&mt('Unable to determine response type').'</h2>'); |
} else { |
} else { |
my $count = 0; |
my $count = 0; |
my $header; |
my @Columns; |
|
if (exists($ENV{'form.concise'}) && $ENV{'form.concise'} eq 'true') { |
|
foreach (@DefaultColumns) { |
|
if ($_->{'name'} =~ /^(username|domain|id)$/){ |
|
push(@Columns,$_); |
|
} |
|
} |
|
} else { |
|
@Columns = @DefaultColumns; |
|
} |
|
my $header = '<table>'.$/.&html_headers(\@Columns); |
if ($response_type eq 'essay') { |
if ($response_type eq 'essay') { |
$header = &html_essay_header(); |
$header .= &html_essay_headers(); |
} elsif ($response_type eq 'radiobutton') { |
|
$header = &html_radiobutton_header(); |
|
} elsif ($response_type eq 'option') { |
} elsif ($response_type eq 'option') { |
$header = &html_option_header(); |
$header .= &html_option_headers(); |
} else { |
} else { |
$header = &html_generic_header(); |
$header .= &html_generic_headers(); |
} |
} |
$header = '<tr>'.$header.'</tr>'; |
$header = '<tr>'.$header.'</tr>'; |
# |
# |
$r->print($/.'<table>'.$/.$header.$/); |
$r->print($/.$header.$/); |
foreach my $student (@$Students) { |
foreach my $student (@$Students) { |
if ($count >= 50) { |
if ($count >= 50) { |
$r->print('</table>'.$/.'<table>'.$/.$header.$/); |
$r->print('</table>'.$/.$header.$/); |
$count = 0; |
$count = 0; |
} |
} |
last if ($c->aborted()); |
last if ($c->aborted()); |
Line 211 sub prepare_html_output {
|
Line 245 sub prepare_html_output {
|
next; |
next; |
} |
} |
my $data; |
my $data; |
$data->{'sname'} = $student->{'username'}.'@'. |
$data->{'username'} = $student->{'username'}; |
$student->{'domain'}; |
$data->{'domain'} = $student->{'domain'}; |
|
$data->{'id'} = $student->{'id'}; |
|
$data->{'fullname'} = $student->{'fullanem'}; |
|
$data->{'status'} = $student->{'status'}; |
$data->{'time'} = &Apache::lonlocal::locallocaltime |
$data->{'time'} = &Apache::lonlocal::locallocaltime |
($response->[&Apache::loncoursedata::RDs_timestamp()]); |
($response->[&Apache::loncoursedata::RDs_timestamp()]); |
$data->{'attempt'} = |
$data->{'attempt'} = |
$response->[&Apache::loncoursedata::RDs_tries()]; |
$response->[&Apache::loncoursedata::RDs_tries()]; |
$data->{'submission'} = |
$data->{'awarded'} = |
$response->[&Apache::loncoursedata::RDs_submission()]; |
$response->[&Apache::loncoursedata::RDs_awarded()]; |
$data->{'correct'} = $student->{'answer'}; |
$data->{'awarddetail'} = |
my $row; |
$response->[&Apache::loncoursedata::RDs_awarddetail()]; |
|
my $rowextra = 'bgcolor="#CCCCCC"'; |
|
if ($count % 2 == 1) { |
|
$rowextra = 'bgcolor="#EEEEEE"'; |
|
} |
|
my $row = '<tr '.$rowextra.'>'; |
|
foreach my $col (@Columns) { |
|
$row .= '<td valign="top">'. |
|
$data->{$col->{'name'}}.'</td>'; |
|
} |
if ($response_type eq 'essay') { |
if ($response_type eq 'essay') { |
$row = &html_essay($data); |
$row .= &html_essay |
} elsif ($response_type eq 'radiobutton') { |
($response->[&Apache::loncoursedata::RDs_submission()], |
$row = &html_radiobutton($data); |
$student->{'answer'}, |
|
scalar(@Columns),$rowextra); |
} elsif ($response_type eq 'option') { |
} elsif ($response_type eq 'option') { |
$row = &html_option($data); |
$row .= &html_option |
|
($response->[&Apache::loncoursedata::RDs_submission()], |
|
$student->{'answer'}, |
|
scalar(@Columns),$rowextra); |
} else { |
} else { |
$row = &html_generic($data); |
$row .= &html_generic |
|
($response->[&Apache::loncoursedata::RDs_submission()], |
|
$student->{'answer'}, |
|
scalar(@Columns),$rowextra); |
} |
} |
|
$row .= '</tr>'; |
$r->print($row.$/); |
$r->print($row.$/); |
$count++; |
$count++; |
} |
} |
Line 244 sub prepare_html_output {
|
Line 298 sub prepare_html_output {
|
## HTML helper routines |
## HTML helper routines |
## |
## |
##################################################### |
##################################################### |
my @FullHeaders = ( |
sub html_headers { |
{name=>'sname', |
my ($Columns) = @_; |
display=>'Student'}, |
my $Str; |
{name => 'id', |
foreach my $column (@$Columns) { |
display => 'Id'}, |
$Str .= '<th align="left">'.$column->{'display'}.'</th>'; |
{name => 'time', |
|
display =>'Time'}, |
|
{name => 'attempt', |
|
display =>'Attempt'}, |
|
{name => 'grading', |
|
display =>'Grading'}, |
|
); |
|
|
|
sub html_essay_header { |
|
my $header; |
|
if ($ENV{'form.subdata'} eq 'true') { |
|
foreach (@FullHeaders) { |
|
$header .= '<th>'.&mt($_->{'display'}).'</th>'; |
|
} |
|
} else { |
|
$header = '<th>'.&mt('Username and Submission').'</th>'; |
|
} |
} |
return $header; |
return $Str; |
} |
} |
|
|
sub html_essay { |
sub html_essay { |
my ($data)=@_; |
my ($submission,$correct,$tablewidth,$rowextra)=@_; |
# |
# |
$data->{'submission'} =~ s|\\r\\n|$/|g; |
$submission =~ s|\\r\\n|$/|g; |
$data->{'submission'} = |
$submission = &HTML::Entities::encode($submission,'<>&"'); |
&HTML::Entities::encode($data->{'submission'},'<>&"'); |
$submission =~ s|$/\s*$/|$/</p><p>$/|g; |
$data->{'submission'} =~ s|$/\s*$/|$/</p><p>$/|g; |
$submission =~ s|\\||g; |
$data->{'submission'} =~ s|\\||g; |
$submission = '<p>'.$submission.'</p>'; |
$data->{'submission'} = '<p>'.$data->{'submission'}.'</p>'; |
# |
# |
my $Str = '</tr><tr '.$rowextra.'>'. |
my $Str = '<tr>'; |
'<td colspan="'.$tablewidth.'">'.$submission.'</td>'; |
if ($ENV{'form.subdata'} eq 'true') { |
|
$Str .= |
|
'<td><b>'.$data->{'sname'}.'</b></td>'. |
|
'<td>'.$data->{'time'}.'</td>'. |
|
'<td>'.$data->{'attempt'}.'</td>'; |
|
$Str .= '</tr>'; |
|
$Str .= '<tr><td colspan="'.scalar(@FullHeaders).'">'. |
|
$data->{'submission'}.'</td>'; |
|
} else { |
|
$Str .= '<td><b>'.$data->{'sname'}.'</b>'. |
|
$data->{'submission'}.'</td>'; |
|
} |
|
if ($ENV{'form.correctans'} eq 'true') { |
if ($ENV{'form.correctans'} eq 'true') { |
$Str .= '</tr>'; |
$Str .= '</tr>'; |
if (defined($data->{'correct'}) && $data->{'correct'} !~ /^\s*$/) { |
if (defined($correct) && $correct !~ /^\s*$/) { |
$Str .= '<tr><td colspan="'.scalar(@FullHeaders).'">'. |
$Str .= '<tr '.$rowextra.'><td colspan="'.$tablewidth.'">'. |
'<b>'.&mt('Correct Answer:').'</b>'.$data->{'correct'}.'</td>'; |
'<b>'.&mt('Correct Answer:').'</b>'.$correct.'</td>'; |
} |
} |
} |
} |
$Str .= '</tr>'; |
$Str .= '</tr>'; |
Line 304 sub html_essay {
|
Line 330 sub html_essay {
|
return $Str; |
return $Str; |
} |
} |
|
|
sub html_radiobutton_header { |
sub html_essay_headers { |
my $header; |
return ''; |
if ($ENV{'form.subdata'} eq 'true') { |
} |
foreach (@FullHeaders) { |
|
$header .= '<th>'.&mt($_->{'display'}).'</th>'; |
sub html_generic_headers { |
} |
my $header ='<th>'.&mt('Submission').'</th>'; |
} else { |
|
$header = |
|
'<th>'.&mt('Username').'</th>'; |
|
} |
|
$header .='<th>'.&mt('Submission').'</th>'; |
|
if ($ENV{'form.correctans'} eq 'true') { |
if ($ENV{'form.correctans'} eq 'true') { |
$header .= '<th>'.&mt('Correct').'</th>'; |
$header .= '<th>'.&mt('Correct').'</th>'; |
} |
} |
Line 322 sub html_radiobutton_header {
|
Line 343 sub html_radiobutton_header {
|
} |
} |
|
|
sub html_radiobutton { |
sub html_radiobutton { |
my ($data)=@_; |
my ($submission,$correct,$tablewidth,$rowclass)=@_; |
# |
$submission =~ s/=([^=])$//; |
$data->{'submission'} =~ s/=([^=])$//; |
return &html_generic_results($submission,$correct,$tablewidth,$rowclass); |
# |
|
my $Str = '<tr>'; |
|
if ($ENV{'form.subdata'} eq 'true') { |
|
$Str .= |
|
'<td>'.'<b>'.$data->{'sname'}.'</b></td>'. |
|
'<td>'.$data->{'time'}.'</td>'. |
|
'<td>'.$data->{'attempt'}.'</td>'; |
|
$Str .= '<td>'.$data->{'submission'}.'</td>'; |
|
if ($ENV{'form.correctans'} eq 'true') { |
|
$Str .= '<td>'.$data->{'correct'}.'</td>'; |
|
} |
|
} else { |
|
$Str .= '<td><b>'.$data->{'sname'}.'</b></td>'; |
|
$Str .= '<td>'.$data->{'submission'}.'</td>'; |
|
if ($ENV{'form.correctans'} eq 'true') { |
|
$Str .= '<td>'.$data->{'correct'}.'</td>'; |
|
} |
|
} |
|
$Str .= '</tr>'; |
|
# |
|
return $Str; |
|
} |
|
|
|
sub html_generic_header { |
|
my $header; |
|
if ($ENV{'form.subdata'} eq 'true') { |
|
foreach (@FullHeaders) { |
|
$header .= '<th>'.&mt($_->{'display'}).'</th>'; |
|
} |
|
} else { |
|
$header = |
|
'<th>'.&mt('Username').'</th>'; |
|
} |
|
$header .= '<th>'.&mt('Submission').'</th>'; |
|
if ($ENV{'form.correctans'} eq 'true') { |
|
$header .= '<th>'.&mt('Correct').'</th>'; |
|
} |
|
return $header; |
|
} |
} |
|
|
sub html_generic { |
sub html_generic { |
my ($data)=@_; |
my ($submission,$correct,$tablewidth,$rowclass)=@_; |
$data->{'submission'} = &Apache::lonnet::unescape($data->{'submission'}); |
my $Str .= '<td>'.$submission.'</td>'; |
my $Str = '<tr>'; |
|
if ($ENV{'form.subdata'} eq 'true') { |
|
$Str .= |
|
'<td><b>'.$data->{'sname'}.'</b></td>'. |
|
'<td>'.$data->{'time'}.'</td>'. |
|
'<td>'.$data->{'attempt'}.'</td>'; |
|
} else { |
|
$Str .= '<td><b>'.$data->{'sname'}.'</b></td>'; |
|
} |
|
$Str .= '<td>'.$data->{'submission'}.'</td>'; |
|
if ($ENV{'form.correctans'} eq 'true') { |
if ($ENV{'form.correctans'} eq 'true') { |
$Str .= '<td>'.$data->{'correct'}.'</td>'; |
$Str .= '<td>'.$correct.'</td>'; |
} |
} |
$Str .= '</tr>'; |
$Str .= '</tr>'; |
return $Str; |
return $Str; |
} |
} |
|
|
sub html_option_header { |
sub html_option_headers { |
my $header; |
return &html_generic_headers(); |
if ($ENV{'form.subdata'} eq 'true') { |
|
foreach (@FullHeaders) { |
|
$header .= '<th>'.&mt($_->{'display'}).'</th>'; |
|
} |
|
} else { |
|
$header = |
|
'<th>'.&mt('Username').'</th>'; |
|
} |
|
$header .= '<th>'.&mt('Submission').'</th>'; |
|
if ($ENV{'form.correctans'} eq 'true') { |
|
$header .= '<th>'.&mt('Correct').'</th>'; |
|
} |
|
return $header; |
|
} |
} |
|
|
sub html_option { |
sub html_option { |
my ($data)=@_; |
my ($submission,$correct,$tablewidth,$rowclass)=@_; |
$data->{'submission'} = '<ul class="studentans">'. |
$submission = |
'<li>'.join('</li><li>', |
'<ul class="sub_studentans">'. |
map { |
|
&Apache::lonnet::unescape($_) ; |
|
} sort split('&',$data->{'submission'})). |
|
'</li><ul>'; |
|
$data->{'correct'} = '<ul class="correctans">'. |
|
'<li>'.join('</li><li>', |
'<li>'.join('</li><li>', |
map { |
map { |
&Apache::lonnet::unescape($_) ; |
&Apache::lonnet::unescape($_) ; |
} sort split('&',$data->{'correct'})).'</li></ul>'; |
} sort split('&',$submission) |
my $Str = '<tr>'; |
). |
if ($ENV{'form.subdata'} eq 'true') { |
'</li><ul>'; |
$Str .= |
if (defined($correct) && $correct !~ /^\s*$/) { |
'<td><b>'.$data->{'sname'}.'</b></td>'. |
$correct = '<ul class="sub_correctans">'. |
'<td>'.$data->{'time'}.'</td>'. |
'<li>'.join('</li><li>', |
'<td>'.$data->{'attempt'}.'</td>'; |
map { |
} else { |
&Apache::lonnet::unescape($_) ; |
$Str .= '<td><b>'.$data->{'sname'}.'</b></td>'; |
} sort split('&',$correct) |
} |
). |
$Str .= '<td>'.$data->{'submission'}.'</td>'; |
'</li></ul>'; |
if ($ENV{'form.correctans'} eq 'true') { |
|
$Str .= '<td>'.$data->{'correct'}.'</td>'; |
|
} |
|
$Str .= '</tr>'; |
|
return $Str; |
|
} |
|
|
|
|
|
=pod |
|
|
|
my @Columns; |
|
push(@Columns,'username'); |
|
push(@Columns,'domain'); |
|
push(@Columns,'attempt'); |
|
push(@Columns,'time'); |
|
push(@Columns,'submission'); |
|
if ($ENV{'form.correctans'} eq 'true') { push(@Columns,'correct'); } |
|
push(@Columns,'grading'); |
|
push(@Columns,'awarded'); |
|
my $awarded_col = $#Columns; |
|
push(@Columns,'weight'); |
|
my $weight_col = $#Columns; |
|
push(@Columns,'score'); |
|
# |
|
# Create excel worksheet |
|
my $filename = '/prtspool/'. |
|
$ENV{'user.name'}.'_'.$ENV{'user.domain'}.'_'. |
|
time.'_'.rand(1000000000).'.xls'; |
|
my $workbook = Spreadsheet::WriteExcel->new('/home/httpd'.$filename); |
|
if (! defined($workbook)) { |
|
$r->log_error("Error creating excel spreadsheet $filename: $!"); |
|
$r->print('<p>'.&mt("Unable to create new Excel file. ". |
|
"This error has been logged. ". |
|
"Please alert your LON-CAPA administrator"). |
|
'</p>'); |
|
return undef; |
|
} |
|
# |
|
$workbook->set_tempdir('/home/httpd/perl/tmp'); |
|
# |
|
my $format = &Apache::loncommon::define_excel_formats($workbook); |
|
my $worksheet = $workbook->addworksheet('Student Submission Data'); |
|
# |
|
# Make sure we get new weight data instead of data on a 10 minute delay |
|
&Apache::lonnet::clear_EXT_cache_status(); |
|
# |
|
# Put on the standard headers and whatnot |
|
my $rows_output=0; |
|
$worksheet->write($rows_output++,0,$resource->{'title'},$format->{'h1'}); |
|
$worksheet->write($rows_output++,0,$resource->{'src'},$format->{'h3'}); |
|
$rows_output++; |
|
$worksheet->write_row($rows_output++,0,\@Columns,$format->{'bold'}); |
|
# |
|
# Populate the worksheet with the student data |
|
foreach my $student (@$Students) { |
|
last if ($c->aborted()); |
|
my $results = &Apache::loncoursedata::get_response_data_by_student |
|
($student,$resource->{'symb'},$respid); |
|
my %row; |
|
$row{'username'} = $student->{'username'}; |
|
$row{'domain'} = $student->{'domain'}; |
|
$row{'correct'} = $student->{'answer'}; |
|
$row{'weight'} = &Apache::lonnet::EXT |
|
('resource.'.$partid.'.weight',$resource->{'symb'}, |
|
undef,undef,undef); |
|
if (! defined($results) || ref($results) ne 'ARRAY') { |
|
$row{'score'} = '='. |
|
&Spreadsheet::WriteExcel::Utility::xl_rowcol_to_cell |
|
($rows_output,$awarded_col) |
|
.'*'. |
|
&Spreadsheet::WriteExcel::Utility::xl_rowcol_to_cell |
|
($rows_output,$weight_col); |
|
my $cols_output = 0; |
|
foreach my $col (@Columns) { |
|
if (! exists($row{$col})) { |
|
$cols_output++; |
|
next; |
|
} |
|
$worksheet->write($rows_output,$cols_output++,$row{$col}); |
|
} |
|
$rows_output++; |
|
} else { |
|
for (my $i=0;$i<scalar(@$results);$i++) { |
|
my $response = $results->[$i]; |
|
if ($ENV{'form.last_sub_only'} eq 'true' && |
|
$i < (scalar(@$results)-1)) { |
|
next; |
|
} |
|
delete($row{'time'}); |
|
delete($row{'attempt'}); |
|
delete($row{'submission'}); |
|
delete($row{'awarded'}); |
|
delete($row{'grading'}); |
|
delete($row{'score'}); |
|
my %row_format; |
|
# |
|
# Time is handled differently |
|
$row{'time'} = &Apache::lonstathelpers::calc_serial |
|
($response->[&Apache::loncoursedata::RDs_timestamp()]); |
|
$row_format{'time'}=$format->{'date'}; |
|
# |
|
$row{'attempt'} = $response->[ |
|
&Apache::loncoursedata::RDs_tries()]; |
|
$row{'submission'} = $response->[ |
|
&Apache::loncoursedata::RDs_submission()]; |
|
if ($row{'submission'} =~ m/^=/) { |
|
# This will be interpreted as a formula. That is bad! |
|
$row{'submission'} = " ".$row{'submission'}; |
|
} |
|
$row{'grading'} = $response->[ |
|
&Apache::loncoursedata::RDs_awarddetail()]; |
|
$row{'awarded'} = $response->[ |
|
&Apache::loncoursedata::RDs_awarded()]; |
|
$row{'score'} = '='. |
|
&Spreadsheet::WriteExcel::Utility::xl_rowcol_to_cell |
|
($rows_output,$awarded_col) |
|
.'*'. |
|
&Spreadsheet::WriteExcel::Utility::xl_rowcol_to_cell |
|
($rows_output,$weight_col); |
|
my $cols_output = 0; |
|
foreach my $col (@Columns) { |
|
$worksheet->write($rows_output,$cols_output++,$row{$col}, |
|
$row_format{$col}); |
|
} |
|
$rows_output++; |
|
} |
|
} # End of else clause on if (! defined($results) .... |
|
} |
} |
# |
# |
# Close the excel file |
return &html_generic($submission,$correct,$tablewidth,$rowclass); |
$workbook->close(); |
|
# |
|
# Write a link to allow them to download it |
|
$r->print('<p><a href="'.$filename.'">'. |
|
&mt('Your Excel spreadsheet.'). |
|
'</a></p>'."\n"); |
|
$r->print('<script>'. |
|
'window.document.Statistics.stats_status.value="'. |
|
'Done compiling spreadsheet. See link below to download.'. |
|
'";</script>'); |
|
$r->rflush(); |
|
return; |
|
|
|
} |
} |
|
|
=cut |
|
|
|
######################################################### |
######################################################### |
######################################################### |
######################################################### |
## |
## |
Line 596 sub prepare_excel_output {
|
Line 409 sub prepare_excel_output {
|
&Apache::lonstathelpers::GetStudentAnswers($r,$problem,$Students, |
&Apache::lonstathelpers::GetStudentAnswers($r,$problem,$Students, |
'Statistics', |
'Statistics', |
'stats_status'); |
'stats_status'); |
|
$r->print('<script>'. |
|
'window.document.Statistics.stats_status.value="'. |
|
'Done computing student answers. Compiling spreadsheet.'. |
|
'";</script>'); |
} |
} |
# |
# |
$r->print('<script>'. |
|
'window.document.Statistics.stats_status.value="'. |
|
'Done computing student answers. Compiling spreadsheet.'. |
|
'";</script>'); |
|
$r->rflush(); |
$r->rflush(); |
my @Columns; |
my @Columns; |
push(@Columns,'username'); |
push(@Columns,'username'); |
Line 647 sub prepare_excel_output {
|
Line 460 sub prepare_excel_output {
|
$worksheet->write_row($rows_output++,0,\@Columns,$format->{'bold'}); |
$worksheet->write_row($rows_output++,0,\@Columns,$format->{'bold'}); |
# |
# |
# Populate the worksheet with the student data |
# Populate the worksheet with the student data |
|
my %prog_state=&Apache::lonhtmlcommon::Create_PrgWin |
|
($r,'Excel File Compilation Status', |
|
'Excel File Compilation Progress', |
|
scalar(@$Students),'inline',undef,'Statistics','stats_status'); |
foreach my $student (@$Students) { |
foreach my $student (@$Students) { |
last if ($c->aborted()); |
last if ($c->aborted()); |
|
|
my $results = &Apache::loncoursedata::get_response_data_by_student |
my $results = &Apache::loncoursedata::get_response_data_by_student |
($student,$resource->{'symb'},$respid); |
($student,$resource->{'symb'},$respid); |
my %row; |
my %row; |
Line 720 sub prepare_excel_output {
|
Line 538 sub prepare_excel_output {
|
$rows_output++; |
$rows_output++; |
} |
} |
} # End of else clause on if (! defined($results) .... |
} # End of else clause on if (! defined($results) .... |
|
&Apache::lonhtmlcommon::Increment_PrgWin($r,\%prog_state, |
|
'last student'); |
} |
} |
|
&Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state); |
# |
# |
# Close the excel file |
# Close the excel file |
$workbook->close(); |
$workbook->close(); |
Line 746 sub prepare_excel_output {
|
Line 567 sub prepare_excel_output {
|
######################################################### |
######################################################### |
sub CreateInterface { |
sub CreateInterface { |
## |
## |
|
## Output Selection |
|
my $OutputSelector = $/.'<select name="output">'.$/; |
|
foreach ('HTML','Excel') { |
|
$OutputSelector .= ' <option value="'.lc($_).'"'; |
|
if ($ENV{'form.output'} eq lc($_)) { |
|
$OutputSelector .= ' selected '; |
|
} |
|
$OutputSelector .='>'.&mt($_).'</option>'.$/; |
|
} |
|
$OutputSelector .= '</select>'.$/; |
|
## |
## Environment variable initialization |
## Environment variable initialization |
my $Str = ''; |
my $Str = ''; |
$Str .= &Apache::lonhtmlcommon::breadcrumbs |
$Str .= &Apache::lonhtmlcommon::breadcrumbs |
Line 753 sub CreateInterface {
|
Line 585 sub CreateInterface {
|
$Str .= '<p>'; |
$Str .= '<p>'; |
$Str .= '<table cellspacing="5">'."\n"; |
$Str .= '<table cellspacing="5">'."\n"; |
$Str .= '<tr>'; |
$Str .= '<tr>'; |
$Str .= '<td align="center"><b>'.&mt('Sections').'</b></td>'; |
$Str .= '<th>'.&mt('Sections').'</th>'; |
$Str .= '<td align="center"><b>'.&mt('Enrollment Status').'</b></td>'; |
$Str .= '<th>'.&mt('Enrollment Status').'</th>'; |
$Str .= '<td> </td>'; |
$Str .= '<th>'.&mt('Output Options').'</th>'; |
$Str .= '</tr>'."\n"; |
$Str .= '</tr>'."\n"; |
# |
# |
$Str .= '<tr><td align="center">'."\n"; |
$Str .= '<tr><td align="center">'."\n"; |
Line 788 sub CreateInterface {
|
Line 620 sub CreateInterface {
|
} |
} |
$last_sub_checkbox.= 'value="true" />'; |
$last_sub_checkbox.= 'value="true" />'; |
# |
# |
# extra submission data checkbox |
# Concise view checkbox |
my $subdata_checkbox = '<input type="checkbox" name="subdata" '; |
my $concise_view_checkbox = '<input type="checkbox" name="concise" '; |
if (exists($ENV{'form.subdata'}) && |
if (exists($ENV{'form.concise'}) && $ENV{'form.concise'} eq 'true') { |
$ENV{'form.subdata'} eq 'true') { |
$concise_view_checkbox .= 'checked '; |
$subdata_checkbox .= 'checked '; |
|
} |
} |
$subdata_checkbox.= 'value="true" />'; |
$concise_view_checkbox .= 'value="true" />'; |
# |
# |
$Str .= '<td align="right" halign="top">'.'<label><b>'. |
$Str .= '<td align="right" halign="top">'. |
|
'<b>'.&mt('Output Format: [_1]',$OutputSelector).'</b><br />'.$/. |
|
'<label><b>'. |
&mt('show problem [_1]',$prob_checkbox).'</b></label><br />'. |
&mt('show problem [_1]',$prob_checkbox).'</b></label><br />'. |
'<label><b>'. |
'<label><b>'. |
&mt('compute correct answers [_1]',$ans_checkbox).'</b></label><br />'. |
&mt('compute correct answers [_1]',$ans_checkbox).'</b></label><br />'. |
'<label><b>'. |
'<label><b>'. |
&mt('final answer only [_1]',$last_sub_checkbox).'</b></label><br />'. |
&mt('final answer only [_1]',$last_sub_checkbox).'</b></label><br />'. |
'<label><b>'.&mt('show extra submission data [_1]',$subdata_checkbox). |
'<label><b>'. |
'</b></label><br />'. |
&mt('concise view [_1]',$concise_view_checkbox).'</b></label><br />'. |
'</td>'; |
'</td>'; |
# |
# |
$Str .= '</tr>'."\n"; |
$Str .= '</tr>'."\n"; |