--- loncom/interface/spreadsheet/assesscalc.pm 2006/04/06 20:24:13 1.52 +++ loncom/interface/spreadsheet/assesscalc.pm 2006/09/03 00:39:57 1.56 @@ -1,5 +1,5 @@ # -# $Id: assesscalc.pm,v 1.52 2006/04/06 20:24:13 raeburn Exp $ +# $Id: assesscalc.pm,v 1.56 2006/09/03 00:39:57 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -302,18 +302,19 @@ this user and course. ################################################## sub parmval { my $self = shift; - my ($what,$symb,$uname,$udom,$csec,$recurse,$mapname,$id,$fn,$cgroup)=@_; - $uname = $self->{'name'} if (! defined($uname)); - $udom = $self->{'domain'} if (! defined($udom)); - $csec = $self->{'section'} if (! defined($csec)); - $cgroup = $self->{'group'} if (! defined($cgroup)); - $symb = $self->{'symb'} if (! defined($symb)); + my ($what,$symb,$uname,$udom,$csec,$recurse,$mapname,$id,$fn,$groups)=@_; + $uname = $self->{'name'} if (! defined($uname)); + $udom = $self->{'domain'} if (! defined($udom)); + $csec = $self->{'section'} if (! defined($csec)); + $groups = $self->{'groups'} if (! defined($groups)); + $symb = $self->{'symb'} if (! defined($symb)); # my $result=''; # # This should be a if (!defined($mapname) || !defined($id) || !defined($fn)) { ($mapname,$id,$fn)=&Apache::lonnet::decode_symb($symb); + $mapname = &Apache::lonnet::deversion($mapname); } # Cascading lookup scheme my $rwhat=$what; @@ -325,10 +326,6 @@ sub parmval { my $courseprefix = $self->{'cid'}; my $usercourseprefix = $uname.'_'.$udom.'_'.$self->{'cid'}; # - my $grplevel=$courseprefix.'.['.$cgroup.'].'.$what; - my $grplevelr=$courseprefix.'.['.$cgroup.'].'.$symbparm; - my $grplevelm=$courseprefix.'.['.$cgroup.'].'.$mapparm; - # my $seclevel = $courseprefix.'.['.$csec.'].'.$what; my $seclevelr = $courseprefix.'.['.$csec.'].'.$symbparm; my $seclevelm = $courseprefix.'.['.$csec.'].'.$mapparm; @@ -346,11 +343,16 @@ sub parmval { return $useropt{$ucourselevelm} if (defined($useropt{$ucourselevelm})); return $useropt{$ucourselevel} if (defined($useropt{$ucourselevel})); } - # check group - if (defined($cgroup)) { - return $courseopt{$grplevelr} if (defined($courseopt{$grplevelr})); - return $courseopt{$grplevelm} if (defined($courseopt{$grplevelm})); - return $courseopt{$grplevel} if (defined($courseopt{$grplevel})); + # check groups + if (defined($groups) && ref($groups) eq 'ARRAY') { + foreach my $group (@{$groups}) { + foreach my $level ($symbparm,$mapparm,$what) { + my $item = $courseprefix.'.['.$group.'].'.$level; + if (defined($courseopt{$item})) { + return $courseopt{$item}; + } + } + } } # check section if (defined($csec)) { @@ -382,7 +384,7 @@ sub parmval { my $newwhat=$rwhat; $newwhat=~s/\Q$space\E/$part/; my $partgeneral=$self->parmval($newwhat,$symb,$uname,$udom,$csec,1, - $mapname,$id,$fn); + $mapname,$id,$fn,$groups); if (defined($partgeneral)) { return $partgeneral; } } if ($recurse) { return undef; } @@ -540,7 +542,7 @@ sub assess_html_row { $row_html .= &Apache::Spreadsheet::html_uneditable_cell($cell, '#FFDDDD'); } else { - $row_html .= ''; + $row_html .= ''; $row_html .= &Apache::Spreadsheet::html_editable_cell($cell, '#E0FFDD',1); } @@ -643,11 +645,12 @@ sub get_parameter_values { if (tie(%parmhash,'GDBM_File', $self->{'coursefilename'}.'_parms.db',&GDBM_READER(),0640)) { my ($mapname,$id,$fn)=&Apache::lonnet::decode_symb($self->{'symb'}); + $mapname = &Apache::lonnet::deversion($mapname); foreach my $parmname (@Parameters) { my $value = $self->parmval($parmname,$self->{'symb'}, $self->{'name'},$self->{'domain'}, $self->{'section'},undef, - $mapname,$id,$fn); + $mapname,$id,$fn,$self->{'groups'}); $parameters{$parmname} =$value; } untie(%parmhash);