Diff for /loncom/interface/lonstatistics.pm between versions 1.59 and 1.64

version 1.59, 2003/02/18 20:27:33 version 1.64, 2003/03/07 18:46:38
Line 1 Line 1
 # The LearningOnline Network with CAPA  # The LearningOnline Network with CAPA
 # (Publication Handler  
 #  #
 # $Id$  # $Id$
 #  #
Line 26 Line 25
 # http://www.lon-capa.org/  # http://www.lon-capa.org/
 #  #
 # (Navigate problems for statistical reports  # (Navigate problems for statistical reports
 # YEAR=2001  
 # 5/5,7/9,7/25/1,8/11,9/13,9/26,10/5,10/9,10/22,10/26 Behrouz Minaei  
 # 11/1,11/4,11/16,12/14,12/16,12/18,12/20,12/31 Behrouz Minaei  
 # YEAR=2002  
 # 1/22,2/1,2/6,2/25,3/2,3/6,3/17,3/21,3/22,3/26,4/7,5/6 Behrouz Minaei  
 # 5/12,5/14,5/15,5/19,5/26,7/16,25/7,29/7  Behrouz Minaei  
 #  #
 ###  ###
   
Line 47  Main handler for statistics and chart. Line 40  Main handler for statistics and chart.
   
 =head1 PACKAGES USED  =head1 PACKAGES USED
   
 use strict;      use strict;
 use Apache::Constants qw(:common :http);      use Apache::Constants qw(:common :http);
 use Apache::lonnet();      use Apache::lonnet();
 use Apache::lonhomework;      use Apache::lonhomework;
 use Apache::loncommon;      use Apache::loncommon;
 use Apache::loncoursedata;      use Apache::loncoursedata;
 use Apache::lonhtmlcommon;      use Apache::lonhtmlcommon;
 use Apache::lonproblemanalysis;      use Apache::lonproblemanalysis;
 use Apache::lonproblemstatistics;      use Apache::lonproblemstatistics;
 use Apache::lonstudentassessment;      use Apache::lonstudentassessment;
 use Apache::lonpercentage;      use Apache::lonpercentage;
 use GDBM_File;      use GDBM_File;
   
 =over 4  =over 4
   
Line 68  package Apache::lonstatistics; Line 61  package Apache::lonstatistics;
   
 use strict;  use strict;
 use Apache::Constants qw(:common :http);  use Apache::Constants qw(:common :http);
   use vars qw(
       @FullClasslist 
       @Students
       @Sections 
       @SelectedSections
       %StudentData
       @StudentDataOrder
       @SelectedStudentData
       $top_map 
       @Sequences 
       @SelectedMaps
       @Assessments);
   
 use Apache::lonnet();  use Apache::lonnet();
 use Apache::lonhomework;  use Apache::lonhomework;
 use Apache::loncommon;  use Apache::loncommon;
 use Apache::loncoursedata;  use Apache::loncoursedata;
 use Apache::lonhtmlcommon;  use Apache::lonhtmlcommon;
 use Apache::lonproblemanalysis;  use Apache::lonproblemanalysis();
 use Apache::lonproblemstatistics;  use Apache::lonproblemstatistics();
 use Apache::lonstudentassessment;  use Apache::lonstudentassessment();
 use Apache::lonpercentage;  use Apache::lonpercentage;
 use GDBM_File;  use GDBM_File;
   
 my @FullClasslist;  
 my @Students;  #######################################################
 my @Sections;  #######################################################
   
   =pod
   
   =item Package Variables
   
   =item @FullClasslist The full classlist
   
   =item @Students The students we are concerned with for this invocation
   
   =item @Sections The sections available in this class
   
   =item $curr_student The student currently being examined
   
   =item $prev_student The student previous in the classlist
   
   =item $next_student The student next in the classlist
   
   =over
   
   =cut 
   
   #######################################################
   #######################################################
   #
   # Classlist variables
   #
 my $curr_student;  my $curr_student;
 my $prev_student;  my $prev_student;
 my $next_student;  my $next_student;
Line 97  undef the following package variables: Line 129  undef the following package variables:
   
 =over  =over
   
 =item @FullClasslist The full classlist  =item @FullClasslist
   
 =item @Students The students we are concerned with for this invocation  =item @Students
   
 =item @Sections The sections available in this class  =item @Sections
   
 =item $curr_student The student currently being examined  =item @SelectedSections
   
 =item $prev_student The student previous in the classlist  =item %StudentData
   
 =item $next_student The student next in the classlist  =item @StudentDataOrder
   
   =item @SelectedStudentData
   
   =item $curr_student
   
   =item $prev_student
   
   =item $next_student
   
 =back  =back
   
Line 119  sub clear_classlist_variables { Line 159  sub clear_classlist_variables {
     undef(@FullClasslist);      undef(@FullClasslist);
     undef(@Students);      undef(@Students);
     undef(@Sections);      undef(@Sections);
       undef(@SelectedSections);
       undef(%StudentData);
       undef(@SelectedStudentData);
     undef($curr_student);      undef($curr_student);
     undef($prev_student);      undef($prev_student);
     undef($next_student);      undef($next_student);
Line 136  the following package variables: Line 179  the following package variables:
   
 =over  =over
   
 =item @FullClasslist The full classlist  =item @FullClasslist
   
 =item @Students The students we are concerned with for this invocation  =item @Students
   
 =item @Sections The sections available in this class  =item @Sections
   
 =item $curr_student The student currently being examined  =item @SelectedSections
   
 =item $prev_student The student previous in the classlist  =item %StudentData
   
 =item $next_student The student next in the classlist  =item @SelectedStudentData
   
   =item $curr_student
   
   =item $prev_student
   
   =item $next_student
   
 =back  =back
   
Line 168  sub PrepareClasslist { Line 217  sub PrepareClasslist {
     my $cnum = $ENV{'course.'.$cid.'.num'};      my $cnum = $ENV{'course.'.$cid.'.num'};
     my ($classlist,$field_names) = &Apache::loncoursedata::get_classlist($cid,      my ($classlist,$field_names) = &Apache::loncoursedata::get_classlist($cid,
                                                                   $cdom,$cnum);                                                                    $cdom,$cnum);
     my %valid_section;      if (exists($ENV{'form.Section'})) {
     if (exists($ENV{'form.Section'}) && $ENV{'form.Section'} !~ /(all|any)/) {  
         if (ref($ENV{'form.Section'})) {          if (ref($ENV{'form.Section'})) {
             foreach (@$ENV{'form.section'}) {              @SelectedSections = @{$ENV{'form.Section'}};
                 $valid_section{$_}++;          } elsif ($ENV{'form.Section'} !~ /^\s*$/) {
             }              @SelectedSections = ($ENV{'form.Section'});
         } else {          }
             $valid_section{$_}++;      }
       @SelectedSections = ('all') if (! @SelectedSections);
       foreach (@SelectedSections) {
           if ($_ eq 'all') {
               @SelectedSections = ('all');
         }          }
     }      }
     #      #
       # Set up %StudentData
       @StudentDataOrder = qw/fullname username domain id section status/;
       foreach my $field (@StudentDataOrder) {
           $StudentData{$field}->{'title'} = $field;
           $StudentData{$field}->{'base_width'} = length($field);
           $StudentData{$field}->{'width'} = 
                                  $StudentData{$field}->{'base_width'};
       }
   
       #
     # Process the classlist      # Process the classlist
     while (my ($student,$student_data) = each (%$classlist)) {      while (my ($student,$student_data) = each (%$classlist)) {
         my $studenthash = ();          my $studenthash = ();
         for (my $i=0; $i< scalar(@$field_names);$i++) {          for (my $i=0; $i< scalar(@$field_names);$i++) {
             $studenthash->{$field_names->[$i]}=$student_data->[$i];              my $field = $field_names->[$i];
               # Store the data
               $studenthash->{$field}=$student_data->[$i];
               # Keep track of the width of the fields
               next if (! exists($StudentData{$field}));
               my $length = length($student_data->[$i]);
               if ($StudentData{$field}->{'width'} < $length) {
                   $StudentData{$field}->{'width'} = $length; 
               }
         }          }
         push (@FullClasslist,$studenthash);          push (@FullClasslist,$studenthash);
         #          #
         # Build up a list of sections          # Build up a list of sections
         my $section = $studenthash->{'section'};          my $section = $studenthash->{'section'};
         $section = 'no section' if (! defined($section) || $section =~/^\s*/ );          if (! defined($section) || $section =~/^\s*$/ || $section == -1) {
               $studenthash->{'section'} = 'none';
               $section = $studenthash->{'section'};
           }
         $Sections{$section}++;          $Sections{$section}++;
         #          #
         # Only put in the list those students we are interested in          # Only put in the list those students we are interested in
         if (defined($ENV{'form.Section'}) &&          foreach my $sect (@SelectedSections) {
             $ENV{'form.Section'} !~ /(all|any)/ &&               if (($sect eq 'all') || ($section eq $sect)) {
             ! exists($valid_section{$section})) {                  push (@Students,$studenthash);
             next;                  last;
               }
         }          }
         push (@Students,$studenthash);  
     }      }
     #      #
     # Put the consolidated section data in the right place      # Put the consolidated section data in the right place
     @Sections = sort {$a<=>$b} keys(%Sections);      @Sections = sort {$a cmp $b} keys(%Sections);
       unshift(@Sections,'all'); # Put 'all' at the front of the list
     #      #
     # Sort the Students      # Sort the Students
     my $sortby = 'fullname';      my $sortby = 'fullname';
     @Students = sort {$a->{$sortby} <=> $b->{$sortby}} @Students;      $sortby = $ENV{'form.sort'} if (exists($ENV{'form.sort'}));
       my @TmpStudents = sort { $a->{$sortby} cmp $b->{$sortby} ||
                                $a->{'fullname'} cmp $b->{'fullname'} } @Students;
       @Students = @TmpStudents;
     #       # 
     # Now deal with that current student thing....      # Now deal with that current student thing....
     if (exists($ENV{'form.StudentAssessmentStudent'})) {      if (exists($ENV{'form.StudentAssessmentStudent'})) {
Line 216  sub PrepareClasslist { Line 293  sub PrepareClasslist {
         for ($i = 0; $i<=$#Students; $i++) {          for ($i = 0; $i<=$#Students; $i++) {
             next if (($Students[$i]->{'username'} ne $current_uname) ||               next if (($Students[$i]->{'username'} ne $current_uname) || 
                      ($Students[$i]->{'domain'}   ne $current_dom));                       ($Students[$i]->{'domain'}   ne $current_dom));
               $curr_student = $Students[$i];
             last; # If we get here, we have our student.              last; # If we get here, we have our student.
         }          }
         if ($i == 0) {          if ($i == 0) {
Line 229  sub PrepareClasslist { Line 307  sub PrepareClasslist {
             $next_student = $Students[$i+1];              $next_student = $Students[$i+1];
         }          }
     }      }
       #
       if (exists($ENV{'form.StudentData'})) {
           if (ref($ENV{'form.StudentData'}) eq 'ARRAY') {
               @SelectedStudentData = @{$ENV{'form.StudentData'}};
           } else {
               @SelectedStudentData = ($ENV{'form.StudentData'});
           }
       } else {
           @SelectedStudentData = ('fullname');
       }
       foreach (@SelectedStudentData) {
           if ($_ eq 'all') {
               @SelectedStudentData = ('all');
               last;
           }
       }
       #
       return;
   }
   
   #######################################################
   #######################################################
   
   =pod
   
   =item &current_student()
   
   Returns a pointer to a hash containing data about the currently
   selected student.
   
   =cut
   
   #######################################################
   #######################################################
   sub current_student { 
       if (defined($curr_student)) {
           return $curr_student;
       } else {
           return 'All Students';
       }
   }
   
   #######################################################
   #######################################################
   
   =pod
   
   =item &previous_student()
   
   Returns a pointer to a hash containing data about the student prior
   in the list of students.  Or something.  
   
   =cut
   
   #######################################################
   #######################################################
   sub previous_student { 
       if (defined($prev_student)) {
           return $prev_student;
       } else {
           return 'No Student Selected';
       }
   }
   
   #######################################################
   #######################################################
   
   =pod
   
   =item &next_student()
   
   Returns a pointer to a hash containing data about the next student
   to be viewed.
   
   =cut
   
   #######################################################
   #######################################################
   sub next_student { 
       if (defined($next_student)) {
           return $next_student;
       } else {
           return 'No Student Selected';
       }
   }
   
   #######################################################
   #######################################################
   
   =pod
   
   =item &clear_sequence_variables()
   
   =cut
   
   #######################################################
   #######################################################
   sub clear_sequence_variables {
       undef($top_map);
       undef(@Sequences);
       undef(@Assessments);
   }
   
   #######################################################
   #######################################################
   
   =pod
   
   =item &SetSelectedMaps($elementname)
   
   Sets the @SelectedMaps array from $ENV{'form.'.$elementname};
   
   =cut
   
   #######################################################
   #######################################################
   sub SetSelectedMaps {
       my $elementname = shift;
       if (exists($ENV{'form.'.$elementname})) {
           if (ref($ENV{'form.'.$elementname})) {
               @SelectedMaps = @{$ENV{'form.'.$elementname}};
           } else {
               @SelectedMaps = ($ENV{'form.'.$elementname});
           }
       } else {
           @SelectedMaps = ('all');
       }
   }
   
   
   #######################################################
   #######################################################
   
   =pod
   
   =item &Sequences_with_Assess()
   
   Returns an array containing the subset of @Sequences which contain
   assessments.
   
   =cut
   
   #######################################################
   #######################################################
   sub Sequences_with_Assess {
       my @Sequences_to_Show;
       foreach my $map_symb (@SelectedMaps) {
           foreach my $sequence (@Sequences) {
               next if ($sequence->{'symb'} ne $map_symb && $map_symb ne 'all');
               next if ($sequence->{'num_assess'} < 1);
               push (@Sequences_to_Show,$sequence);
           }
       }
       return @Sequences_to_Show;
 }  }
   
 #######################################################  #######################################################
 #######################################################  #######################################################
   
   =pod
   
   =item &PrepareCourseData($r)
   
   =cut
   
   #######################################################
   #######################################################
   sub PrepareCourseData {
       my ($r) = @_;
       &clear_sequence_variables();
       my ($top,$sequences,$assessments) = 
           &Apache::loncoursedata::get_sequence_assessment_data();
       if (! defined($top) || ! ref($top)) {
           # There has been an error, better report it
           &Apache::lonnet::logthis('top is undefined');
           return;
       }
       $top_map = $top if (ref($top));
       @Sequences = @{$sequences} if (ref($sequences) eq 'ARRAY');
       @Assessments = @{$assessments} if (ref($assessments) eq 'ARRAY');
       #
       # Compute column widths
       foreach my $seq (@Sequences) {
           my $name_length = length($seq->{'title'});
           my $num_parts = $seq->{'num_assess_parts'};
           #
           # The number of columns needed for the summation text: 
           #    " 1/5" = 1+3 columns, " 10/99" = 1+5 columns
           my $sum_length = 1+1+2*(length($num_parts));
           my $num_col = $num_parts+$sum_length;
           if ($num_col < $name_length) {
               $num_col = $name_length;
           }
           $seq->{'base_width'} = $name_length;
           $seq->{'width'} = $num_col;
       }
       return;
   }
   
   #######################################################
   #######################################################
   
   =pod
   
   =item &log_sequence($sequence,$recursive,$padding)
   
   Write data about the sequence to a logfile.  If $recursive is not
   undef the data is written recursively.  $padding is used for recursive
   calls.
   
   =cut
   
   #######################################################
   #######################################################
   sub log_sequence {
       my ($seq,$recursive,$padding) = @_;
       $padding = '' if (! defined($padding));
       if (ref($seq) ne 'HASH') {
           &Apache::lonnet::logthis('log_sequence passed bad sequnce');
           return;
       }
       &Apache::lonnet::logthis($padding.'sequence '.$seq->{'title'});
       while (my($key,$value) = each(%$seq)) {
           next if ($key eq 'contents');
           if (ref($value) eq 'ARRAY') {
               for (my $i=0;$i< scalar(@$value);$i++) {
                   &Apache::lonnet::logthis($padding.$key.'['.$i.']='.
                                            $value->[$i]);
               }
           } else {
               &Apache::lonnet::logthis($padding.$key.'='.$value);
           }
       }
       if (defined($recursive)) {
           &Apache::lonnet::logthis($padding.'-'x20);
           &Apache::lonnet::logthis($padding.'contains:');
           foreach my $item (@{$seq->{'contents'}}) {
               if ($item->{'type'} eq 'container') {
                   &log_sequence($item,$recursive,$padding.'    ');
               } else {
                   &Apache::lonnet::logthis($padding.'title = '.$item->{'title'});
                   while (my($key,$value) = each(%$item)) {
                       next if ($key eq 'title');
                       if (ref($value) eq 'ARRAY') {
                           for (my $i=0;$i< scalar(@$value);$i++) {
                               &Apache::lonnet::logthis($padding.$key.'['.$i.']='.
                                                        $value->[$i]);
                           }
                       } else {
                           &Apache::lonnet::logthis($padding.$key.'='.$value);
                       }
                   }
               }
           }
           &Apache::lonnet::logthis($padding.'end contents of '.$seq->{'title'});
           &Apache::lonnet::logthis($padding.'-'x20);
       }
       return;
   }
   
   ##############################################
   ##############################################
   
   =pod 
   
   =item &StudentDataSelect($elementname,$status,$numvisible,$selected)
   
   Returns html for a selection box allowing the user to choose one (or more) 
   of the fields of student data available (fullname, username, id, section, etc)
   
   =over 4
   
   =item $elementname The name of the HTML form element
   
   =item $status 'multiple' or 'single' selection box
   
   =item $numvisible The number of options to be visible
   
   =back
   
   =cut
   
   ##############################################
   ##############################################
   sub StudentDataSelect {
       my ($elementname,$status,$numvisible)=@_;
       if ($numvisible < 1) {
           return;
       }
       #
       # Build the form element
       my $Str = "\n";
       $Str .= '<select name="'.$elementname.'" ';
       if ($status ne 'single') {
           $Str .= 'multiple="true" ';
       }
       $Str .= 'size="'.$numvisible.'" >'."\n";
       #
       # Deal with 'all'
       $Str .= '    <option value="all" ';
       foreach (@SelectedStudentData) {
           if ($_ eq 'all') {
               $Str .= 'selected ';
               last;
           }
       }
       $Str .= ">all</option>\n";
       #
       # Loop through the student data fields
       foreach my $item (@StudentDataOrder) {
           $Str .= '    <option value="'.$item.'" ';
           foreach (@SelectedStudentData) {
               if ($item eq $_ ) {
                   $Str .= 'selected ';
                   last;
               }
           }
           $Str .= '>'.$item."</option>\n";
       }
       $Str .= "</select>\n";
       return $Str;
   }
   
   ##############################################
   ##############################################
   
   =pod 
   
   =item &MapSelect($elementname,$status,$numvisible,$restriction) 
   
   Returns html for a selection box allowing the user to choose one (or more) 
   of the sequences in the course.  The values of the sequences are the symbs.
   If the top sequence is selected, the value 'top' will result.
   
   =over 4
   
   =item $elementname The name of the HTML form element
   
   =item $status 'multiple' or 'single' selection box
   
   =item $numvisible The number of options to be visible
   
   =item $restriction Code reference to subroutine which returns true or 
   false.  The code must expect a reference to a sequence data structure.
   
   =back
   
   =cut
   
   ##############################################
   ##############################################
   sub MapSelect {
       my ($elementname,$status,$numvisible,$restriction)=@_;
       if ($numvisible < 1) {
           return;
       }
       #
       # Set up array of selected items
       &SetSelectedMaps($elementname);
       #
       # Set up the restriction call
       if (! defined($restriction)) {
           $restriction = sub { 1; };
       }
       #
       # Build the form element
       my $Str = "\n";
       $Str .= '<select name="'.$elementname.'" ';
       if ($status ne 'single') {
           $Str .= 'multiple="true" ';
       }
       $Str .= 'size="'.$numvisible.'" >'."\n";
       #
       # Deal with 'all'
       foreach (@SelectedMaps) {
           if ($_ eq 'all') {
               @SelectedMaps = ('all');
               last;
           }
       }
       #
       # Put in option for 'all'
       $Str .= '    <option value="all" ';
       foreach (@SelectedMaps) {
           if ($_ eq 'all') {
               $Str .= 'selected ';
               last;
           }
       }
       $Str .= ">all</option>\n";
       #
       # Loop through the sequences
       foreach my $seq (@Sequences) {
           next if (! $restriction->($seq));
           $Str .= '    <option value="'.$seq->{'symb'}.'" ';
           foreach (@SelectedMaps) {
               if ($seq->{'symb'} eq $_) {
                   $Str .= 'selected ';
                   last;
               }
           }
           $Str .= '>'.$seq->{'title'}."</option>\n";
       }
       $Str .= "</select>\n";
       return $Str;
   }
   
   ##############################################
   ##############################################
   
   =pod 
   
   =item &SectionSelect($elementname,$status,$numvisible) 
   
   Returns html for a selection box allowing the user to choose one (or more) 
   of the sections in the course.  
   
   =over 4
   
   =item $elementname The name of the HTML form element
   
   =item $status 'multiple' or 'single' selection box
   
   =item $numvisible The number of options to be visible
   
   =item $selected Array ref to the names of the already selected sections.
   If undef, $ENV{'form.'.$elementname} is used.  
   If $ENV{'form.'.$elementname} is also empty, none will be selected.
   
   =item $restriction Code reference to subroutine which returns true or 
   false.  The code must expect a reference to a sequence data structure.
   
   =back
   
   =cut
   
   ##############################################
   ##############################################
   sub SectionSelect {
       my ($elementname,$status,$numvisible)=@_;
       if ($numvisible < 1) {
           return;
       }
       #
       # Build the form element
       my $Str = "\n";
       $Str .= '<select name="'.$elementname.'" ';
       if ($status ne 'single') {
           $Str .= 'multiple="true" ';
       }
       $Str .= 'size="'.$numvisible.'" >'."\n";
       #
       # Loop through the sequences
       foreach my $s (@Sections) {
           $Str .= '    <option value="'.$s.'" ';
           foreach (@SelectedSections) {
               if ($s eq $_) {
                   $Str .= 'selected ';
                   last;
               }
           }
           $Str .= '>'.$s."</option>\n";
       }
       $Str .= "</select>\n";
       return $Str;
   }
   
   ##############################################
   ##############################################
   
 sub CheckFormElement {  sub CheckFormElement {
     my ($cache, $ENVName, $cacheName, $default)=@_;      my ($cache, $ENVName, $cacheName, $default)=@_;
   
Line 241  sub CheckFormElement { Line 784  sub CheckFormElement {
         $cache->{$cacheName} = $ENV{'form.'.$ENVName};          $cache->{$cacheName} = $ENV{'form.'.$ENVName};
     } elsif(!defined($cache->{$cacheName})) {      } elsif(!defined($cache->{$cacheName})) {
         $cache->{$cacheName} = $default;          $cache->{$cacheName} = $default;
       } else {
           $ENV{'form.'.$ENVName} = $cache->{$cacheName};
     }      }
   
     return;      return;
 }  }
   
Line 252  sub ProcessFormData{ Line 796  sub ProcessFormData{
     $cache->{'reportKey'} = 'false';      $cache->{'reportKey'} = 'false';
   
     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},      &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
                                             ['sort','download',                                              ['download',
                                              'reportSelected',                                               'reportSelected',
                                              'StudentAssessmentStudent',                                               'StudentAssessmentStudent',
                                              'ProblemStatisticsSort']);                                               'ProblemStatisticsSort']);
Line 399  sub ProcessFormData{ Line 943  sub ProcessFormData{
     return;      return;
 }  }
   
   ##################################################
   ##################################################
   
 =pod  =pod
   
 =item &SortStudents()  =item &SortStudents()
Line 598  sub PrepareData { Line 1145  sub PrepareData {
     return ('OK', $students);      return ('OK', $students);
 }  }
   
   sub DisplayClasslist {
       my ($r)=@_;
       #
       my @Fields = ('fullname','username','domain','id','section');
       #
       my $Str='';
       $Str .= '<table border="0"><tr><td bgcolor="#777777">'."\n";
       $Str .= '<table border="0" cellpadding="3"><tr bgcolor="#e6ffff">'."\n";
       foreach my $field (@Fields) {
           $Str .= '<th><a href="/adm/statistics?sort='.$field.'">'.$field.
               '</a></th>';
       }
       $Str .= '</tr>'."\n";
       #
       my $alternate = 0;
       foreach my $student (@Students) {
           my $sname = $student->{'username'}.':'.$student->{'domain'};
           if($alternate) {
               $Str .= '<tr bgcolor="#ffffe6">';
           } else {
               $Str .= '<tr bgcolor="#ffffc6">';
           }
           $alternate = ($alternate + 1) % 2;
           #
           foreach my $field (@Fields) {
               $Str .= '<td>';
               if ($field eq 'fullname') {
                   $Str .= '<a href="/adm/statistics?reportSelected=';
                   $Str .= &Apache::lonnet::escape('Student Assessment');
                   $Str .= '&StudentAssessmentStudent=';
                   $Str .= &Apache::lonnet::escape($sname).'">';
                   $Str .= $student->{$field}.'&nbsp';
                   $Str .= '</a>';
               } else {
                   $Str .= $student->{$field};
               }
               $Str .= '</td>';
           }
           $Str .= "</tr>\n";
       }
       $Str .= '</table></td></tr></table>'."\n";
       #
       $r->print($Str);
       $r->rflush();
       #
       return;
   }
   
 sub BuildClasslist {  sub BuildClasslist {
     my ($cacheDB,$students,$studentInformation,$headings,$r)=@_;      my ($cacheDB,$students,$studentInformation,$headings,$r)=@_;
   
Line 683  sub CreateMainMenu { Line 1278  sub CreateMainMenu {
     my $Str = '';      my $Str = '';
   
     $Str .= '<table border="0"><tbody><tr>'."\n";      $Str .= '<table border="0"><tbody><tr>'."\n";
     $Str .= '<td></td><td></td>'."\n";      $Str .= '<td></td>'."\n";
     $Str .= '<td align="center"><b>Select a Report</b></td>'."\n";      $Str .= '<td align="center"><b>Select a Report</b></td>'."\n";
     $Str .= '<td align="center"><b>Student Status</b></td></tr>'."\n";      $Str .= '<td align="center"><b>Student Status</b></td></tr>'."\n";
     $Str .= '<tr>'."\n";      $Str .= '<tr>'."\n";
     $Str .= '<td align="center"><input type="submit" name="Refresh" ';      $Str .= '<td align="center"><input type="submit" name="Refresh" ';
     $Str .= 'value="Refresh" /></td>'."\n";      $Str .= 'value="Update Display" /></td>'."\n";
     $Str .= '<td align="center"><input type="submit" name="DownloadAll" ';  
     $Str .= 'value="Update All Student Data" /></td>'."\n";  
     $Str .= '<td align="center">';      $Str .= '<td align="center">';
     $Str .= '<select name="reportSelected" onchange="document.';      $Str .= '<select name="reportSelected" onchange="document.';
     $Str .= 'Statistics.submit()">'."\n";      $Str .= 'Statistics.submit()">'."\n";
Line 787  sub BuildStatistics { Line 1380  sub BuildStatistics {
     } elsif($GoToPage eq 'Option Response Analysis') {      } elsif($GoToPage eq 'Option Response Analysis') {
         &Apache::lonproblemanalysis::BuildProblemAnalysisPage($cacheDB, $r);          &Apache::lonproblemanalysis::BuildProblemAnalysisPage($cacheDB, $r);
     } elsif($GoToPage eq 'Student Assessment') {      } elsif($GoToPage eq 'Student Assessment') {
         &Apache::lonstudentassessment::BuildStudentAssessmentPage($cacheDB,          &Apache::lonstudentassessment::BuildStudentAssessmentPage($r, $c);
                                                           $students,  
                                                           $courseID,  
                                                           'Statistics',  
                                                           \@headings,  
                                                           $spacing,  
                                                           \@studentInformation,  
                                                           $r, $c);  
     } elsif($GoToPage eq 'Analyze') {      } elsif($GoToPage eq 'Analyze') {
         &Apache::lonproblemanalysis::BuildAnalyzePage($cacheDB, $students,          &Apache::lonproblemanalysis::BuildAnalyzePage($cacheDB, $students,
                                                       $courseID, $r);                                                        $courseID, $r);
Line 806  sub BuildStatistics { Line 1392  sub BuildStatistics {
                                                          $students, $courseID,                                                           $students, $courseID,
                                                          $r, $c);                                                           $r, $c);
     } elsif($GoToPage eq 'Class list') {      } elsif($GoToPage eq 'Class list') {
         &BuildClasslist($cacheDB, $students, \@studentInformation,          &DisplayClasslist($r);
                         \@headings, $r);  #        &BuildClasslist($cacheDB, $students, \@studentInformation,
   #                        \@headings, $r);
     } elsif($GoToPage eq 'Correct-problems Plot') {      } elsif($GoToPage eq 'Correct-problems Plot') {
  &Apache::lonpercentage::BuildPercentageGraph($cacheDB, $students,   &Apache::lonpercentage::BuildPercentageGraph($cacheDB, $students,
      $courseID, $c, $r);       $courseID, $c, $r);
Line 861  sub handler { Line 1448  sub handler {
     $r->content_type('text/html');      $r->content_type('text/html');
     $r->send_http_header;      $r->send_http_header;
   
       &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
                                               ['sort',
                                                'StudentAssessmentStudent']);
   
     &PrepareClasslist($r);      &PrepareClasslist($r);
   
       &PrepareCourseData($r);
   
     &BuildStatistics($r);      &BuildStatistics($r);
   
     return OK;      return OK;

Removed from v.1.59  
changed lines
  Added in v.1.64


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