Diff for /loncom/interface/Attic/lonchart.pm between versions 1.30 and 1.41

version 1.30, 2002/02/19 18:58:10 version 1.41, 2002/06/03 19:28:17
Line 25 Line 25
 #  #
 # http://www.lon-capa.org/  # http://www.lon-capa.org/
 #  #
 #  
 # Homework Performance Chart  # Homework Performance Chart
 #  #
 # (Navigate Maps Handler  # (Navigate Maps Handler
Line 43 Line 42
 # 9/8 Gerd Kortemeyer  # 9/8 Gerd Kortemeyer
 # 10/1, 10/19, 11/17, 11/22, 11/24, 11/28 12/18 Behrouz Minaei  # 10/1, 10/19, 11/17, 11/22, 11/24, 11/28 12/18 Behrouz Minaei
 # YEAR=2002  # YEAR=2002
 # 2/1, 2/6, 2/19 Behrouz Minaei  # 2/1, 2/6, 2/19, 2/28 Behrouz Minaei
 #  #
 ###  ###
   
Line 64  my @rowlabels; Line 63  my @rowlabels;
 my @students;  my @students;
 my @PreCol;  my @PreCol;
 my $r;  my $r;
    
 # ------------------------------------------------------------- Find out status  # ------------------------------------------------------------- Find out status
   
 sub ExtractStudentData {  sub ExtractStudentData {
     my ($index,$coid)=@_;      my ($index,$coid)=@_;
     my ($sname,$sdom) = split( /\:/, $students[$index] );      my ($sname,$sdom) = split( /\:/, $students[$index] );
     my $shome=&Apache::lonnet::homeserver( $sname,$sdom );                my %result=&Apache::lonnet::dump($coid,$sdom,$sname);
     my $reply=&Apache::lonnet::reply('dump:'.$sdom.':'.$sname.':'.$coid,$shome );  
     my %result=();  
     my $ResId;      my $ResId;
     my $Code;      my $Code;
     my $Tries;      my $Tries;
Line 87  sub ExtractStudentData { Line 84  sub ExtractStudentData {
             '                                                        ',0,14).' ! '.              '                                                        ',0,14).' ! '.
             substr($rowlabels[$index].              substr($rowlabels[$index].
             '                                                        ',0,45).' ! ';              '                                                        ',0,45).' ! ';
     unless ($reply=~/^error\:/) {  
         map {      my($checkForError)=keys (%result);
             my ($name,$value)=split(/\=/,&Apache::lonnet::unescape($_));      if($checkForError =~ /^(con_lost|error|no_such_host)/i) {
             $result{$name}=$value;   my $PrTot = sprintf( "%5d", $ProbTotal );
         } split(/\&/,$reply);   my $PrSvd = sprintf( "%5d", $ProbSolved );
  $ProbNo = 0;   $Str .= ' '.'<font color="#000088">'.$PrSvd.'  /'.$PrTot.'</font> ';
  $ProbTotal = 0;   return $Str;
         $ProbSolved = 0;      }
  my $IterationNo = 0;  
         foreach $ResId (@cols) {      $ProbNo = 0;
     if ($IterationNo == 0) {$IterationNo++; next;}      $ProbTotal = 0;
     if (!$ResId) {       $ProbSolved = 0;
  my $PrNo = sprintf( "%3d", $ProbNo );      my $IterationNo = 0;
  $Str .= ' '.'<font color="#007700">'.$PrNo.'</font> ';      foreach $ResId (@cols) {
  $ProbSolved += $ProbNo;   if ($IterationNo == 0) {$IterationNo++; next;}
  $ProbNo=0;   if (!$ResId) { 
  next;       my $PrNo = sprintf( "%3d", $ProbNo );
     }      $Str .= ' '.'<font color="#007700">'.$PrNo.'</font> ';
             $ResId=~/(\d+)\.(\d+)/;      $ProbSolved += $ProbNo;
     my $meta=$hash{'src_'.$ResId};      $ProbNo=0;
     my $PartNo = 0;      next; 
     undef %TempHash;   }
     map {   $ResId=~/(\d+)\.(\d+)/;
  if ($_=~/^stores\_(\d+)\_tries$/) {   my $meta=$hash{'src_'.$ResId};
                     my $Part=&Apache::lonnet::metadata($meta,$_.'.part');   my $PartNo = 0;
     if ( $TempHash{"$Part"} eq '' ) {    undef %TempHash;
  $TempHash{"$Part"} = $Part;   foreach (split(/\,/,&Apache::lonnet::metadata($meta,'keys'))) {
  $TempHash{$PartNo}=$Part;      if ($_=~/^stores\_(\d+)\_tries$/) {
  $TempHash{"$Part.Code"} = ' ';     my $Part=&Apache::lonnet::metadata($meta,$_.'.part');
  $PartNo++;   if ( $TempHash{"$Part"} eq '' ) { 
     }      $TempHash{"$Part"} = $Part;
       $TempHash{$PartNo}=$Part;
       $TempHash{"$Part.Code"} = ' ';  
       $PartNo++;
  }   }
             } split(/\,/,&Apache::lonnet::metadata($meta,'keys'));      }
    }
   
             my $Prob = &Apache::lonnet::declutter( $hash{'map_id_'.$1} ).   my $Prob = &Apache::lonnet::symbclean(
          &Apache::lonnet::declutter($hash{'map_id_'.$1} ).
                        '___'.$2.'___'.                         '___'.$2.'___'.
                        &Apache::lonnet::declutter( $hash{'src_'.$ResId} );                         &Apache::lonnet::declutter( $hash{'src_'.$ResId} ));
             $Code=' ';   $Code=' ';
             $Tries = 0;   $Tries = 0;
      $LatestVersion = $result{"version:$Prob"};   $LatestVersion = $result{"version:$Prob"};
   
             if ( $LatestVersion ) {   if ( $LatestVersion ) {
  for ( my $Version=1; $Version<=$LatestVersion; $Version++ ) {      for ( my $Version=1; $Version<=$LatestVersion; $Version++ ) {
     my $vkeys = $result{"$Version:keys:$Prob"};   my $vkeys = $result{"$Version:keys:$Prob"};
     my @keys = split(/\:/,$vkeys);     my @keys = split(/\:/,$vkeys);  
   
     foreach my $Key (@keys) {     foreach my $Key (@keys) {  
  if (($Key=~/\.(\w+)\.solved$/) && ($Key!~/^\d+\:/)) {      if (($Key=~/\.(\w+)\.solved$/) && ($Key!~/^\d+\:/)) {
     my $Part = $1;   my $Part = $1;
     $Tries = $result{"$Version:$Prob:resource.$Part.tries"};   $Tries = $result{"$Version:$Prob:resource.$Part.tries"};
     $TempHash{"$Part.Tries"}=($Tries) ? $Tries : 0;   $TempHash{"$Part.Tries"}=($Tries) ? $Tries : 0;
     my $Val = $result{"$Version:$Prob:resource.$Part.solved"};   my $Val = $result{"$Version:$Prob:resource.$Part.solved"};
     if ($Val eq 'correct_by_student'){$Code='*';}    if ($Val eq 'correct_by_student'){$Code='*';} 
     elsif ($Val eq 'correct_by_override'){$Code = '+';}                           elsif ($Val eq 'correct_by_override'){$Code = '+';}
     elsif ($Val eq 'incorrect_attempted'){$Code = '.';}    elsif ($Val eq 'incorrect_attempted'){$Code = '.';} 
     elsif ($Val eq 'incorrect_by_override'){$Code = '-';}   elsif ($Val eq 'incorrect_by_override'){$Code = '-';}
     elsif ($Val eq 'excused'){$Code = 'x';}   elsif ($Val eq 'excused'){$Code = 'x';}
     elsif ($Val eq 'ungraded_attempted'){$Code = '#';}   elsif ($Val eq 'ungraded_attempted'){$Code = '#';}
     else {$Code = ' ';}   else {$Code = ' ';}
     $TempHash{"$Part.Code"} = $Code;  
  }   $TempHash{"$Part.Code"} = $Code;
          }      }
                 }   
  for ( my $n = 0; $n < $PartNo; $n++ ) {    
     my $part = $TempHash{$n};  
     my $Code = $TempHash{"$part.Code"};  
                     if ( $Code eq '*') {  
  $ProbNo++;  
                         if (($TempHash{"$part.Tries"}<10) ||  
                             ($TempHash{"$part.Tries"} eq '')) {  
     $TempHash{"$part.Code"}=$TempHash{"$part.Tries"};  
  }  
                     }  
     elsif ( $Code eq '+' ) {$ProbNo++;}  
     $Str .= $TempHash{"$part.Code"};  
     if ( $Code ne 'x' ) {$ProbTotal++;}  
  }   }
             }         }
     else {  # Actually append problem to output (all parts)
  for(my $n=0; $n<$PartNo; $n++) {      $Str.='<a href="/adm/grades?symb='.
     $Str.=' ';                  &Apache::lonnet::escape($Prob).
     $ProbTotal++;                  '&student='.$sname.'&domain='.$sdom.'&command=submission">'; 
       for ( my $n = 0; $n < $PartNo; $n++ ) {  
    my $part = $TempHash{$n};
    my $Code = $TempHash{"$part.Code"};
    if ( $Code eq '*') {
       $ProbNo++;
       if (($TempHash{"$part.Tries"}<10) ||
    ($TempHash{"$part.Tries"} eq '')) {
    $TempHash{"$part.Code"}=$TempHash{"$part.Tries"};
       }
  }   }
    elsif ( $Code eq '+' ) {$ProbNo++;}
    $Str .= $TempHash{"$part.Code"};
    if ( $Code ne 'x' ) {$ProbTotal++;}
       }
       $Str.='</a>';
    } else {
       for(my $n=0; $n<$PartNo; $n++) {
    $Str.=' ';
    $ProbTotal++;
     }      }
         }    }
     }      }
   
     my $PrTot = sprintf( "%5d", $ProbTotal );      my $PrTot = sprintf( "%5d", $ProbTotal );
     my $PrSvd = sprintf( "%5d", $ProbSolved );      my $PrSvd = sprintf( "%5d", $ProbSolved );
     $Str .= ' '.'<font color="#000088">'.$PrSvd.'  /'.$PrTot.'</font> ';      $Str .= ' '.'<font color="#000088">'.$PrSvd.'  /'.$PrTot.'</font> ';
Line 217  sub tracetable { Line 224  sub tracetable {
           }            }
        }         }
        if (defined($hash{'to_'.$rid})) {         if (defined($hash{'to_'.$rid})) {
           map {            foreach (split(/\,/,$hash{'to_'.$rid})){
               &tracetable($hash{'goesto_'.$_},$beenhere);                &tracetable($hash{'goesto_'.$_},$beenhere);
           } split(/\,/,$hash{'to_'.$rid});            }
        }         }
     }      }
 }  }
   
   sub usection {
       my ($udom,$unam,$courseid,$ActiveFlag)=@_;
       $courseid=~s/\_/\//g;
       $courseid=~s/^(\w)/\/$1/;
   
       my %result=&Apache::lonnet::dump('roles',$udom,$unam);
   
       my($checkForError)=keys (%result);
       if($checkForError =~ /^(con_lost|error|no_such_host)/i) {
    return -1;
       }
       my $cursection='-1';
       my $oldsection='-1';
       my $status='Expired';
       foreach my $key (keys (%result)) {
    my $value = $result{$key};
           if ($key=~/^$courseid(?:\/)*(\w+)*\_st$/) {
               my $section=$1;
               if ($key eq $courseid.'_st') { $section=''; }
       my ($dummy,$end,$start)=split(/\_/,$value);
       my $now=time;
       my $notactive=0;
       if ($start) { if ($now<$start) { $notactive=1; } }
       if ($end) { if ($now>$end) { $notactive=1; } }
       if ($notactive == 0) { $status='Active';$cursection=$section;}
       if ($notactive == 1) { $oldsection=$section;}
           }
       }
       if ($status eq $ActiveFlag) {
         if ($cursection eq '-1') { return $oldsection; }
         return $cursection;
       }
       if ($ActiveFlag eq 'Any') { 
         if ($cursection eq '-1') { return $oldsection; }
         return $cursection;
       }
       return '-1';
   }
   
 sub BuildChart {  sub BuildChart {
 # ----------------------- Get first and last resource, see if there is anything  # ----------------------- Get first and last resource, see if there is anything
Line 235  sub BuildChart { Line 280  sub BuildChart {
         my $chome=$ENV{'course.'.$cid.'.home'};          my $chome=$ENV{'course.'.$cid.'.home'};
         my ($cdom,$cnum)=split(/\_/,$cid);          my ($cdom,$cnum)=split(/\_/,$cid);
 # ---------------------------------------------- Read class list and row labels  # ---------------------------------------------- Read class list and row labels
  my $classlst=&Apache::lonnet::reply   my %classlist=&Apache::lonnet::dump('classlist',$cdom,$cnum);
                             ('dump:'.$cdom.':'.$cnum.':classlist',$chome);  
  my $now=time;   my($checkForError)=keys (%classlist);
  unless ($classlst=~/^error\:/) {   if($checkForError =~ /^(con_lost|error|no_such_host)/i) {
     map {      $r->print('<h1>Could not access course data</h1>');
  my ($name,$value)=split(/\=/,$_);   } else {
  my ($end,$start)=split(/\:/,&Apache::lonnet::unescape($value));      my $now=time;
       foreach my $name (sort(keys(%classlist))) {
    my $value=$classlist{$name};
    my ($end,$start)=split(/\:/,$value);
  my $active=1;   my $active=1;
  if (($end) && ($now>$end)) { $active=0; }   my $Status=$ENV{'form.status'};
    $Status = ($Status) ? $Status : 'Active';
    if ( ( ($end) && $now > $end ) && 
        ( ($Status eq 'Active') ) ) { $active=0; }
    if ( ($Status eq 'Expired') && 
        ($end == 0 || $now < $end) ) { $active=0; }
  if ($active) {   if ($active) {
     my $thisindex=$#students+1;      my $thisindex=$#students+1;
     $name=&Apache::lonnet::unescape($name);  
     $students[$thisindex]=$name;      $students[$thisindex]=$name;
     my ($sname,$sdom)=split(/\:/,$name);      my ($sname,$sdom)=split(/\:/,$name);
     $PreCol[$thisindex]=$sname.':';      $PreCol[$thisindex]=$sname.':';
     my $ssec=&Apache::lonnet::usection($sdom,$sname,$cid);      my $ssec=&usection($sdom,$sname,$cid,$Status);
     if ($ssec==-1) {      if ($ssec==-1) {
  $rowlabels[$thisindex]=   $rowlabels[$thisindex]=
     'Data not available: '.$name;      'Data not available: '.$name;
     } else {      } else {
  my %reply=&Apache::lonnet::idrget($sdom,$sname);   my %reply=&Apache::lonnet::idrget($sdom,$sname);
  my $reply=&Apache::lonnet::reply('get:'.$sdom.':'.$sname.   my %name=&Apache::lonnet::get('environment',
                                      ':environment:lastname&generation&firstname&middlename',         ['lastname','generation'
                                                  &Apache::lonnet::homeserver($sname,$sdom));         ,'firstname'
          ,'middlename'],
          $sdom,$sname);
    my $name=$name{lastname};
    if ($name{generation}) {$name.=" $name{generation}";}
    $name.=',';
    if ($name{firstname}) {$name.=" $name{firstname}";}
    if ($name{middlename}) {$name.=" $name{middlename}";}
    if ($name eq ',') {$name='';}
  #$ssec=(int($ssec)) ? int($ssec) : $ssec;   #$ssec=(int($ssec)) ? int($ssec) : $ssec;
  $rowlabels[$thisindex]=   my $sec=sprintf('%3s',$ssec);
     sprintf('%3s',$ssec).' '.$reply{$sname}.' ';   $rowlabels[$thisindex]=$sec.' '.$reply{$sname}.' ';
  $PreCol[$thisindex] .= $reply.':'.$ssec;   $PreCol[$thisindex] .= $name.':'.$sec;
  my $i=0;   $rowlabels[$thisindex].=$name.' ';
  map {  
     $i++;  
     if ( $_ ne '') {  
  $rowlabels[$thisindex].=&Apache::lonnet::unescape($_).' ';  
     }  
     if ($i == 2) {  
  chop($rowlabels[$thisindex]);  
  $rowlabels[$thisindex].=', ';  
     }  
  } split(/\&/,$reply);  
     }      }
  }   }
     } sort split(/\&/,$classlst);      }
   
  } else {  
     $r->print('<h1>Could not access course data</h1>');  
  }   }
   
  my $allstudents=$#students+1;   my $allstudents=$#students+1;
Line 306  sub BuildChart { Line 353  sub BuildChart {
 }  }
   
 sub CreateForm {  sub CreateForm {
       my $OpSel1='';
       my $OpSel2='';
       my $OpSel3='';
       my $Status = $ENV{'form.status'};
       if ( $Status eq 'Any' ) { $OpSel3='selected'; }
       elsif ($Status eq 'Expired' ) { $OpSel2 = 'selected'; }
       else { $OpSel1 = 'selected'; }
   
     my $Ptr = '<form name=stat method=post action="/adm/chart" >'."\n";      my $Ptr = '<form name=stat method=post action="/adm/chart" >'."\n";
     $Ptr .= '<b> Sort by: &nbsp; </b>'."\n";      $Ptr .= '<b> Sort by: &nbsp; </b>'."\n";
     $Ptr .= '&nbsp;&nbsp;&nbsp;';      $Ptr .= '&nbsp;&nbsp;&nbsp;';
     $Ptr .= '<input type=submit name=sort value="Email Name" />'."\n";      $Ptr .= '<input type=submit name=sort value="User Name" />'."\n";
     $Ptr .= '&nbsp;&nbsp;&nbsp;';      $Ptr .= '&nbsp;&nbsp;&nbsp;';
     $Ptr .= '<input type=submit name=sort value="Last Name" />'."\n";      $Ptr .= '<input type=submit name=sort value="Last Name" />'."\n";
     $Ptr .= '&nbsp;&nbsp;&nbsp;';      $Ptr .= '&nbsp;&nbsp;&nbsp;';
     $Ptr .= '<input type=submit name=sort value="Section"/>'."\n";      $Ptr .= '<input type=submit name=sort value="Section"/>'."\n";
     $Ptr .= '<br>';      $Ptr .= '<br><br>';
       $Ptr .= '<b> Student Status: &nbsp; </b>'."\n".
               '<select name="status">'. 
               '<option '.$OpSel1.' >Active</option>'."\n".
               '<option '.$OpSel2.' >Expired</option>'."\n".
       '<option '.$OpSel3.' >Any</option> </select> '."\n";
       $Ptr .= '&nbsp;&nbsp;&nbsp;';
     $Ptr .= '<input type=submit name=sort value="Recalculate Chart"/>'."\n";      $Ptr .= '<input type=submit name=sort value="Recalculate Chart"/>'."\n";
     $Ptr .= '</form>'."\n";      $Ptr .= '</form>'."\n";
     $r->print( $Ptr );      $r->print( $Ptr );
 }  }
   
 sub CacheChart {  sub CacheChart {
     my @list = ();      my %list = ();
     my $count=0;      my $count=0;
   
     my $Pos = $ENV{'form.sort'};      my $Pos = $ENV{'form.sort'};
Line 332  sub CacheChart { Line 393  sub CacheChart {
     foreach my $key( keys %CachData) {       foreach my $key( keys %CachData) { 
  my @Temp=split(/\:/,$key);   my @Temp=split(/\:/,$key);
  my $Use = $Temp[$Pos];   my $Use = $Temp[$Pos];
  $list[$count]=$Use.$key.'*'.$CachData{$key};   $list{$Use.$key}=$key;
  $count++;   $count++;
     }      }
   
     @list = sort (@list);      my @order = sort(keys(%list));
   
     $r->print('<h3>'.$count.' students</h3>');      $r->print('<h3>'.$count.' students</h3>');
     &CreateForm();      &CreateForm();
Line 344  sub CacheChart { Line 405  sub CacheChart {
           
     $r->print('<p><pre>');      $r->print('<p><pre>');
     for ( my $n; $n < $count; $n++) {      for ( my $n; $n < $count; $n++) {
  my ($dummy, $Line) = split(/\*/,$list[$n]);   $r->print($CachData{$list{$order[$n]}}.'<br>');
  $r->print($Line.'<br>');  
     }      }
     $r->print('</pre>');      $r->print('</pre>');
 }  }
Line 459  sub handler { Line 519  sub handler {
 }  }
 1;  1;
 __END__  __END__
   
   
   
   
   
   
   

Removed from v.1.30  
changed lines
  Added in v.1.41


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