--- loncom/homework/grades.pm 2002/06/25 21:07:56 1.31 +++ loncom/homework/grades.pm 2002/06/27 21:34:18 1.33 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # The LON-CAPA Grading handler # -# $Id: grades.pm,v 1.31 2002/06/25 21:07:56 ng Exp $ +# $Id: grades.pm,v 1.33 2002/06/27 21:34:18 ng Exp $ # # Copyright Michigan State University Board of Trustees # @@ -87,6 +87,7 @@ sub verifyreceipt { } } $request->printf('

'.$matches." match%s

",$matches <= 1 ? '' : 'es'); +# needs to print who is matched } return ''; } @@ -116,6 +117,21 @@ ENDHEADER return ''; } +sub student_gradeStatus { + my ($url,$udom,$uname) = @_; + my $symb=($ENV{'form.symb'} ne '' ? $ENV{'form.symb'} : (&Apache::lonnet::symbread($url))); + my %record= &Apache::lonnet::restore($symb,$ENV{'request.course.id'},$udom,$uname); + foreach my $part (&getpartlist($url)) { + my ($temp,$part,$type)=split(/_/,$part); + if ($type eq 'solved') { + my ($status,$foo)=split(/_/,$record{"resource.$part.$type"},2); + $status = 'nothing' if ($status eq ''); + return $type,$status; + } + } + return ''; +} + sub listStudents { my ($request) = shift; my $cdom=$ENV{"course.$ENV{'request.course.id'}.domain"}; @@ -124,11 +140,12 @@ sub listStudents { $request->print(<Show Student Submissions on Assessment -
+
- + - + + ENDTABLEST my (%classlist) = &getclasslist($cdom,$cnum,'0'); foreach my $student ( sort(@{ $classlist{'allids'} }) ) { @@ -145,7 +162,7 @@ ENDTABLEST $fullname.=$name{'firstname'}.' '.$name{'middlename'}; } if ( $Apache::grades::viewgrades eq 'F' ) { - $request->print("\n".''."". + $request->print("\n".''."". ''); if ($ENV{'form.url'}) { $request->print( @@ -167,8 +184,11 @@ ENDTABLEST ' no '. ' yes '); $request->print(''); + ' last '. + ' all '); + my ($type,$status) = &student_gradeStatus($ENV{'form.url'},$cdom,$sname); + $request->print( + ''); $request->print( ''); @@ -237,6 +257,7 @@ sub viewstudentgrade { my (@requests) = ('lastname','firstname','middlename','generation'); my (%name) = &Apache::lonnet::get('environment',\@requests,$domain,$username); my %record=&Apache::lonnet::restore($symb,$courseid,$domain,$username); + my $fullname=$name{'lastname'}.$name{'generation'}; if ($fullname =~ /[^\s]+/) { $fullname.=', '; } $fullname.=$name{'firstname'}.' '.$name{'middlename'}; @@ -252,7 +273,7 @@ sub viewstudentgrade { my ($status,$foo)=split(/_/,$score,2); $result.="
Resource: $ENV{'form.url'}
Resource: $ENV{'form.url'}
UsernameNameDomainView ProblemSubmissionsAction
View ProblemSubmissionsGrade StatusAction
$sname$fullname$sdom
$sname$fullname$sdom
'. - ' last '. - ' all '.$status.' '); $request->print('
'; + $result.='
Username: '.$uname.'Fullname: '.$ENV{'form.fullname'}.'Domain: '.$udom.'
'; $result.='
Username: '.$uname. + 'Fullname: '.$ENV{'form.fullname'}.'Domain: '.$udom.'
Resource: '.$url.'
'; # # option to display problem @@ -347,67 +414,192 @@ JAVASCRIPT $ENV{'request.course.id'}); my $companswer=&Apache::loncommon::get_student_answers($symb,$uname,$udom, $ENV{'request.course.id'}); - $result.='
'; - $result.='
'; + $result.='
'; + $result.='
'; $result.='Student\'s view of the problem
'.$rendered.'
'; $result.='Correct answer:
'.$companswer; $result.='
'; $result.='

'; } - my $last = ''; - $last = 'last' if ($ENV{'form.submission'} eq 'last'); + my $last = ($ENV{'form.lastSub'} eq 'last' ? 'last' : ''); my $answer=&Apache::loncommon::get_previous_attempt($symb,$uname,$udom, $ENV{'request.course.id'},$last); $result.=$answer; - my $maxpt = &Apache::lonnet::EXT('resource.partid.weight',$symb,$udom,$uname); + my $wgt = &Apache::lonnet::EXT('resource.partid.weight',$symb,$udom,$uname); my %record= &Apache::lonnet::restore($symb,$ENV{'request.course.id'},$udom,$uname); - my $score = $record{'resource.0.awarded'}*$maxpt; + my $score = $record{'resource.0.awarded'}*$wgt; $result.= '
'."\n". ''."\n". ''."\n". - ''."\n". - '
Points'; + ''."\n". + ''."\n". + ''."\n". + ''."\n"; + + my $counter = 0; + $result.=''. + ''."\n"; + $result.=''; - $result.=''."\n"; - $result.=''."\n"; + $result.='\n"; } } - $result.='
Points'; my $ctr = 0; - while ($ctr<=$maxpt) { - $result.= ' '.$ctr."\n"; + while ($ctr<=$wgt) { + $result.= ' '.$ctr."\n"; $ctr++; } $result.=' or /'.$maxpt.' (max pts)'; + $result.='/'.($wgt > 0 ? $wgt.' (problem weight)' : 'invalid problem weight' ). + ' '; foreach my $part (&getpartlist($url)) { my ($temp,$part,$type)=split(/_/,$part); if ($type eq 'solved') { my ($status,$foo)=split(/_/,$record{"resource.$part.$type"},2); - $result.="'."\n"; my $optsel = ''. ''. - ''."\n"; + ''."\n"; $status = 'nothing' if ($status eq ''); $optsel =~ s/
The buttons do not work yet. '; + + $result.='
'; + my $ntstu =''."\n"; + my $nsel = ($ENV{'form.NTSTU'} ne '' ? $ENV{'form.NTSTU'} : '1'); + $ntstu =~ s/
'; return $result; } +sub processHandGrade { + my ($request) = @_; + my $result=''; + + my $url = $ENV{'form.url'}; + my $symb = $ENV{'form.symb'}; + my $button = $ENV{'form.gradeOpt'}; + my $ngrade = $ENV{'form.NCT'}; + my $ntstu = $ENV{'form.NTSTU'}; + my $vProb = $ENV{'form.vProb'}; + my $lastSub= $ENV{'form.lastSub'}; + + my (@parts) = sort(&getpartlist($url)); + if ($button eq 'Save & Next') { + my $ctr = 0; + while ($ctr < $ENV{'form.NCT'}) { + my $pts = ($ENV{'form.GRADE_BOX'.$ctr} ne '' ? $ENV{'form.GRADE_BOX'.$ctr} : $ENV{'form.RADVAL'.$ctr}); + my $wgt = $ENV{'form.WGT'.$ctr}; + my $sel = $ENV{'form.GRADE_SEL'.$ctr}; + my $score = $pts/$wgt if ($wgt != 0); + my ($uname,$udom) = split(/:/,$ENV{'form.unamedom'.$ctr}); + &saveHandGrade($url,$symb,$uname,$udom,$score,@parts); + $ctr++; + } + } + my $firststu = $ENV{'form.unamedom0'}; + my $laststu = $ENV{'form.unamedom'.($ngrade-1)}; + + #get classlist + my ($cdom,$cnum) = split(/_/,$ENV{'request.course.id'}); + my (%classlist) = &getclasslist($cdom,$cnum,'0'); + + my (@nextlist,@prevlist); + my ($nextflg,$prevflg,$ctr) = (0,0,0); + foreach my $student ( sort(@{ $classlist{'allids'} }) ) { + my ($uname,$udom) = split(/:/,$student); + if ($nextflg == 1 && $button =~ /Next$/) { + push @nextlist,$uname if ($ctr < $ENV{'form.NTSTU'}); + $ctr++; + } + $nextflg = 1 if ($student eq $laststu); + $prevflg = 1 if ($student eq $firststu); + } + foreach my $student (@nextlist) { + $ENV{'form.student'} = $student; + $request->print(&submission($request)); + } + $request->print ("

Grading

"); + + #get info for each student + foreach my $student ( sort(@{ $classlist{'allids'} }) ) { + my $display=&viewstudentgrade($url,$symb,$ENV{'request.course.id'},$student,@parts); + print "ID=$ENV{'request.course.id'}:STU=$student:DIS=$display:
\n"; +# $result.=&viewstudentgrade($url,$symb,$ENV{'request.course.id'},$student,@parts); + } + + return 'The End'; +# return $result; +} + +sub saveHandGrade { + my ($url,$symb,$stuname,$domain,$newscore,@parts) = @_; + +# my ($stuname,$domain) = split(/:/,$student); + my %record=&Apache::lonnet::restore($symb,$ENV{'request.course.id'},$domain,$stuname); + my %newrecord; + + foreach my $part (@parts) { + my ($temp,$part,$type)=split(/_/,$part); + my $oldscore=$record{"resource.$part.$type"}; + if ($type eq 'solved') { + my $update=0; + if ($newscore eq 'nothing' ) { + if ($oldscore ne '') { + $update=1; + $newscore = ''; + } + } elsif ($oldscore !~ m/^$newscore/) { + $update=1; + if ($newscore eq 'correct') { $newscore = 'correct_by_override'; } + if ($newscore eq 'incorrect') { $newscore = 'incorrect_by_override'; } + if ($newscore eq 'excused') { $newscore = 'excused'; } + if ($newscore eq 'ungraded') { $newscore = 'ungraded_attempted'; } + if ($newscore eq 'partial') { $newscore = 'partial_correct'; } + } + if ($update) { $newrecord{"resource.$part.$type"}=$newscore; } + } else { + if ($oldscore ne $newscore) { + $newrecord{"resource.$part.$type"}=$newscore; + } + } + if ( scalar(keys(%newrecord)) > 0 ) { + $newrecord{'resource.regrader'}="$ENV{'user.name'}:$ENV{'user.domain'}"; +# print "grader=$newrecord{'resource.regrader'}:
records
"; +# while (my ($k,$v) = each %newrecord) { +# print "k=$k:v=$v:
\n"; +# } +# &Apache::lonnet::cstore(\%newrecord,$symb,$courseid,$domain,$stuname); + } + return ''; + } +} + sub get_symb_and_url { my ($request) = @_; my $url=$ENV{'form.url'}; $url=~s-^http://($ENV{'SERVER_NAME'}|$ENV{'HTTP_HOST'})--; - my $symb=$ENV{'form.symb'}; - if (!$symb) { $symb=&Apache::lonnet::symbread($url); } +# my $symb=$ENV{'form.symb'}; +# if (!$symb) { $symb=&Apache::lonnet::symbread($url); } + my $symb=($ENV{'form.symb'} ne '' ? $ENV{'form.symb'} : (&Apache::lonnet::symbread($url))); if ($symb eq '') { $request->print("Unable to handle ambiguous references:$url:."); return ''; } return ($symb,$url); } @@ -440,7 +632,7 @@ sub gradingmenu { if (!$symb) {return '';} my $result='

 Select a Grading Method


'; - $result.='
'."\n"; + $result.='
'."\n"; $result.=''."\n"; $result.='
'."\n"; $result.=' Resource : '.$url.'
'."\n"; @@ -493,7 +685,7 @@ sub viewgrades { ''."\n". ''."\n". ''."\n". - '
'."\n". + '
'."\n". ''."\n". ''."\n"; foreach my $part (@parts) { @@ -868,6 +1060,8 @@ sub handler { $request->print(&gradingmenu($request)); } elsif ($command eq 'viewgrades') { $request->print(&viewgrades($request)); + } elsif ($command eq 'handgrade') { + $request->print(&processHandGrade($request)); } elsif ($command eq 'editgrades') { $request->print(&editgrades($request)); } elsif ($command eq 'verify') {
UsernameNameDomain