Diff for /loncom/interface/statistics/lonproblemstatistics.pm between versions 1.53 and 1.60

version 1.53, 2003/06/13 20:27:17 version 1.60, 2003/10/24 13:36:16
Line 54  use Apache::lonnet(); Line 54  use Apache::lonnet();
 use Apache::lonhtmlcommon;  use Apache::lonhtmlcommon;
 use Apache::loncoursedata;  use Apache::loncoursedata;
 use Apache::lonstatistics;  use Apache::lonstatistics;
   use Apache::lonlocal;
 use Spreadsheet::WriteExcel;  use Spreadsheet::WriteExcel;
   
   ##
   ## Localization notes:
   ##
   ## in @Fields[0]->{'long_title'} is placed in Excel files and is used as the
   ## header for plots created with Graph.pm, both of which more than likely do
   ## not support localization.
   ##
 my @Fields = (  my @Fields = (
            { name => 'problem_num',             { name => 'problem_num',
              title => 'P#',               title => 'P#',
Line 75  my @Fields = ( Line 83  my @Fields = (
            { name   => 'part',              { name   => 'part', 
              title  => 'Part',               title  => 'Part',
              align  => 'left',               align  => 'left',
              color  => '#FFFFE6' },               color  => '#FFFFE6',
                },
            { name   => 'num_students',             { name   => 'num_students',
              title  => '#Stdnts',               title  => '#Stdnts',
              align  => 'right',               align  => 'right',
Line 131  my @Fields = ( Line 140  my @Fields = (
              format => '%5.2f',               format => '%5.2f',
              sortable  => 'yes',               sortable  => 'yes',
              graphable => 'yes',               graphable => 'yes',
              long_title => 'Degree of Difficulty' },               long_title => 'Degree of Difficulty'.
                              '[ 1 - ((#YES+#yes) / Tries) ]'},
            { name   => 'num_solved',             { name   => 'num_solved',
              title  => '#YES',               title  => '#YES',
              align  => 'right',               align  => 'right',
Line 155  my @Fields = ( Line 165  my @Fields = (
              format => '%4.1f',               format => '%4.1f',
              sortable  => 'yes',               sortable  => 'yes',
              graphable => 'yes',               graphable => 'yes',
              long_title => 'Percent Wrong' },               long_title => 'Percent of students whose final answer is wrong' },
 );  );
   
 ###############################################  ###############################################
Line 172  select sections, maps, and output. Line 182  select sections, maps, and output.
   
 ###############################################  ###############################################
 ###############################################  ###############################################
 sub CreateInterface {  
     my $Str = '';  
     $Str .= '<table cellspacing="5">'."\n";  
     $Str .= '<tr>';  
     $Str .= '<td align="center"><b>Sections</b></td>';  
     $Str .= '<td align="center"><b>Enrollment Status</b></td>';  
     $Str .= '<td align="center"><b>Sequences and Folders</b></td>';  
     $Str .= '<td align="center"><b>Output</b></td>';  
     $Str .= '</tr>'."\n";  
     #  
     $Str .= '<tr><td align="center">'."\n";  
     $Str .= &Apache::lonstatistics::SectionSelect('Section','multiple',5);  
     $Str .= '</td><td align="center">';  
     $Str .= &Apache::lonhtmlcommon::StatusOptions(undef,undef,5);  
     $Str .= '</td><td align="center">';  
     #  
     my $only_seq_with_assessments = sub {   
         my $s=shift;  
         if ($s->{'num_assess'} < 1) {   
             return 0;  
         } else {   
             return 1;  
         }  
     };  
     $Str .= &Apache::lonstatistics::MapSelect('Maps','multiple,all',5,  
                                               $only_seq_with_assessments);  
     $Str .= '</td><td>'."\n";  
     $Str .= &CreateAndParseOutputSelector();  
     $Str .= '</td></tr>'."\n";  
     $Str .= '</table>'."\n";  
     $Str .= '<input type="submit" value="Generate Statistics" />';  
     return $Str;  
 }  
   
 #######################################################  
 #######################################################  
   
 =pod  
   
 =item &CreateAndParseOutputSelector()  
   
 Construct a selection list of options for output and parse output selections.  
 The current output selected is indicated by the values of the two package  
 variables $output_mode and $show.  @OutputOptions holds the descriptions of  
 the output options and the values for $output_mode and $show.  
   
 Based on code from lonstudentassessment.pm.  
   
 =cut  
   
 #######################################################  
 #######################################################  
 my $output_mode;  
 my $show;  
   
 my @OutputOptions =   my @OutputOptions = 
     (      (
      { name  => 'problem statistics grouped by sequence',       { name  => 'problem statistics grouped by sequence',
Line 250  my @OutputOptions = Line 205  my @OutputOptions =
      },       },
      );       );
   
 sub OutputDescriptions {  sub CreateInterface {
     my $Str = '';  
     $Str .= "<h2>Output Modes</h2>\n";  
     $Str .= "<dl>\n";  
     foreach my $outputmode (@OutputOptions) {  
  $Str .="    <dt>".$outputmode->{'name'}."</dt>\n";  
  $Str .="        <dd>".$outputmode->{'description'}."</dd>\n";  
     }  
     $Str .= "</dl>\n";  
     return $Str;  
 }  
   
 sub CreateAndParseOutputSelector {  
     my $Str = '';      my $Str = '';
     my $elementname = 'statsoutputmode';      $Str .= '<table cellspacing="5">'."\n";
     #      $Str .= '<tr>';
     # Format for output options is 'mode, restrictions';      $Str .= '<td align="center"><b>'.&mt('Sections').'</b></td>';
     my $selected = 'HTML problem statistics grouped';      $Str .= '<td align="center"><b>'.&mt('Enrollment Status').'</b></td>';
     if (exists($ENV{'form.'.$elementname})) {      $Str .= '<td align="center"><b>'.&mt('Sequences and Folders').'</b></td>';
         if (ref($ENV{'form.'.$elementname} eq 'ARRAY')) {      $Str .= '<td align="center"><b>'.&mt('Output').'</b></td>';
             $selected = $ENV{'form.'.$elementname}->[0];      $Str .= '</tr>'."\n";
         } else {  
             $selected = $ENV{'form.'.$elementname};  
         }  
     }  
     #      #
     # Set package variables describing output mode      $Str .= '<tr><td align="center">'."\n";
     $output_mode = 'html';      $Str .= &Apache::lonstatistics::SectionSelect('Section','multiple',5);
     $show        = 'all';      $Str .= '</td><td align="center">';
     foreach my $option (@OutputOptions) {      $Str .= &Apache::lonhtmlcommon::StatusOptions(undef,undef,5);
         next if ($option->{'value'} ne $selected);      $Str .= '</td><td align="center">';
         $output_mode = $option->{'mode'};  
         $show        = $option->{'show'};  
     }  
     #      #
     # Build the form element      my $only_seq_with_assessments = sub { 
     $Str = qq/<select size="5" name="$elementname">/;          my $s=shift;
     foreach my $option (@OutputOptions) {          if ($s->{'num_assess'} < 1) { 
         if (exists($option->{'special'}) &&               return 0;
             $option->{'special'} =~ /do not show/) {          } else { 
             next;              return 1;
         }          }
         $Str .= "\n".'    <option value="'.$option->{'value'}.'"';      };
         $Str .= " selected " if ($option->{'value'} eq $selected);      $Str .= &Apache::lonstatistics::MapSelect('Maps','multiple,all',5,
         $Str .= ">".$option->{'name'}."<\/option>";                                                $only_seq_with_assessments);
     }      $Str .= '</td><td>'."\n";
     $Str .= "\n</select>";      my ($html,$outputmode,$show) = 
     return $Str;          &Apache::lonstatistics::CreateAndParseOutputSelector(
 }                                              'statsoutputmode',
                                               'HTML problem statistics grouped',
 ###############################################                                              @OutputOptions);
 ###############################################      $Str .= $html;
       $Str .= '</td></tr>'."\n";
 =pod       $Str .= '</table>'."\n";
       $Str .= '<input type="submit" name="GenerateStatistics" value="'.
 =item &Gather_Student_Data()          &mt('Generate Statistics').'" />';
       $Str .= '&nbsp;'x5;
 Ensures all student data is up to date.      $Str .= '<input type="submit" name="ClearCache" value="'.
           &mt('Clear Caches').'" />';
 =cut      $Str .= '&nbsp;'x5;
       return ($Str,$outputmode,$show);
 ###############################################  
 ###############################################  
 sub Gather_Student_Data {  
     my ($r) = @_;  
     my $c = $r->connection();  
     #  
     my @Sequences = &Apache::lonstatistics::Sequences_with_Assess();  
     #  
     my @Students = @Apache::lonstatistics::Students;  
     #  
     # Open the progress window  
     my %prog_state=&Apache::lonhtmlcommon::Create_PrgWin  
         ($r,'Statistics Compilation Status',  
          'Statistics Compilation Progress', scalar(@Students));  
     #  
     while (my $student = shift @Students) {  
         return if ($c->aborted());  
         my ($status,undef) = &Apache::loncoursedata::ensure_current_data  
             ($student->{'username'},$student->{'domain'},  
              $ENV{'request.course.id'});  
         &Apache::lonhtmlcommon::Increment_PrgWin($r,\%prog_state,  
                                                  'last student');  
     }  
     &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);  
     $r->rflush();  
 }  }
   
 ###############################################  ###############################################
Line 354  Main interface to problem statistics. Line 265  Main interface to problem statistics.
 sub BuildProblemStatisticsPage {  sub BuildProblemStatisticsPage {
     my ($r,$c)=@_;      my ($r,$c)=@_;
     #      #
     $output_mode = 'html';      my ($interface,$output_mode,$show) = &CreateInterface();
     $show = 'grouped';      $r->print($interface);
     #  
     $r->print(&CreateInterface());  
     $r->print('<input type="hidden" name="statsfirstcall" value="no" />');      $r->print('<input type="hidden" name="statsfirstcall" value="no" />');
     $r->print('<input type="hidden" name="sortby" value="'.$ENV{'form.sortby'}.      $r->print('<input type="hidden" name="sortby" value="'.$ENV{'form.sortby'}.
               '" />');                '" />');
Line 366  sub BuildProblemStatisticsPage { Line 275  sub BuildProblemStatisticsPage {
         return;          return;
     }      }
     #      #
     &Gather_Student_Data($r);      &Apache::lonstatistics::Gather_Student_Data($r);
     #      #
     #      #
     if ($output_mode eq 'html') {      if ($output_mode eq 'html') {
Line 381  sub BuildProblemStatisticsPage { Line 290  sub BuildProblemStatisticsPage {
             &output_html_ungrouped($r);              &output_html_ungrouped($r);
         }          }
     } elsif ($output_mode eq 'excel') {      } elsif ($output_mode eq 'excel') {
         $r->print("<h2>Preparing Excel Spreadsheet</h2>");          $r->print('<h2>'.&mt('Preparing Excel Spreadsheet').'</h2>');
         &output_excel($r);          &output_excel($r);
     } else {      } else {
         $r->print("<h1>Not implemented</h1>");          $r->print('<h1>'.&mt('Not implemented').'</h1>');
     }      }
     return;      return;
 }  }
Line 591  sub output_excel { Line 500  sub output_excel {
     # Check for errors      # Check for errors
     if (! defined($excel_workbook)) {      if (! defined($excel_workbook)) {
         $r->log_error("Error creating excel spreadsheet $filename: $!");          $r->log_error("Error creating excel spreadsheet $filename: $!");
         $r->print("Problems creating new Excel file.  ".          $r->print(&mt("Problems creating new Excel file.  ".
                   "This error has been logged.  ".                    "This error has been logged.  ".
                   "Please alert your LON-CAPA administrator");                    "Please alert your LON-CAPA administrator."));
         return ;          return ;
     }      }
     #      #
Line 642  sub output_excel { Line 551  sub output_excel {
     $rows_output++;       $rows_output++; 
     $cols_output=0;      $cols_output=0;
     #      #
     # Add the headers      # Long Headersheaders
       foreach my $field (@Fields) {
           next if ($field->{'name'} eq 'problem_num');
           if (exists($field->{'long_title'})) {
               $excel_sheet->write($rows_output,$cols_output++,
                                   $field->{'long_title'});
           } else {
               $excel_sheet->write($rows_output,$cols_output++,'');
           }
       }
       $rows_output++;
       $cols_output=0;
       # Brief headers
     foreach my $field (@Fields) {      foreach my $field (@Fields) {
         next if ($field->{'name'} eq 'problem_num');          next if ($field->{'name'} eq 'problem_num');
           # Use english for excel as I am not sure how well excel handles 
           # other character sets....
         $excel_sheet->write($rows_output,$cols_output++,$field->{'title'});          $excel_sheet->write($rows_output,$cols_output++,$field->{'title'});
     }      }
     $rows_output++;      $rows_output++;
Line 678  sub output_excel { Line 601  sub output_excel {
     $excel_workbook->close();      $excel_workbook->close();
     # Tell the user where to get their excel file      # Tell the user where to get their excel file
     $r->print('<br />'.      $r->print('<br />'.
               '<a href="'.$filename.'">Your Excel spreadsheet.</a>'."\n");                '<a href="'.$filename.'">'.
                 &mt('Your Excel Spreadsheet').'</a>'."\n");
     $r->rflush();      $r->rflush();
     return;      return;
 }  }
Line 734  sub statistics_table_header { Line 658  sub statistics_table_header {
                 'document.Statistics.sortby.value='."'".$field->{'name'}."'".                  'document.Statistics.sortby.value='."'".$field->{'name'}."'".
                     ';document.Statistics.submit();">';                      ';document.Statistics.submit();">';
         }          }
         $header_row .= $field->{'title'};          $header_row .= &mt($field->{'title'});
         if ($options =~ /sortable/) {          if ($options =~ /sortable/) {
             $header_row.= '</a>';              $header_row.= '</a>';
         }          }
Line 745  sub statistics_table_header { Line 669  sub statistics_table_header {
             $header_row .= '<a href="javascript:'.              $header_row .= '<a href="javascript:'.
                 "document.Statistics.plot.value='$field->{'name'}'".                  "document.Statistics.plot.value='$field->{'name'}'".
                     ';document.Statistics.submit();">';                      ';document.Statistics.submit();">';
             $header_row .= 'plot</a>)';              $header_row .= &mt('plot').'</a>)';
         }          }
         $header_row .= '</th>';          $header_row .= '</th>';
     }      }
Line 827  sub plot_statistics { Line 751  sub plot_statistics {
         }          }
     }      }
           
     $r->print("<p>".&DrawGraph(\@Data,$title,'Problem Number',$yaxis,      $r->print("<p>".&Apache::loncommon::DrawBarGraph($title,
                                $Max)."</p>\n");                                                       'Problem Number',
                                                        $yaxis,
                                                        $Max,
                                                        undef,
                                                        \@Data)."</p>\n");
     #      #
     # Print out the data      # Print out the data
     $ENV{'form.sortby'} = 'Contents';      $ENV{'form.sortby'} = 'Contents';
Line 836  sub plot_statistics { Line 764  sub plot_statistics {
     return;      return;
 }  }
   
 ###############################################  
 ###############################################  
   
 =pod   
   
 =item &DrawGraph()  
   
 =cut  
   
 ###############################################  
 ###############################################  
 sub DrawGraph {  
     my ($values,$title,$xaxis,$yaxis,$Max)=@_;  
     $title = '' if (! defined($title));  
     $xaxis = '' if (! defined($xaxis));  
     $yaxis = '' if (! defined($yaxis));  
     #  
     my $sendValues = join(',', @$values);  
     my $sendCount = scalar(@$values);  
     $Max =1 if ($Max < 1);  
     if ( int($Max) < $Max ) {  
         $Max++;  
         $Max = int($Max);  
     }  
     my @GData = ($title,$xaxis,$yaxis,$Max,$sendCount,$sendValues);  
     return '<IMG src="/cgi-bin/graph.png?'.  
         (join('&', @GData)).'" border="1" />';  
 }  
   
 sub get_statistics {  sub get_statistics {
     my ($sequence,$resource,$part,$problem_num) = @_;      my ($sequence,$resource,$part,$problem_num) = @_;
     #      #
Line 894  sub get_statistics { Line 793  sub get_statistics {
   
 =item &ProblemStatisticsLegend()  =item &ProblemStatisticsLegend()
   
   HELP  This needs to be localized, or at least generated automatically.
   
 =cut  =cut
   
 ###############################################  ###############################################

Removed from v.1.53  
changed lines
  Added in v.1.60


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