version 1.12, 2001/11/22 17:25:30
|
version 1.29, 2002/02/06 16:59:50
|
Line 1
|
Line 1
|
# The LearningOnline Network with CAPA |
# The LearningOnline Network with CAPA |
|
# (Publication Handler |
|
# |
|
# $Id$ |
|
# |
|
# Copyright Michigan State University Board of Trustees |
|
# |
|
# This file is part of the LearningOnline Network with CAPA (LON-CAPA). |
|
# |
|
# LON-CAPA is free software; you can redistribute it and/or modify |
|
# it under the terms of the GNU General Public License as published by |
|
# the Free Software Foundation; either version 2 of the License, or |
|
# (at your option) any later version. |
|
# |
|
# LON-CAPA is distributed in the hope that it will be useful, |
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
# GNU General Public License for more details. |
|
# |
|
# You should have received a copy of the GNU General Public License |
|
# along with LON-CAPA; if not, write to the Free Software |
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
# |
|
# /home/httpd/html/adm/gpl.txt |
|
# |
|
# http://www.lon-capa.org/ |
|
# |
|
# |
# Homework Performance Chart |
# Homework Performance Chart |
# |
# |
# (Navigate Maps Handler |
# (Navigate Maps Handler |
Line 6
|
Line 33
|
# (Page Handler |
# (Page Handler |
# |
# |
# (TeX Content Handler |
# (TeX Content Handler |
# |
# YEAR=2000 |
# 05/29/00,05/30 Gerd Kortemeyer) |
# 05/29/00,05/30 Gerd Kortemeyer) |
# 08/30,08/31,09/06,09/14,09/15,09/16,09/19,09/20,09/21,09/23, |
# 08/30,08/31,09/06,09/14,09/15,09/16,09/19,09/20,09/21,09/23, |
# 10/02,10/10,10/14,10/16,10/18,10/19,10/31,11/6,11/14,11/16 Gerd Kortemeyer) |
# 10/02,10/10,10/14,10/16,10/18,10/19,10/31,11/6,11/14,11/16 Gerd Kortemeyer) |
# |
# YEAR=2001 |
# 3/1/1,6/1,17/1,29/1,30/1 Gerd Kortemeyer) |
# 3/1/1,6/1,17/1,29/1,30/1,31/1 Gerd Kortemeyer) |
# |
|
# 1/31 Gerd Kortemeyer |
|
# |
|
# 7/10/01 Behrouz Minaei |
# 7/10/01 Behrouz Minaei |
# 9/8 Gerd Kortemeyer |
# 9/8 Gerd Kortemeyer |
# 10/18/01, 10/19/01 Behrouz Minaei |
# 10/1, 10/19, 11/17, 11/22, 11/24, 11/28 12/18 Behrouz Minaei |
# 11/17/01, 11/22/01 Behrouz Minaei |
# YEAR=2002 |
|
# 2/1 Behrouz Minaei |
|
# |
|
### |
|
|
package Apache::lonchart; |
package Apache::lonchart; |
|
|
use strict; |
use strict; |
use Apache::Constants qw(:common :http); |
use Apache::Constants qw(:common :http); |
use Apache::lonnet(); |
use Apache::lonnet(); |
|
use Apache::loncommon(); |
use HTML::TokeParser; |
use HTML::TokeParser; |
use GDBM_File; |
use GDBM_File; |
|
|
Line 33 my %hash;
|
Line 61 my %hash;
|
my @cols; |
my @cols; |
my @rowlabels; |
my @rowlabels; |
my @students; |
my @students; |
my $r; |
|
|
|
# ------------------------------------------------------------- Find out status |
# ------------------------------------------------------------- Find out status |
|
|
Line 50 sub ExtractStudentData {
|
Line 77 sub ExtractStudentData {
|
my %TempHash; |
my %TempHash; |
my $Version; |
my $Version; |
my $ProbNo; |
my $ProbNo; |
my $PrTotal; |
my $ProbSolved; |
my $LatestVersion; |
my $ProbTotal; |
|
my $LatestVersion; |
my $Str=substr($students[$index]. |
my $Str=substr($students[$index]. |
' ',0,14).' ! '. |
' ',0,14).' ! '. |
substr($rowlabels[$index]. |
substr($rowlabels[$index]. |
Line 63 sub ExtractStudentData {
|
Line 90 sub ExtractStudentData {
|
$result{$name}=$value; |
$result{$name}=$value; |
} split(/\&/,$reply); |
} split(/\&/,$reply); |
$ProbNo = 0; |
$ProbNo = 0; |
$PrTotal = 0; |
$ProbTotal = 0; |
|
$ProbSolved = 0; |
my $IterationNo = 0; |
my $IterationNo = 0; |
foreach $ResId (@cols) { |
foreach $ResId (@cols) { |
if ($IterationNo == 0) {$IterationNo++; next;} |
if ($IterationNo == 0) {$IterationNo++; next;} |
if (!$ResId) { |
if (!$ResId) { |
my $PrNo = sprintf( "%3d", $ProbNo ); |
my $PrNo = sprintf( "%3d", $ProbNo ); |
$Str .= ' '.'<font color="#007700">'.$PrNo.'</font> '; |
$Str .= ' '.'<font color="#007700">'.$PrNo.'</font> '; |
$PrTotal += $ProbNo; |
$ProbSolved += $ProbNo; |
$ProbNo=0; |
$ProbNo=0; |
next; |
next; |
} |
} |
Line 96 sub ExtractStudentData {
|
Line 124 sub ExtractStudentData {
|
$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; |
$TempHash{"$Part.Tries"} = $result{"$Version:$Prob:resource.$Part.tries"}; |
|
$Tries = $result{"$Version:$Prob:resource.$Part.tries"}; |
$Tries = $result{"$Version:$Prob:resource.$Part.tries"}; |
my $Val = $result{"$Version:$Prob:$Key"}; |
$TempHash{"$Part.Tries"}=($Tries) ? $Tries : 0; |
|
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 = '#';} |
|
else {$Code = ' ';} |
$TempHash{"$Part.Code"} = $Code; |
$TempHash{"$Part.Code"} = $Code; |
} |
} |
} |
} |
} |
} |
|
|
for ( my $n = 0; $n < $PartNo; $n++ ) { |
for ( my $n = 0; $n < $PartNo; $n++ ) { |
my $part = $TempHash{$n}; |
my $part = $TempHash{$n}; |
if ($TempHash{$part.'.Code'} eq '*') { |
my $Code = $TempHash{"$part.Code"}; |
|
if ( $Code eq '*') { |
$ProbNo++; |
$ProbNo++; |
if ($TempHash{$part.'.Tries'}<10) { |
if (($TempHash{"$part.Tries"}<10) || |
$TempHash{$part.'.Code'}=$Tries; |
($TempHash{"$part.Tries"} eq '')) { |
|
$TempHash{"$part.Code"}=$TempHash{"$part.Tries"}; |
} |
} |
} |
} |
$Str .= $TempHash{$part.'.Code'}; |
elsif ( $Code eq '+' ) {$ProbNo++;} |
|
$Str .= $TempHash{"$part.Code"}; |
|
if ( $Code ne 'x' ) {$ProbTotal++;} |
} |
} |
} |
} |
else {for(my $n=0; $n<$PartNo; $n++) {$Str.=' ';}} |
else { |
|
for(my $n=0; $n<$PartNo; $n++) { |
|
$Str.=' '; |
|
$ProbTotal++; |
|
} |
|
} |
} |
} |
} |
} |
my $PrTot = sprintf( "%5d", $PrTotal ); |
my $PrTot = sprintf( "%5d", $ProbTotal ); |
$Str .= ' '.'<font color="#000088">'.$PrTot.'</font> '; |
my $PrSvd = sprintf( "%5d", $ProbSolved ); |
|
$Str .= ' '.'<font color="#000088">'.$PrSvd.' /'.$PrTot.'</font> '; |
|
|
return $Str ; |
return $Str ; |
} |
} |
Line 184 sub tracetable {
|
Line 224 sub tracetable {
|
# ================================================================ Main Handler |
# ================================================================ Main Handler |
|
|
sub handler { |
sub handler { |
$r=shift; |
|
|
undef %hash; |
|
undef @students; |
|
undef @cols; |
|
undef @rowlabels; |
|
|
|
my $r=shift; |
|
|
if (&Apache::lonnet::allowed('vgr',$ENV{'request.course.id'})) { |
if (&Apache::lonnet::allowed('vgr',$ENV{'request.course.id'})) { |
# ------------------------------------------- Set document type for header only |
# ------------------------------------------- Set document type for header only |
Line 195 sub handler {
|
Line 241 sub handler {
|
} else { |
} else { |
$r->content_type('text/html'); |
$r->content_type('text/html'); |
} |
} |
|
&Apache::loncommon::no_cache($r); |
$r->send_http_header; |
$r->send_http_header; |
return OK; |
return OK; |
} |
} |
Line 231 sub handler {
|
Line 278 sub handler {
|
" +: correct by override\n". |
" +: correct by override\n". |
" -: incorrect by override\n". |
" -: incorrect by override\n". |
" .: incorrect attempted\n". |
" .: incorrect attempted\n". |
|
" #: ungraded attempted\n". |
" : not attempted\n". |
" : not attempted\n". |
" x: excused</pre><p>"); |
" x: excused</pre><p>"); |
|
|
Line 252 sub handler {
|
Line 300 sub handler {
|
|
|
# ---------------------------------------------- Read class list and row labels |
# ---------------------------------------------- Read class list and row labels |
|
|
undef @rowlabels; |
|
undef @students; |
|
|
|
my $classlst=&Apache::lonnet::reply |
my $classlst=&Apache::lonnet::reply |
('dump:'.$cdom.':'.$cnum.':classlist',$chome); |
('dump:'.$cdom.':'.$cnum.':classlist',$chome); |
my $now=time; |
my $now=time; |
Line 278 sub handler {
|
Line 323 sub handler {
|
my $reply=&Apache::lonnet::reply('get:'.$sdom.':'.$sname. |
my $reply=&Apache::lonnet::reply('get:'.$sdom.':'.$sname. |
':environment:lastname&generation&firstname&middlename', |
':environment:lastname&generation&firstname&middlename', |
&Apache::lonnet::homeserver($sname,$sdom)); |
&Apache::lonnet::homeserver($sname,$sdom)); |
|
|
|
#$ssec=(int($ssec)) ? int($ssec) : $ssec; |
|
|
$rowlabels[$thisindex]= |
$rowlabels[$thisindex]= |
sprintf('%3s',$ssec).' '.$reply{$sname}.' '; |
sprintf('%3s',$ssec).' '.$reply{$sname}.' '; |
my $i=0; |
my $i=0; |