Diff for /loncom/interface/statistics/lonstudentsubmissions.pm between versions 1.17 and 1.18

version 1.17, 2004/09/08 14:58:33 version 1.18, 2004/09/15 21:08:50
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 90  sub BuildStudentSubmissionsPage { Line 85  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'}};              my %Data;
             if ($ENV{'form.output'} eq 'excel') {              if (scalar(@Problems) > 5) {
                 &prepare_excel_output($r,$current_problem,                  # progress window
                                       $ProblemData,\@Students);                  my %prog_state=&Apache::lonhtmlcommon::Create_PrgWin
             } elsif ($ENV{'form.output'} eq 'csv') {                      ($r,'Problem Analysis Status',
                 &prepare_csv_output($r,$current_problem,                       'Problem Analysis Progress', 
                                       $ProblemData,\@Students);                       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 {              } else {
                 &prepare_html_output($r,$current_problem,                  foreach my $problem (@Problems) {
                                      $ProblemData,\@Students);                      $Data{$problem->symb} = 
                       {&Apache::lonstathelpers::get_problem_data
                            ($problem->src)};
                   }
             }              }
               &new_excel_output($r,\@Problems,\@Students,\%Data);
         }          }
         $r->print('<hr />');          $r->print('<hr />');
     } else {      } else {
Line 148  sub BuildStudentSubmissionsPage { Line 155  sub BuildStudentSubmissionsPage {
                   &mt('Prepare Report').'" />');                    &mt('Prepare Report').'" />');
         $r->print('&nbsp;'x5);          $r->print('&nbsp;'x5);
         $r->print('<h3>'.&mt('Please select a problem to analyze').'</h3>');          $r->print('<h3>'.&mt('Please select a problem to analyze').'</h3>');
         $r->print(&Apache::lonstathelpers::ProblemSelector('.'));          $r->print(&Apache::lonstathelpers::MultipleProblemSelector
                     (undef,'.','problemchoice','Statistics'));
       }
   }
   
   #########################################################
   #########################################################
   
   sub new_excel_output {
       my ($r,$Problems,$Students,$ProblemData) = @_;
       my $c = $r->connection();
       #
       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++,$_,$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++;
               }
           }
       }
       #
       # 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);
                   }
               }
           }
           $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/\&colon;/:/g;
       }
       return $title;
   }
   
   sub excel_format_response {
       my ($answer,$responsetype) = @_;
       if ($responsetype eq 'radiobutton') {
           $answer =~ s/=([^=])$//;
       } elsif ($responsetype eq 'option') {
           $answer = join("\n",
                          map { 
                              &Apache::lonnet::unescape($_) ;
                          } sort split('&',$answer)
                          );
     }      }
       if ($answer =~ m/^=/) {
           $answer = ' '.$answer;
       }
       return $answer;
 }  }
   
   
   =pod
   
   
   
   
   
   
   
   
   
   
   
   
   
   
   
   
   
   
 #########################################################  #########################################################
 #########################################################  #########################################################
   
Line 163  my @DefaultColumns = Line 347  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 398  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 471  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 609  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 694  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 813  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 839  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 915  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 982  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 1008  sub prepare_excel_output {
     return;      return;
 }  }
   
   =cut
   
 #########################################################  #########################################################
 #########################################################  #########################################################
 ##  ##
Line 844  sub CreateInterface { Line 1080  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]',$OutputSelector).'</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('final answer only [_1]',$last_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";

Removed from v.1.17  
changed lines
  Added in v.1.18


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>