--- loncom/homework/optionresponse.pm 2002/08/26 18:15:22 1.46
+++ loncom/homework/optionresponse.pm 2002/10/17 14:30:40 1.51
@@ -1,7 +1,7 @@
# LearningOnline Network with CAPA
# option list style responses
#
-# $Id: optionresponse.pm,v 1.46 2002/08/26 18:15:22 sakharuk Exp $
+# $Id: optionresponse.pm,v 1.51 2002/10/17 14:30:40 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,38 +227,67 @@ 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(rand($#names+1));
+ $aopt=int(&Math::Random::random_uniform() * ($#names+1));
}
&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.=''.$alphabet[$ind].': '.$opt[$ind].' | ';
+ }
+ $result.='
';
+ }
$temp++;
} else {
if ($displayoptionintex == 0) {
- my $texoptionlist = $optionlist;
- $texoptionlist =~ s/