version 1.17, 2004/09/08 14:58:33
|
version 1.19, 2004/09/16 21:54:22
|
Line 38 use HTML::Entities();
|
Line 38 use HTML::Entities();
|
use Time::Local(); |
use Time::Local(); |
use Spreadsheet::WriteExcel(); |
use Spreadsheet::WriteExcel(); |
|
|
my @SubmitButtons = ({ name => 'PrevProblem', |
my @SubmitButtons = ({ name => 'SelectAnother', |
text => 'Previous Problem' }, |
|
{ name => 'NextProblem', |
|
text => 'Next Problem' }, |
|
{ name => 'break'}, |
|
{ name => 'SelectAnother', |
|
text => 'Choose a different Problem' }, |
text => 'Choose a different Problem' }, |
{ name => 'Generate', |
{ name => 'Generate', |
text => 'Generate Report'}, |
text => 'Generate Report'}, |
Line 72 sub BuildStudentSubmissionsPage {
|
Line 67 sub BuildStudentSubmissionsPage {
|
} |
} |
# |
# |
my @CacheButtonHTML = |
my @CacheButtonHTML = |
&Apache::lonstathelpers::manage_caches($r,'Statistics','stats_status'); |
&Apache::lonstathelpers::manage_caches($r,'Statistics','stats_status', |
|
'<h3>'.&mt('Loading student data').'</h3>'); |
$r->rflush(); |
$r->rflush(); |
# |
# |
if (exists($ENV{'form.problemchoice'}) && |
if (exists($ENV{'form.problemchoice'}) && |
Line 90 sub BuildStudentSubmissionsPage {
|
Line 86 sub BuildStudentSubmissionsPage {
|
$r->print($html.(' 'x5)); |
$r->print($html.(' 'x5)); |
} |
} |
# |
# |
$r->print('<hr />'); |
$r->print('<hr />'.$/); |
$r->rflush(); |
$r->rflush(); |
# |
# |
# Determine which problem we are to analyze |
# Determine which problems we are to analyze |
my $current_problem = &Apache::lonstathelpers::get_target_from_id |
my @Symbs = |
($ENV{'form.problemchoice'}); |
&Apache::lonstathelpers::get_selected_symbs('problemchoice'); |
# |
foreach my $selected (@Symbs) { |
my ($prev,$curr,$next) = |
$r->print('<input type="hidden" name="problemchoice" value="'. |
&Apache::lonstathelpers::get_prev_curr_next($current_problem, |
$selected.'" />'.$/); |
'.', |
|
'response', |
|
); |
|
if (exists($ENV{'form.PrevProblem'}) && defined($prev)) { |
|
$current_problem = $prev; |
|
} elsif (exists($ENV{'form.NextProblem'}) && defined($next)) { |
|
$current_problem = $next; |
|
} else { |
|
$current_problem = $curr; |
|
} |
} |
# |
# |
# Store the current problem choice and send it out in the form |
# Get resource objects |
$ENV{'form.problemchoice'} = |
my $navmap = Apache::lonnavmaps::navmap->new(); |
&Apache::lonstathelpers::make_target_id($current_problem); |
if (!defined($navmap)) { |
$r->print('<input type="hidden" name="problemchoice" value="'. |
$r->print('<h1>'.&mt("Internal error").'</h1>'); |
$ENV{'form.problemchoice'}.'" />'); |
return; |
|
} |
|
my %already_seen; |
|
my @Problems; |
|
foreach my $symb (@Symbs) { |
|
my $resource = $navmap->getBySymb($symb); |
|
push(@Problems,$resource); |
|
} |
# |
# |
if (! defined($current_problem->{'resource'})) { |
if (! scalar(@Problems) || ! defined($Problems[0])) { |
$r->print('resource is undefined'); |
$r->print('resource is undefined'); |
} else { |
} else { |
my $resource = $current_problem->{'resource'}; |
if (scalar(@Problems) == 1) { |
$r->print('<h1>'.$resource->{'title'}.'</h1>'); |
my $resource = $Problems[0]; |
$r->print('<h3>'.$resource->{'src'}.'</h3>'); |
$r->print('<h1>'.$resource->title.'</h1>'); |
if ($ENV{'form.renderprob'} eq 'true') { |
$r->print('<h3>'.$resource->src.'</h3>'); |
$r->print(&Apache::lonstathelpers::render_resource($resource)); |
if ($ENV{'form.renderprob'} eq 'true') { |
} |
$r->print( |
$r->rflush(); |
&Apache::lonstathelpers::render_resource({src => $resource->src}) |
my %Data = &Apache::lonstathelpers::get_problem_data |
); |
($resource->{'src'}); |
$r->rflush(); |
my $ProblemData = $Data{$current_problem->{'part'}. |
} |
'.'. |
|
$current_problem->{'respid'}}; |
|
if ($ENV{'form.output'} eq 'excel') { |
|
&prepare_excel_output($r,$current_problem, |
|
$ProblemData,\@Students); |
|
} elsif ($ENV{'form.output'} eq 'csv') { |
|
&prepare_csv_output($r,$current_problem, |
|
$ProblemData,\@Students); |
|
} else { |
|
&prepare_html_output($r,$current_problem, |
|
$ProblemData,\@Students); |
|
} |
} |
|
&new_excel_output($r,\@Problems,\@Students); |
} |
} |
$r->print('<hr />'); |
$r->print('<hr />'); |
} else { |
} else { |
$r->print('<input type="submit" name="Generate" value="'. |
$r->print('<input type="submit" name="Generate" value="'. |
&mt('Prepare Report').'" />'); |
&mt('Prepare Report').'" />'); |
$r->print(' 'x5); |
$r->print(' 'x5); |
$r->print('<h3>'.&mt('Please select a problem to analyze').'</h3>'); |
$r->print('<p>'. |
$r->print(&Apache::lonstathelpers::ProblemSelector('.')); |
&mt('Computing correct answers greatly increasese the amount of time required to prepare a report.'). |
|
'</p>'); |
|
$r->print('<p>'. |
|
&mt('please select problems and use the <b>Prepare Report</b> button to continue.'). |
|
'</p>'); |
|
$r->print(&Apache::lonstathelpers::MultipleProblemSelector |
|
(undef,'problemchoice','Statistics')); |
|
} |
|
} |
|
|
|
######################################################### |
|
######################################################### |
|
|
|
sub new_excel_output { |
|
my ($r,$Problems,$Students) = @_; |
|
my $c = $r->connection(); |
|
# |
|
# |
|
# Determine the number of columns in the spreadsheet |
|
my $columncount = 3; # username, domain, id |
|
my $multiplier = 1; |
|
$multiplier ++ if ($ENV{'form.correctans'} eq 'true'); |
|
foreach my $prob (@$Problems) { |
|
$columncount += ($multiplier * $prob->countResponses); |
|
last if ($columncount > 255); |
|
} |
|
if ($columncount > 255) { |
|
$r->print('<h1>'.&mt('Unable to complete request').'</h1>'.$/. |
|
'<p>'.&mt('LON-CAPA is unable to produce your Excel spreadsheet because your selections will result in more than 255 columns. Excel allows only 255 columns in a spreadsheet.').'</p>'.$/. |
|
'<p>'.&mt('Consider selecting fewer problems to generate reports on, or reducing the number of items per problem. Or use HTML or CSV output.').'</p>'.$/); |
|
$r->rflush(); |
|
return; |
|
} |
|
# |
|
# Print out a message telling them what we are doing |
|
if (scalar(@$Problems) > 1) { |
|
$r->print('<h2>'. |
|
&mt('Preparing Excel spreadsheet of student responses to [_1] problems', |
|
scalar(@$Problems)). |
|
'</h2>'); |
|
} else { |
|
$r->print('<h2>'. |
|
&mt('Preparing Excel spreadsheet of student responses'). |
|
'</h2>'); |
|
} |
|
$r->rflush(); |
|
# |
|
# Create the excel spreadsheet |
|
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'); |
|
# |
|
# Add headers to the worksheet |
|
my $rows_output = 0; |
|
$worksheet->write($rows_output++,0, |
|
$ENV{'course.'.$ENV{'request.course.id'}.'.description'}, |
|
$format->{'h1'}); |
|
$rows_output++; |
|
my $cols_output = 0; |
|
my $title_row = $rows_output++; |
|
my $partid_row = $rows_output++; |
|
my $respid_row = $rows_output++; |
|
my $header_row = $rows_output++; |
|
$worksheet->write($title_row ,0,'Problem Title',$format->{'bold'}); |
|
$worksheet->write($partid_row,0,'Part ID',$format->{'bold'}); |
|
$worksheet->write($respid_row,0,'Response ID',$format->{'bold'}); |
|
# Student headers |
|
my @StudentColumns = ('username','domain','id'); |
|
foreach (@StudentColumns) { |
|
$worksheet->write($header_row,$cols_output++,ucfirst($_), |
|
$format->{'bold'}); |
|
} |
|
# Problem headers |
|
foreach my $prob (@$Problems) { |
|
my $title = &get_title($prob->title,$prob->src); |
|
$worksheet->write($title_row,$cols_output, |
|
$title,$format->{'h3'}); |
|
foreach my $partid (@{$prob->parts}) { |
|
$worksheet->write($partid_row,$cols_output,$partid); |
|
my $responses = [$prob->responseIds($partid)]; |
|
my $resptypes = [$prob->responseType($partid)]; |
|
for (my $i=0;$i<scalar(@$responses);$i++) { |
|
$worksheet->write($respid_row,$cols_output, |
|
$resptypes->[$i].', '.$responses->[$i]); |
|
$worksheet->write($header_row,$cols_output,'Submission'); |
|
$cols_output++; |
|
if ($ENV{'form.correctans'} eq 'true') { |
|
$worksheet->write($header_row,$cols_output,'Correct'); |
|
$cols_output++; |
|
} |
|
} |
|
} |
|
} |
|
# |
|
# 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) { |
|
last if ($c->aborted()); |
|
$cols_output = 0; |
|
foreach my $field (@StudentColumns) { |
|
$worksheet->write($rows_output,$cols_output++, |
|
$student->{$field}); |
|
} |
|
foreach my $prob (@$Problems) { |
|
foreach my $partid (@{$prob->parts}) { |
|
my @Response = $prob->responseIds($partid); |
|
my @ResponseType = $prob->responseType($partid); |
|
for (my $i=0;$i<=$#Response;$i++) { |
|
my $respid = $Response[$i]; |
|
my $resptype = $ResponseType[$i]; |
|
my $results = |
|
&Apache::loncoursedata::get_response_data_by_student |
|
($student,$prob->symb(),$respid); |
|
my $final_response = $results->[-1]; |
|
my $submission = |
|
$final_response->[ |
|
&Apache::loncoursedata::RDs_submission() |
|
]; |
|
$submission=&excel_format_response($submission,$resptype); |
|
$worksheet->write($rows_output,$cols_output++, |
|
$submission); |
|
if ($ENV{'form.correctans'} eq 'true') { |
|
my $correct = |
|
&Apache::lonstathelpers::analyze_problem_as_student |
|
($prob,$student->{'username'},$student->{'domain'}, |
|
$partid,$respid); |
|
$correct =&excel_format_response($correct,$resptype); |
|
$worksheet->write($rows_output,$cols_output++, |
|
$correct); |
|
} |
|
} |
|
} |
|
} |
|
$rows_output++; |
|
&Apache::lonhtmlcommon::Increment_PrgWin($r,\%prog_state, |
|
'last student'); |
|
} |
|
&Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state); |
|
# |
|
# Close the excel file |
|
$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; |
|
} |
|
|
|
sub get_title { |
|
my ($title,$src) = @_; |
|
if ($title eq '') { |
|
($title) = ($src =~ m|/([^/]+)$|); |
|
} else { |
|
$title =~ s/\:/:/g; |
} |
} |
|
return $title; |
} |
} |
|
|
|
sub excel_format_response { |
|
my ($answer,$responsetype) = @_; |
|
if ($responsetype eq 'radiobutton') { |
|
$answer =~ s/=([^=])$//; |
|
} elsif ($responsetype =~ /^(option|match)$/) { |
|
$answer = join("\n", |
|
map { |
|
&Apache::lonnet::unescape($_) ; |
|
} sort split('&',$answer) |
|
); |
|
} |
|
if ($answer =~ m/^=/) { |
|
$answer = ' '.$answer; |
|
} |
|
return $answer; |
|
} |
|
|
|
## |
|
## Currently not used |
|
sub get_problem_data { |
|
my ($r,$Problems) = @_; |
|
# |
|
# Analyze |
|
my %Data; |
|
if (scalar(@$Problems) > 5) { |
|
# progress window |
|
my %prog_state=&Apache::lonhtmlcommon::Create_PrgWin |
|
($r,'Problem Analysis Status', |
|
'Problem Analysis Progress', |
|
scalar(@$Problems), |
|
'inline',undef,'Statistics','stats_status'); |
|
foreach my $problem (@$Problems) { |
|
$Data{$problem->symb} = |
|
{&Apache::lonstathelpers::get_problem_data |
|
($problem->src)}; |
|
&Apache::lonhtmlcommon::Increment_PrgWin($r,\%prog_state, |
|
'last problem'); |
|
} |
|
&Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state); |
|
} else { |
|
foreach my $problem (@$Problems) { |
|
$Data{$problem->symb} = |
|
{&Apache::lonstathelpers::get_problem_data |
|
($problem->src)}; |
|
} |
|
} |
|
return \%Data; |
|
} |
|
|
|
|
|
=pod |
|
|
######################################################### |
######################################################### |
######################################################### |
######################################################### |
|
|
Line 163 my @DefaultColumns =
|
Line 376 my @DefaultColumns =
|
display=>'Domain'}, |
display=>'Domain'}, |
{name => 'id', |
{name => 'id', |
display => 'Id'}, |
display => 'Id'}, |
|
# FIXME: Probably need to add score |
|
); |
|
|
|
my @PartColumns = |
|
( |
{name => 'time', |
{name => 'time', |
display =>'Time'}, |
display =>'Time'}, |
{name => 'attempt', |
{name => 'attempt', |
display =>'Attempt'}, |
display =>'Attempt'}, |
{name => 'awarddetail', |
|
display =>'Awarddetail'}, |
|
{name => 'awarded', |
{name => 'awarded', |
display =>'Award'}, |
display =>'Award'}, |
# FIXME: Probably need to add score |
{name => 'weight', |
); |
display =>'Part Weight'}, |
|
{name => 'score', |
|
display =>'Score'}, |
|
); |
|
|
|
my @ResponseColumns = |
|
( |
|
{name => 'submission', |
|
display =>'Submission'}, |
|
{name => 'answer', |
|
display =>'Correct Answer'}, |
|
{name => 'awarddetail', |
|
display =>'Awarddetail'}, |
|
); |
|
|
sub get_response_type { |
sub get_response_type { |
my ($resource,$partid,$respid) = @_; |
my ($resource,$partid,$respid) = @_; |
Line 198 sub get_response_type {
|
Line 427 sub get_response_type {
|
######################################################### |
######################################################### |
######################################################### |
######################################################### |
sub prepare_html_output { |
sub prepare_html_output { |
my ($r,$problem,$ProblemData,$Students) = @_; |
my ($r,$Problems,$Students) = @_; |
|
my $problem; |
my $c = $r->connection(); |
my $c = $r->connection(); |
my ($resource,$respid,$partid) = ($problem->{'resource'}, |
my ($resource,$respid,$partid) = ($problem->{'resource'}, |
$problem->{'respid'}, |
$problem->{'respid'}, |
Line 270 sub prepare_html_output {
|
Line 500 sub prepare_html_output {
|
$response->[&Apache::loncoursedata::RDs_awarded()]; |
$response->[&Apache::loncoursedata::RDs_awarded()]; |
$data->{'awarddetail'} = |
$data->{'awarddetail'} = |
$response->[&Apache::loncoursedata::RDs_awarddetail()]; |
$response->[&Apache::loncoursedata::RDs_awarddetail()]; |
|
$data->{'weight'} = &Apache::lonnet::EXT |
|
('resource.'.$partid.'.weight',$resource->{'symb'}, |
|
undef,undef,undef); |
|
$data->{'score'} = $data->{'weight'} * $data->{'awarded'}; |
my $rowextra = 'bgcolor="#CCCCCC"'; |
my $rowextra = 'bgcolor="#CCCCCC"'; |
if ($count % 2 == 1) { |
if ($count % 2 == 1) { |
$rowextra = 'bgcolor="#EEEEEE"'; |
$rowextra = 'bgcolor="#EEEEEE"'; |
Line 404 sub html_option_results {
|
Line 638 sub html_option_results {
|
######################################################### |
######################################################### |
######################################################### |
######################################################### |
sub prepare_csv_output { |
sub prepare_csv_output { |
my ($r,$problem,$ProblemData,$Students) = @_; |
my ($r,$Problems,$Students) = @_; |
|
my $problem; |
# |
# |
my $c = $r->connection(); |
my $c = $r->connection(); |
my ($resource,$respid,$partid) = ($problem->{'resource'}, |
my ($resource,$respid,$partid) = ($problem->{'resource'}, |
Line 488 sub prepare_csv_output {
|
Line 723 sub prepare_csv_output {
|
$response->[&Apache::loncoursedata::RDs_awarded()]; |
$response->[&Apache::loncoursedata::RDs_awarded()]; |
$data->{'awarddetail'} = |
$data->{'awarddetail'} = |
$response->[&Apache::loncoursedata::RDs_awarddetail()]; |
$response->[&Apache::loncoursedata::RDs_awarddetail()]; |
|
$data->{'weight'} = &Apache::lonnet::EXT |
|
('resource.'.$partid.'.weight',$resource->{'symb'}, |
|
undef,undef,undef); |
|
$data->{'score'} = $data->{'weight'} * $data->{'awarded'}; |
my $rowextra = ''; |
my $rowextra = ''; |
my $row; |
my $row; |
foreach my $col (@Columns) { |
foreach my $col (@Columns) { |
Line 603 sub csv_generic_results {
|
Line 842 sub csv_generic_results {
|
######################################################### |
######################################################### |
######################################################### |
######################################################### |
sub prepare_excel_output { |
sub prepare_excel_output { |
my ($r,$problem,$ProblemData,$Students) = @_; |
my ($r,$Problems,$Students) = @_; |
my $c = $r->connection(); |
my $c = $r->connection(); |
my ($resource,$respid,$partid) = ($problem->{'resource'}, |
# |
$problem->{'respid'}, |
|
$problem->{'part'}); |
|
$r->print('<h2>'. |
$r->print('<h2>'. |
&mt('Preparing Excel spreadsheet of student responses'). |
&mt('Preparing Excel spreadsheet of student responses'). |
'</h2>'. |
'</h2>'); |
'<p>'. |
|
&mt('See the status bar above for student answer computation progress'). |
|
'</p>'); |
|
# |
|
if ($ENV{'form.correctans'} eq 'true') { |
if ($ENV{'form.correctans'} eq 'true') { |
&Apache::lonstathelpers::GetStudentAnswers($r,$problem,$Students, |
$r->print('<p>'. |
'Statistics', |
&mt('See the status bar above for student answer computation progress'). |
'stats_status'); |
'</p>'); |
|
foreach my $problem (@$Problems) { |
|
my ($resource,$respid,$partid) = ($problem->{'resource'}, |
|
$problem->{'respid'}, |
|
$problem->{'part'}); |
|
# |
|
&Apache::lonstathelpers::GetStudentAnswers($r,$problem,$Students, |
|
'Statistics', |
|
'stats_status'); |
|
} |
$r->print('<script>'. |
$r->print('<script>'. |
'window.document.Statistics.stats_status.value="'. |
'window.document.Statistics.stats_status.value="'. |
'Done computing student answers. Compiling spreadsheet.'. |
'Done computing student answers. Compiling spreadsheet.'. |
Line 626 sub prepare_excel_output {
|
Line 868 sub prepare_excel_output {
|
} |
} |
# |
# |
$r->rflush(); |
$r->rflush(); |
my @Columns; |
|
if (exists($ENV{'form.concise'}) && $ENV{'form.concise'} eq 'true') { |
|
foreach (@DefaultColumns) { |
|
if ($_->{'name'} =~ /^(username|domain|id)$/){ |
|
push(@Columns,$_); |
|
} |
|
|
|
|
|
|
|
|
|
|
my @ColumnLabels; |
|
my @Columns = @DefaultColumns; |
|
my %seen; |
|
foreach my $problem (@$Problems) { |
|
my ($resource,$respid,$partid) = ($problem->{'resource'}, |
|
$problem->{'respid'}, |
|
$problem->{'part'}); |
|
my $partkey = $resource->{'symb'}.':'.$partid; |
|
if (! $seen{$partkey}) { |
|
$ColumnLabels[$#Columns]=$resource->{'title'}; |
|
push(@ColumnLabels,$partid); |
|
push(@Columns,@PartColumns); |
} |
} |
} else { |
push(@Column |
@Columns = @DefaultColumns; |
if ($ENV{'form.correctans'} eq 'true') { |
} |
push(@Columns,'Computers answer'); |
my ($awarded_col,$weight_col); |
} |
for (my $i=0;$i<=$#Columns;$i++) { |
$seen{$resource->{'symb'}.':'.$partid} .= ':'.$respid; |
if ($Columns[$i]->{'name'} eq 'weight' ) { $weight_col = $i; } |
|
if ($Columns[$i]->{'name'} eq 'awarded') { $awarded_col = $i; } |
|
} |
} |
|
|
|
# my ($awarded_col,$weight_col); |
|
# for (my $i=0;$i<=$#Columns;$i++) { |
|
# if ($Columns[$i]->{'name'} eq 'weight' ) { $weight_col = $i; } |
|
# if ($Columns[$i]->{'name'} eq 'awarded') { $awarded_col = $i; } |
|
# } |
|
|
# |
# |
# Create excel worksheet |
# Create excel worksheet |
my $filename = '/prtspool/'. |
my $filename = '/prtspool/'. |
Line 680 sub prepare_excel_output {
|
Line 944 sub prepare_excel_output {
|
scalar(@$Students),'inline',undef,'Statistics','stats_status'); |
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 748 sub prepare_excel_output {
|
Line 1011 sub prepare_excel_output {
|
($rows_output,$weight_col); |
($rows_output,$weight_col); |
my $cols_output = 0; |
my $cols_output = 0; |
foreach my $col (@Columns) { |
foreach my $col (@Columns) { |
$worksheet->write($rows_output,$cols_output++,$row{$col}, |
$worksheet->write($rows_output,$cols_output++,$row{$col->{'name'}}, |
$row_format{$col->{'name'}}); |
$row_format{$col->{'name'}}); |
} |
} |
$rows_output++; |
$rows_output++; |
Line 774 sub prepare_excel_output {
|
Line 1037 sub prepare_excel_output {
|
return; |
return; |
} |
} |
|
|
|
=cut |
|
|
######################################################### |
######################################################### |
######################################################### |
######################################################### |
## |
## |
Line 784 sub prepare_excel_output {
|
Line 1049 sub prepare_excel_output {
|
sub CreateInterface { |
sub CreateInterface { |
## |
## |
## Output Selection |
## Output Selection |
my $OutputSelector = $/.'<select name="output">'.$/; |
my $output_selector = $/.'<select name="output">'.$/; |
foreach ('HTML','Excel','CSV') { |
foreach ('HTML','Excel','CSV') { |
$OutputSelector .= ' <option value="'.lc($_).'"'; |
$output_selector .= ' <option value="'.lc($_).'"'; |
if ($ENV{'form.output'} eq lc($_)) { |
if ($ENV{'form.output'} eq lc($_)) { |
$OutputSelector .= ' selected '; |
$output_selector .= ' selected '; |
} |
} |
$OutputSelector .='>'.&mt($_).'</option>'.$/; |
$output_selector .='>'.&mt($_).'</option>'.$/; |
} |
} |
$OutputSelector .= '</select>'.$/; |
$output_selector .= '</select>'.$/; |
## |
## |
## Environment variable initialization |
## Environment variable initialization |
my $Str = ''; |
my $Str = ''; |
Line 828 sub CreateInterface {
|
Line 1093 sub CreateInterface {
|
} |
} |
$ans_checkbox .= 'value="true" />'; |
$ans_checkbox .= 'value="true" />'; |
# |
# |
# Only show last submission checkbox |
# Show all submissions checkbox |
my $last_sub_checkbox = '<input type="checkbox" name="last_sub_only" '; |
my $all_sub_checkbox = '<input type="checkbox" name="all_sub" '; |
if (exists($ENV{'form.last_sub_only'}) && |
if (exists($ENV{'form.all_sub'}) && |
$ENV{'form.last_sub_only'} eq 'true') { |
$ENV{'form.all_sub'} eq 'true') { |
$last_sub_checkbox .= 'checked '; |
$all_sub_checkbox .= 'checked '; |
} |
} |
$last_sub_checkbox.= 'value="true" />'; |
$all_sub_checkbox.= 'value="true" />'; |
# |
# |
# Concise view checkbox |
# Concise view checkbox |
my $concise_view_checkbox = '<input type="checkbox" name="concise" '; |
my $concise_view_checkbox = '<input type="checkbox" name="concise" '; |
Line 844 sub CreateInterface {
|
Line 1109 sub CreateInterface {
|
$concise_view_checkbox .= 'value="true" />'; |
$concise_view_checkbox .= 'value="true" />'; |
# |
# |
$Str .= '<td align="right" halign="top">'. |
$Str .= '<td align="right" halign="top">'. |
'<b>'.&mt('Output Format: [_1]',$OutputSelector).'</b><br />'.$/. |
# '<b>'.&mt('Output Format: [_1]',$output_selector).'</b><br />'.$/. |
'<label><b>'. |
'<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('All submission [_1]',$all_sub_checkbox).'</b></label><br />'. |
'<label><b>'. |
# '<label><b>'. |
&mt('concise view [_1]',$concise_view_checkbox).'</b></label><br />'. |
# &mt('concise view [_1]',$concise_view_checkbox).'</b></label><br />'. |
'</td>'; |
'</td>'; |
# |
# |
$Str .= '</tr>'."\n"; |
$Str .= '</tr>'."\n"; |