version 1.53, 2002/10/02 21:24:35
|
version 1.54, 2002/10/04 06:22:12
|
Line 51 sub getpartlist {
|
Line 51 sub getpartlist {
|
my @parts =(); |
my @parts =(); |
my (@metakeys) = split(/,/,&Apache::lonnet::metadata($url,'keys')); |
my (@metakeys) = split(/,/,&Apache::lonnet::metadata($url,'keys')); |
foreach my $key (@metakeys) { |
foreach my $key (@metakeys) { |
if ( $key =~ m/stores_([0-9]+)_.*/) { |
if ( $key =~ m/stores_(\w+)_.*/) { |
push(@parts,$key); |
push(@parts,$key); |
} |
} |
} |
} |
Line 91 sub response_type {
|
Line 91 sub response_type {
|
my %seen = (); |
my %seen = (); |
my (@partlist,%handgrade); |
my (@partlist,%handgrade); |
foreach (split(/,/,&Apache::lonnet::metadata($url,'packages'))) { |
foreach (split(/,/,&Apache::lonnet::metadata($url,'packages'))) { |
if (/^\w+response_\d+.*/) { |
if (/^\w+response_\w+.*/) { |
my ($responsetype,$part) = split(/_/,$_,2); |
my ($responsetype,$part) = split(/_/,$_,2); |
my ($partid,$respid) = split(/_/,$part); |
my ($partid,$respid) = split(/_/,$part); |
$handgrade{$part} = $responsetype.':'.($allkeys =~ /parameter_$part\_handgrade/ ? 'yes' : 'no'); |
$handgrade{$part} = $responsetype.':'.($allkeys =~ /parameter_$part\_handgrade/ ? 'yes' : 'no'); |
Line 1441 sub viewgrades_js {
|
Line 1441 sub viewgrades_js {
|
for (i=0;i<document.classgrade.total.value;i++) { |
for (i=0;i<document.classgrade.total.value;i++) { |
var user = eval("document.classgrade.ctr"+i+".value"); |
var user = eval("document.classgrade.ctr"+i+".value"); |
var scorename = eval("document.classgrade.GD_"+user+ |
var scorename = eval("document.classgrade.GD_"+user+ |
"_"+partid+"_aw"); |
"_"+partid+"_awarded"); |
var saveval = eval("document.classgrade.GD_"+user+ |
var saveval = eval("document.classgrade.GD_"+user+ |
"_"+partid+"_sv_s.value"); |
"_"+partid+"_solved_s.value"); |
var selname = eval("document.classgrade.GD_"+user+"_"+partid+"_sv"); |
var selname = eval("document.classgrade.GD_"+user+"_"+partid+"_solved"); |
if (saveval != "correct") { |
if (saveval != "correct") { |
scorename.value = point; |
scorename.value = point; |
if (selname[0].selected != true) { |
if (selname[0].selected != true) { |
Line 1470 sub viewgrades_js {
|
Line 1470 sub viewgrades_js {
|
for (i=0;i<document.classgrade.total.value;i++) { |
for (i=0;i<document.classgrade.total.value;i++) { |
var user = eval("document.classgrade.ctr"+i+".value"); |
var user = eval("document.classgrade.ctr"+i+".value"); |
var scorename = eval("document.classgrade.GD_"+user+ |
var scorename = eval("document.classgrade.GD_"+user+ |
"_"+partid+"_aw"); |
"_"+partid+"_awarded"); |
var saveval = eval("document.classgrade.GD_"+user+ |
var saveval = eval("document.classgrade.GD_"+user+ |
"_"+partid+"_sv_s.value"); |
"_"+partid+"_solved_s.value"); |
var selname = eval("document.classgrade.GD_"+user+ |
var selname = eval("document.classgrade.GD_"+user+ |
"_"+partid+"_sv"); |
"_"+partid+"_solved"); |
if (saveval != "correct") { |
if (saveval != "correct") { |
scorename.value = ""; |
scorename.value = ""; |
selname[1].selected = true; |
selname[1].selected = true; |
Line 1484 sub viewgrades_js {
|
Line 1484 sub viewgrades_js {
|
for (i=0;i<document.classgrade.total.value;i++) { |
for (i=0;i<document.classgrade.total.value;i++) { |
var user = eval("document.classgrade.ctr"+i+".value"); |
var user = eval("document.classgrade.ctr"+i+".value"); |
var scorename = eval("document.classgrade.GD_"+user+ |
var scorename = eval("document.classgrade.GD_"+user+ |
"_"+partid+"_aw"); |
"_"+partid+"_awarded"); |
var saveval = eval("document.classgrade.GD_"+user+ |
var saveval = eval("document.classgrade.GD_"+user+ |
"_"+partid+"_sv_s.value"); |
"_"+partid+"_solved_s.value"); |
var selname = eval("document.classgrade.GD_"+user+ |
var selname = eval("document.classgrade.GD_"+user+ |
"_"+partid+"_sv"); |
"_"+partid+"_solved"); |
if (saveval != "correct") { |
if (saveval != "correct") { |
scorename.value = eval("document.classgrade.GD_"+user+ |
scorename.value = eval("document.classgrade.GD_"+user+ |
"_"+partid+"_aw_s.value");; |
"_"+partid+"_awarded_s.value");; |
selname[0].selected = true; |
selname[0].selected = true; |
} |
} |
} |
} |
Line 1499 sub viewgrades_js {
|
Line 1499 sub viewgrades_js {
|
} |
} |
|
|
function changeSelect(partid,user) { |
function changeSelect(partid,user) { |
var selval = eval("document.classgrade.GD_"+user+'_'+partid+"_sv"); |
var selval = eval("document.classgrade.GD_"+user+'_'+partid+"_solved"); |
var textbox = eval("document.classgrade.GD_"+user+'_'+partid+"_aw"); |
var textbox = eval("document.classgrade.GD_"+user+'_'+partid+"_awarded"); |
var point = textbox.value; |
var point = textbox.value; |
var weight = eval("document.classgrade.weight_"+partid+".value"); |
var weight = eval("document.classgrade.weight_"+partid+".value"); |
|
|
Line 1521 sub viewgrades_js {
|
Line 1521 sub viewgrades_js {
|
} |
} |
|
|
function changeOneScore(partid,user) { |
function changeOneScore(partid,user) { |
var selval = eval("document.classgrade.GD_"+user+'_'+partid+"_sv"); |
var selval = eval("document.classgrade.GD_"+user+'_'+partid+"_solved"); |
if (selval[1].selected) { |
if (selval[1].selected) { |
var boxval = eval("document.classgrade.GD_"+user+'_'+partid+"_aw"); |
var boxval = eval("document.classgrade.GD_"+user+'_'+partid+"_awarded"); |
boxval.value = ""; |
boxval.value = ""; |
} |
} |
} |
} |
Line 1544 sub viewgrades_js {
|
Line 1544 sub viewgrades_js {
|
for (i=0;i<document.classgrade.total.value;i++) { |
for (i=0;i<document.classgrade.total.value;i++) { |
var user = eval("document.classgrade.ctr"+i+".value"); |
var user = eval("document.classgrade.ctr"+i+".value"); |
var resetscore = eval("document.classgrade.GD_"+user+ |
var resetscore = eval("document.classgrade.GD_"+user+ |
"_"+partid+"_aw"); |
"_"+partid+"_awarded"); |
resetscore.value = eval("document.classgrade.GD_"+user+ |
resetscore.value = eval("document.classgrade.GD_"+user+ |
"_"+partid+"_aw_s.value"); |
"_"+partid+"_awarded_s.value"); |
|
|
var saveselval = eval("document.classgrade.GD_"+user+ |
var saveselval = eval("document.classgrade.GD_"+user+ |
"_"+partid+"_sv_s.value"); |
"_"+partid+"_solved_s.value"); |
|
|
var selname = eval("document.classgrade.GD_"+user+"_"+partid+"_sv"); |
var selname = eval("document.classgrade.GD_"+user+"_"+partid+"_solved"); |
if (saveselval == "excused") { |
if (saveselval == "excused") { |
if (selname[1].selected == false) { selname[1].selected = true;} |
if (selname[1].selected == false) { selname[1].selected = true;} |
} else { |
} else { |
Line 1608 sub viewgrades {
|
Line 1608 sub viewgrades {
|
$result.='<table border="0">'; |
$result.='<table border="0">'; |
my %seen = (); |
my %seen = (); |
for (sort keys(%$handgrade)) { |
for (sort keys(%$handgrade)) { |
my ($partid,$respid) = split (/_/); |
my ($partid,$respid) = split (/_/,$_,2); |
next if $seen{$partid}; |
next if $seen{$partid}; |
$seen{$partid}++; |
$seen{$partid}++; |
my ($responsetype,$handgrade)=split(/:/,$$handgrade{$_}); |
my ($responsetype,$handgrade)=split(/:/,$$handgrade{$_}); |
Line 1624 sub viewgrades {
|
Line 1624 sub viewgrades {
|
my $ctr = 0; |
my $ctr = 0; |
while ($ctr<=$weight{$partid}) { # display radio buttons in a nice table 10 across |
while ($ctr<=$weight{$partid}) { # display radio buttons in a nice table 10 across |
$result.= '<td><input type="radio" name="RADVAL_'.$partid.'" '. |
$result.= '<td><input type="radio" name="RADVAL_'.$partid.'" '. |
'onclick="javascript:writePoint('.$partid.','.$weight{$partid}. |
'onclick="javascript:writePoint(\''.$partid.'\','.$weight{$partid}. |
','.$ctr.')" />'.$ctr."</td>\n"; |
','.$ctr.')" />'.$ctr."</td>\n"; |
$result.=(($ctr+1)%10 == 0 ? '</tr><tr>' : ''); |
$result.=(($ctr+1)%10 == 0 ? '</tr><tr>' : ''); |
$ctr++; |
$ctr++; |
} |
} |
$result.='</tr></table>'; |
$result.='</tr></table>'; |
$result.= '</td><td><b> or </b><input type="text" name="TEXTVAL_'. |
$result.= '</td><td><b> or </b><input type="text" name="TEXTVAL_'. |
$partid.'" size="4" '. |
$partid.'" size="4" '.'onChange="javascript:writePoint(\''. |
'onChange="javascript:writePoint('.$partid.','.$weight{$partid}. |
$partid.'\','.$weight{$partid}.',\'textval\')" /> /'. |
',\'textval\')" /> /'. |
|
$weight{$partid}.' (problem weight)</td>'."\n"; |
$weight{$partid}.' (problem weight)</td>'."\n"; |
$result.= '</td><td><select name="SELVAL_'.$partid.'"'. |
$result.= '</td><td><select name="SELVAL_'.$partid.'"'. |
'onChange="javascript:writeRadText('.$partid.','.$weight{$partid}.')" /> '. |
'onChange="javascript:writeRadText(\''.$partid.'\','. |
|
$weight{$partid}.')" /> '. |
'<option selected="on"> </option>'. |
'<option selected="on"> </option>'. |
'<option>excused</option></select></td></tr>'."\n"; |
'<option>excused</option></select></td></tr>'."\n"; |
$ctsparts++; |
$ctsparts++; |
Line 1664 sub viewgrades {
|
Line 1664 sub viewgrades {
|
my (@parts) = sort(&getpartlist($url)); |
my (@parts) = sort(&getpartlist($url)); |
foreach my $part (@parts) { |
foreach my $part (@parts) { |
my $display=&Apache::lonnet::metadata($url,$part.'.display'); |
my $display=&Apache::lonnet::metadata($url,$part.'.display'); |
next if ($display =~ /^Number of Attempts/); |
|
if (!$display) { $display = &Apache::lonnet::metadata($url,$part.'.name'); } |
if (!$display) { $display = &Apache::lonnet::metadata($url,$part.'.name'); } |
if ($display =~ /^Partial Credit Factor/) { |
if ($display =~ /^Partial Credit Factor/) { |
$_ = $display; |
my ($partid) = &split_part_type($part); |
my ($partid) = /.*?(\d+).*/; |
|
$result.='<td><b>Score Part '.$partid.'<br />(weight = '. |
$result.='<td><b>Score Part '.$partid.'<br />(weight = '. |
$weight{$partid}.')</b></td>'."\n"; |
$weight{$partid}.')</b></td>'."\n"; |
next; |
next; |
Line 1707 sub viewstudentgrade {
|
Line 1705 sub viewstudentgrade {
|
'\')"; TARGET=_self>'.$fullname.'</a>'. |
'\')"; TARGET=_self>'.$fullname.'</a>'. |
'</td><td>'.$uname.'</td><td align="middle">'.$udom.'</td>'."\n"; |
'</td><td>'.$uname.'</td><td align="middle">'.$udom.'</td>'."\n"; |
foreach my $part (@$parts) { |
foreach my $part (@$parts) { |
my ($temp,$part,$type)=split(/_/,$part); |
my ($part,$type) = &split_part_type($part); |
my $score=$record{"resource.$part.$type"}; |
my $score=$record{"resource.$part.$type"}; |
next if $type eq 'tries'; |
|
if ($type eq 'awarded') { |
if ($type eq 'awarded') { |
my $pts = $score eq '' ? '' : $score*$$weight{$part}; |
my $pts = $score eq '' ? '' : $score*$$weight{$part}; |
$result.='<input type="hidden" name="'. |
$result.='<input type="hidden" name="'. |
'GD_'.$uname.'_'.$part.'_aw_s" value="'.$pts.'" />'."\n"; |
'GD_'.$uname.'_'.$part.'_awarded_s" value="'.$pts.'" />'."\n"; |
$result.='<td align="middle"><input type="text" name="'. |
$result.='<td align="middle"><input type="text" name="'. |
'GD_'.$uname.'_'.$part.'_aw" '. |
'GD_'.$uname.'_'.$part.'_awarded" '. |
'onChange="javascript:changeSelect('.$part.',\''.$uname. |
'onChange="javascript:changeSelect(\''.$part.'\',\''.$uname. |
'\')" value="'.$pts.'" size="4" /></td>'."\n"; |
'\')" value="'.$pts.'" size="4" /></td>'."\n"; |
} elsif ($type eq 'solved') { |
} elsif ($type eq 'solved') { |
my ($status,$foo)=split(/_/,$score,2); |
my ($status,$foo)=split(/_/,$score,2); |
$status = 'nothing' if ($status eq ''); |
$status = 'nothing' if ($status eq ''); |
$result.='<input type="hidden" name="'. |
$result.='<input type="hidden" name="'.'GD_'.$uname.'_'. |
'GD_'.$uname.'_'.$part.'_sv_s" value="'.$status.'" />'."\n"; |
$part.'_solved_s" value="'.$status.'" />'."\n"; |
$result.='<td align="middle"><select name="'. |
$result.='<td align="middle"><select name="'. |
'GD_'.$uname.'_'.$part.'_sv" '. |
'GD_'.$uname.'_'.$part.'_solved" '. |
'onChange="javascript:changeOneScore('.$part.',\''.$uname.'\')" >'."\n"; |
'onChange="javascript:changeOneScore(\''.$part.'\',\''.$uname.'\')" >'."\n"; |
my $optsel = '<option selected="on"> </option><option>excused</option>'."\n"; |
my $optsel = '<option selected="on"> </option><option>excused</option>'."\n"; |
$optsel = '<option> </option><option selected="on">excused</option>'."\n" |
$optsel = '<option> </option><option selected="on">excused</option>'."\n" |
if ($status eq 'excused'); |
if ($status eq 'excused'); |
$result.=$optsel; |
$result.=$optsel; |
$result.="</select></td>\n"; |
$result.="</select></td>\n"; |
|
} else { |
|
$result.='<input type="hidden" name="'. |
|
'GD_'.$uname.'_'.$part.'_'.$type.'_s" value="'.$score.'" />'. |
|
"\n"; |
|
$result.='<td align="middle"><input type="text" name="'. |
|
'GD_'.$uname.'_'.$part.'_'.$type.'" '. |
|
'value="'.$score.'" size="4" /></td>'."\n"; |
} |
} |
} |
} |
$result.='</tr>'; |
$result.='</tr>'; |
Line 1763 sub editgrades {
|
Line 1767 sub editgrades {
|
|
|
my (@partid); |
my (@partid); |
my %weight = (); |
my %weight = (); |
|
my %columns = (); |
my ($i,$ctr,$count,$rec_update) = (0,0,0,0); |
my ($i,$ctr,$count,$rec_update) = (0,0,0,0); |
|
|
|
my (@parts) = sort(&getpartlist($url)); |
|
my $header; |
while ($ctr < $ENV{'form.totalparts'}) { |
while ($ctr < $ENV{'form.totalparts'}) { |
my $partid = $ENV{'form.partid_'.$ctr}; |
my $partid = $ENV{'form.partid_'.$ctr}; |
push @partid,$partid; |
push @partid,$partid; |
$weight{$partid} = $ENV{'form.weight_'.$partid}; |
$weight{$partid} = $ENV{'form.weight_'.$partid}; |
$ctr++; |
$ctr++; |
$result .= '<td colspan = 2 align="center"><b>Part '.$partid. |
|
'</b> (Weight = '.$weight{$partid}.')</td>'; |
|
} |
} |
$result .= '</tr><tr bgcolor="#deffff">'; |
foreach my $partid (@partid) { |
foreach (@partid) { |
$header .= '<td align="center"> <b>Old Score</b> </td>'. |
$result .= '<td align="center"> <b>Old Score</b> </td>'. |
|
'<td align="center"> <b>New Score</b> </td>'; |
'<td align="center"> <b>New Score</b> </td>'; |
|
$columns{$partid}=2; |
|
foreach my $stores (@parts) { |
|
my ($part,$type) = &split_part_type($stores); |
|
if ($part !~ m/^\Q$partid\E/) { next;} |
|
if ($type eq 'awarded' || $type eq 'solved') { next; } |
|
my $display=&Apache::lonnet::metadata($url,$stores.'.display'); |
|
$display =~ s/\[Part: (\w)+\]//; |
|
$header .= '<td align="center"> <b>Old</b> '.$display.' </td>'. |
|
'<td align="center"> <b>New</b> '.$display.' </td>'; |
|
$columns{$partid}+=2; |
|
} |
} |
} |
|
foreach my $partid (@partid) { |
|
$result .= '<td colspan="'.$columns{$partid}. |
|
'" align="center"><b>Part '.$partid. |
|
'</b> (Weight = '.$weight{$partid}.')</td>'; |
|
|
|
} |
|
$result .= '</tr><tr bgcolor="#deffff">'; |
|
$result .= $header; |
$result .= '</tr>'."\n"; |
$result .= '</tr>'."\n"; |
|
|
for ($i=0; $i<$ENV{'form.total'}; $i++) { |
for ($i=0; $i<$ENV{'form.total'}; $i++) { |
Line 1784 sub editgrades {
|
Line 1808 sub editgrades {
|
my %newrecord; |
my %newrecord; |
my $updateflag = 0; |
my $updateflag = 0; |
my @userdom = grep /^$user:/,keys %$classlist; |
my @userdom = grep /^$user:/,keys %$classlist; |
my ($foo,$udom) = split(/:/,$userdom[0]); |
my (undef,$udom) = split(/:/,$userdom[0]); |
|
|
$result .= '<tr bgcolor="#ffffde"><td>'.$user.' </td><td>'. |
$result .= '<tr bgcolor="#ffffde"><td>'.$user.' </td><td>'. |
$$fullname{$userdom[0]}.' </td>'; |
$$fullname{$userdom[0]}.' </td>'; |
|
|
foreach (@partid) { |
foreach (@partid) { |
my $old_aw = $ENV{'form.GD_'.$user.'_'.$_.'_aw_s'}; |
my $old_aw = $ENV{'form.GD_'.$user.'_'.$_.'_awarded_s'}; |
my $old_part = $old_aw eq '' ? '' : $old_aw/$weight{$_}; |
my $old_part_pcr = $old_aw/($weight{$_} ne '0' ? $weight{$_}:1); |
my $old_score = $scoreptr{$ENV{'form.GD_'.$user.'_'.$_.'_sv_s'}}; |
my $old_part = $old_aw eq '' ? '' : $old_part_pcr; |
|
my $old_score = $scoreptr{$ENV{'form.GD_'.$user.'_'.$_.'_solved_s'}}; |
my $awarded = $ENV{'form.GD_'.$user.'_'.$_.'_aw'}; |
|
my $partial = $awarded eq '' ? '' : $awarded/$weight{$_}; |
my $awarded = $ENV{'form.GD_'.$user.'_'.$_.'_awarded'}; |
|
my $pcr = $awarded/($weight{$_} ne '0' ? $weight{$_} : 1); |
|
my $partial = $awarded eq '' ? '' : $pcr; |
my $score; |
my $score; |
if ($partial eq '') { |
if ($partial eq '') { |
$score = $scoreptr{$ENV{'form.GD_'.$user.'_'.$_.'_sv_s'}}; |
$score = $scoreptr{$ENV{'form.GD_'.$user.'_'.$_.'_solved_s'}}; |
} elsif ($partial > 0) { |
} elsif ($partial > 0) { |
$score = 'correct_by_override'; |
$score = 'correct_by_override'; |
} elsif ($partial == 0) { |
} elsif ($partial == 0) { |
$score = 'incorrect_by_override'; |
$score = 'incorrect_by_override'; |
} |
} |
$score = 'excused' if (($ENV{'form.GD_'.$user.'_'.$_.'_sv'} eq 'excused') && |
$score = 'excused' if (($ENV{'form.GD_'.$user.'_'.$_.'_solved'} eq 'excused') && |
($score ne 'excused')); |
($score ne 'excused')); |
$result .= '<td align="center">'.$old_aw.' </td>'. |
$result .= '<td align="center">'.$old_aw.' </td>'. |
'<td align="center">'.$awarded. |
'<td align="center">'.$awarded. |
($score eq 'excused' ? $score : '').' </td>'; |
($score eq 'excused' ? $score : '').' </td>'; |
|
|
next if ($old_part eq $partial && $old_score eq $score); |
if (!($old_part eq $partial && $old_score eq $score)) { |
|
$updateflag = 1; |
$updateflag = 1; |
$newrecord{'resource.'.$_.'.awarded'} = $partial if $partial ne ''; |
$newrecord{'resource.'.$_.'.awarded'} = $partial if $partial ne ''; |
$newrecord{'resource.'.$_.'.solved'} = $score; |
$newrecord{'resource.'.$_.'.solved'} = $score; |
$rec_update++; |
$rec_update++; |
} |
|
|
|
my $partid=$_; |
|
foreach my $stores (@parts) { |
|
my ($part,$type) = &split_part_type($stores); |
|
if ($part !~ m/^\Q$partid\E/) { next;} |
|
if ($type eq 'awarded' || $type eq 'solved') { next; } |
|
my $old_aw = $ENV{'form.GD_'.$user.'_'.$part.'_'.$type.'_s'}; |
|
my $awarded = $ENV{'form.GD_'.$user.'_'.$part.'_'.$type}; |
|
if ($awarded ne '' && $awarded ne $old_aw) { |
|
$newrecord{'resource.'.$part.'.'.$type}= $awarded; |
|
$updateflag=1; |
|
} |
|
$result .= '<td align="center">'.$old_aw.' </td>'. |
|
'<td align="center">'.$awarded.' </td>'; |
|
} |
} |
} |
$result .= '</tr>'."\n"; |
$result .= '</tr>'."\n"; |
if ($updateflag) { |
if ($updateflag) { |
Line 1831 sub editgrades {
|
Line 1871 sub editgrades {
|
'<b>Total number of students = '.$ENV{'form.total'}.'</b><br />'; |
'<b>Total number of students = '.$ENV{'form.total'}.'</b><br />'; |
return $title.$msg.$result; |
return $title.$msg.$result; |
} |
} |
|
|
|
sub split_part_type { |
|
my ($partstr) = @_; |
|
my ($temp,@allparts)=split(/_/,$partstr); |
|
my $type=pop(@allparts); |
|
my $part=join('.',@allparts); |
|
return ($part,$type); |
|
} |
|
|
#------------- end of section for handling grading by section/class --------- |
#------------- end of section for handling grading by section/class --------- |
# |
# |
#---------------------------------------------------------------------------- |
#---------------------------------------------------------------------------- |