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

version 1.59, 2003/02/18 20:27:33 version 1.60, 2003/02/25 20:47:47
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 79  use Apache::lonstudentassessment; Line 72  use Apache::lonstudentassessment;
 use Apache::lonpercentage;  use Apache::lonpercentage;
 use GDBM_File;  use GDBM_File;
   
   use vars qw/@FullClasslist @Students @Sections @SelectedSections
       $curr_student $prev_student $next_student 
       $top_map @Sequences @Assessments /;
   
   #######################################################
   #######################################################
   
   =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 @FullClasslist;  my @FullClasslist;
 my @Students;  my @Students;
 my @Sections;  my @Sections;
   my @SelectedSections;
 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 123  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 $curr_student
   
 =item $next_student The student next in the classlist  =item $prev_student
   
   =item $next_student
   
 =back  =back
   
Line 119  sub clear_classlist_variables { Line 147  sub clear_classlist_variables {
     undef(@FullClasslist);      undef(@FullClasslist);
     undef(@Students);      undef(@Students);
     undef(@Sections);      undef(@Sections);
       undef(@SelectedSections);
     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 165  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 $curr_student
   
 =item $next_student The student next in the classlist  =item $prev_student
   
   =item $next_student
   
 =back  =back
   
Line 168  sub PrepareClasslist { Line 199  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{$_}++;              # Remove the empty sections
               for (my $i=0; $i<=$#SelectedSections; $i++) {
                   if ($SelectedSections[$i] =~ /^\s*$/) {
                       splice(@SelectedSections,$i,1);
                   }
             }              }
         } else {          } else {
             $valid_section{$_}++;              if ($ENV{'form.Section'} !~ /^\s*$/) {
                   @SelectedSections = ($ENV{'form.Section'});
               }
         }          }
     }      }
       @SelectedSections = ('any') if (! @SelectedSections);
     #      #
     # Process the classlist      # Process the classlist
     while (my ($student,$student_data) = each (%$classlist)) {      while (my ($student,$student_data) = each (%$classlist)) {
Line 189  sub PrepareClasslist { Line 226  sub PrepareClasslist {
         #          #
         # 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 'any') || ($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);
     #      #
     # 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 260  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 233  sub PrepareClasslist { Line 278  sub PrepareClasslist {
   
 #######################################################  #######################################################
 #######################################################  #######################################################
   #
   # Course Sequences variables
   #
   my $top_map;
   my @Sequences;
   my @Assessments;
   
   #######################################################
   #######################################################
   
   =pod
   
   =item &clear_sequence_variables()
   
   =cut
   
   #######################################################
   #######################################################
   sub clear_sequence_variables {
       undef($top_map);
       undef(@Sequences);
       undef(@Assessments);
   }
   
   #######################################################
   #######################################################
   
   =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 'HASH');
   
   =pod
   
       ##
       ## Debugging code
       ##
       foreach my $s (@Sequences) {
           next if ($s->{'title'} ne 'Bioenergetics: Enzyme Regulation');
           &Apache::lonnet::logthis('-----------------------------------');
           &Apache::lonnet::logthis('title      = '.$s->{'title'});
           &Apache::lonnet::logthis('symb       = '.$s->{'symb'});
           &Apache::lonnet::logthis('num_assess = '.$s->{'num_assess'});
           foreach my $a (@{$s->{'contents'}}) {
               &Apache::lonnet::logthis('   --------------------------------');
               &Apache::lonnet::logthis('   title      = '.$a->{'title'});
               &Apache::lonnet::logthis('   symb       = '.$a->{'symb'});
           }
       }
   
   =cut
   
       return;
   }
   
   ##############################################
   ##############################################
   
   =pod 
   
   =item &MapSelect($elementname,$status,$numvisible,$selected,$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 $selected Array ref to the names of the already selected maps.
   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 MapSelect {
       my ($elementname,$status,$numvisible,$selected,$restriction)=@_;
       if ($numvisible < 1) {
           return;
       }
       #
       # Set up array of selected items
       my @Selected;
       if (! defined($selected)) {
           if (exists($ENV{'form.'.$elementname})) {
               if (ref($ENV{'form.'.$elementname})) {
                   @Selected = @$ENV{'form.'.$elementname};
               } else {
                   @Selected = ($ENV{'form.'.$elementname});
               }
           } else {
               @Selected = ();
           }
       } else {
           if (ref($selected)) {
               @Selected = @$selected;
           } else {
               @Selected = ($selected);
           }
       }
       #
       # 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";
       #
       # Loop through the sequences
       foreach my $s (@Sequences) {
           next if (! $restriction->($s));
           $Str .= '    <option value="'.$s->{'symb'}.'" ';
           foreach (@Selected) {
               if ($s->{'symb'} eq $_) {
                   $Str .= 'selected ';
                   last;
               }
           }
           $Str .= '>'.$s->{'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 $_ || $_ =~ /^(any|all)$/) {
                   $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 507  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 519  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 598  sub PrepareData { Line 865  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($student->{$field}).'">';
                   $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 806  sub BuildStatistics { Line 1121  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 1177  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']);
   
     &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.60


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