--- loncom/homework/optionresponse.pm 2002/09/26 20:45:00 1.47 +++ loncom/homework/optionresponse.pm 2002/10/17 14:40:05 1.52 @@ -1,7 +1,7 @@ # LearningOnline Network with CAPA # option list style responses # -# $Id: optionresponse.pm,v 1.47 2002/09/26 20:45:00 albertel Exp $ +# $Id: optionresponse.pm,v 1.52 2002/10/17 14:40:05 sakharuk Exp $ # # Copyright Michigan State University Board of Trustees # @@ -50,12 +50,14 @@ sub start_optionresponse { &Apache::edit::end_row(). &Apache::edit::start_spanning_row(). "\n"; - $result.=&Apache::edit::text_arg('Max Number Of Shown Foils:','max',$token,'4'). - &Apache::edit::end_row(). - &Apache::edit::start_spanning_row(); + $result.=&Apache::edit::text_arg('Max Number Of Shown Foils:','max', + $token,'4'). + &Apache::edit::select_arg('Randomize Foil Order','randomize', + ['yes','no'],$token). + &Apache::edit::end_row().&Apache::edit::start_spanning_row(); } elsif ($target eq 'modified') { my $constructtag=&Apache::edit::get_new_args($token,$parstack, - $safeeval,'max'); + $safeeval,'max','randomize'); if ($constructtag) { $result = &Apache::edit::rebuild_tag($token); } } elsif ($target eq 'meta') { $result=&Apache::response::meta_package_write('optionresponse'); @@ -150,16 +152,16 @@ sub end_foilgroup { my $result; if ($target eq 'grade' || $target eq 'web' || $target eq 'answer' || $target eq 'tex' || $target eq 'analyze') { my $name; - my ($count,$max) = &getfoilcounts($parstack,$safeeval); - if ($count>$max) { $count=$max } - &Apache::lonxml::debug("Count is $count from $max"); my @opt; eval '@opt ='.&Apache::lonxml::get_param('options',$parstack,$safeeval); &Apache::lonxml::debug("Options are $#opt"); + my $max = &Apache::lonxml::get_param('max',$parstack,$safeeval,'-2'); + my $randomize = &Apache::lonxml::get_param('randomize',$parstack, + $safeeval,'-2'); if ($target eq 'web' || $target eq 'tex') { - $result.=&displayfoils($target,$count,@opt); + $result.=&displayfoils($target,$max,$randomize,@opt); } elsif ( $target eq 'answer') { - $result.=&displayanswers($count,@opt); + $result.=&displayanswers($max,$randomize,@opt); } elsif ( $target eq 'analyze') { my $part_id="$Apache::inputtags::part.$Apache::inputtags::response[-1]"; foreach my $name (@{ $Apache::response::foilgroup{'names'} }) { @@ -171,10 +173,10 @@ sub end_foilgroup { $Apache::response::foilgroup{"$name.text"}; } push (@{ $Apache::lonhomework::analyze{"$part_id.options"} },@opt); - push (@{ $Apache::lonhomework::analyze{"$part_id.shown"} },&whichfoils($count)); + push (@{ $Apache::lonhomework::analyze{"$part_id.shown"} },&whichfoils($max,$randomize)); } elsif ( $target eq 'grade') { if ( defined $ENV{'form.submitted'}) { - my @whichopt = &whichfoils($count); + my @whichopt = &whichfoils($max,$randomize); my $temp=1;my $name; my %responsehash; my $right=0; @@ -225,22 +227,38 @@ sub end_foilgroup { } sub getfoilcounts { - my ($parstack,$safeeval)=@_; - my $max = &Apache::lonxml::get_param('max',$parstack,$safeeval,'-2'); + my ($max)=@_; # +1 since instructors will count from 1 my $count = $#{ $Apache::response::foilgroup{'names'} }+1; if (&Apache::response::showallfoils()) { $max=$count; } - return ($count,$max); + if ($count>$max) { $count=$max } + &Apache::lonxml::debug("Count is $count from $max"); + return $count; } sub whichfoils { - my ($max)=@_; + my ($max,$randomize)=@_; + $max = &getfoilcounts($max); + &Apache::lonxml::debug("randomize $randomize"); my @names = @{ $Apache::response::foilgroup{'names'} }; my @whichopt =(); + my (%top,@toplist,%bottom,@bottomlist); + if (!(&Apache::response::showallfoils() || ($randomize eq 'no'))) { + my $current=0; + foreach my $name (@names) { + $current++; + if ($Apache::response::foilgroup{$name.'.location'} eq 'top') { + $top{$name}=$current; + } elsif ($Apache::response::foilgroup{$name.'.location'} eq + 'bottom') { + $bottom{$name}=$current; + } + } + } while ((($#whichopt+1) < $max) && ($#names > -1)) { &Apache::lonxml::debug("Have $#whichopt max is $max"); my $aopt; - if (&Apache::response::showallfoils()) { + if (&Apache::response::showallfoils() || ($randomize eq 'no')) { $aopt=0; } else { $aopt=int(&Math::Random::random_uniform() * ($#names+1)); @@ -248,15 +266,28 @@ sub whichfoils { &Apache::lonxml::debug("From $#whichopt $max $#names elms, picking $aopt"); $aopt=splice(@names,$aopt,1); &Apache::lonxml::debug("Picked $aopt"); - push (@whichopt,$aopt); + if ($top{$aopt}) { + $toplist[$top{$aopt}]=$aopt; + } elsif ($bottom{$aopt}) { + $bottomlist[$bottom{$aopt}]=$aopt; + } else { + push (@whichopt,$aopt); + } + } + for (my $i=0;$i<=$#toplist;$i++) { + if ($toplist[$i]) { unshift(@whichopt,$toplist[$i]) } } + for (my $i=0;$i<=$#bottomlist;$i++) { + if ($bottomlist[$i]) { push(@whichopt,$bottomlist[$i]) } + } + return @whichopt; } sub displayanswers { - my ($max,@opt)=@_; + my ($max,$randomize,@opt)=@_; my @names = @{ $Apache::response::foilgroup{'names'} }; - my @whichopt = &whichfoils($max); + my @whichopt = &whichfoils($max,$randomize); my $result=&Apache::response::answer_header('optionresponse'); foreach my $name (@whichopt) { $result.=&Apache::response::answer_part('optionresponse', @@ -267,14 +298,16 @@ sub displayanswers { } sub displayfoils { - my ($target,$max,@opt)=@_; + my ($target,$max,$randomize,@opt)=@_; my @names = @{ $Apache::response::foilgroup{'names'} }; my @truelist; my @falselist; my $result; my $name; my $displayoptionintex=0; - my @whichopt = &whichfoils($max); + my @alphabet = ('A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P', + 'Q','R','S','T','U','V','W','X','Y','Z'); + my @whichopt = &whichfoils($max,$randomize); my $part=$Apache::inputtags::part; my $id=$Apache::inputtags::response[-1]; if (($Apache::lonhomework::history{"resource.$part.solved"} =~ /^correct/) || ($Apache::inputtags::status[-1] eq 'SHOW_ANSWER')) { @@ -310,29 +343,50 @@ sub displayfoils { $result.="
\n".$Apache::response::foilgroup{$name.'.text'}."\n"; + if ($Apache::lonhomework::type eq 'exam') { + my $number_of_bubbles = $#opt + 1; + $result.= ''; + for (my $ind=0;$ind<$number_of_bubbles;$ind++) { + $result.=''; + } + $result.='
'.$alphabet[$ind].': '.$opt[$ind].'
'; + } $temp++; } else { if ($displayoptionintex == 0) { - my $texoptionlist = $optionlist; - $texoptionlist =~ s/