version 1.13, 2001/02/22 00:49:03
|
version 1.15, 2001/04/23 17:15:13
|
Line 25 sub end_radiobuttonresponse {
|
Line 25 sub end_radiobuttonresponse {
|
%Apache::response::foilgroup={}; |
%Apache::response::foilgroup={}; |
sub start_foilgroup { |
sub start_foilgroup { |
%Apache::response::foilgroup={}; |
%Apache::response::foilgroup={}; |
|
$Apache::optionresponse::conceptgroup=0; |
|
&setrandomnumber(); |
return ''; |
return ''; |
} |
} |
|
|
Line 38 sub setrandomnumber {
|
Line 40 sub setrandomnumber {
|
return ''; |
return ''; |
} |
} |
|
|
|
sub storesurvey { |
|
if ( defined $ENV{'form.submitted'}) { |
|
my $response = $ENV{'form.HWVAL'.$Apache::inputtags::response['-1']}; |
|
&Apache::lonxml::debug("Here I am!:$response:"); |
|
if ( $response =~ /[^\s]/) { |
|
my $id = $Apache::inputtags::response['-1']; |
|
$Apache::lonhomework::results{"resource.$Apache::inputtags::part.$id.submission"}=$response; |
|
$Apache::lonhomework::results{"resource.$Apache::inputtags::part.$id.awarddetail"}='SUBMITTED'; |
|
&Apache::lonxml::debug("submitted a $response<br />\n"); |
|
} |
|
} |
|
return ''; |
|
} |
|
|
sub end_foilgroup { |
sub end_foilgroup { |
my ($target,$token,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$parstack,$parser,$safeeval,$style)=@_; |
|
|
my $result; |
my $result; |
if ($target ne 'meta') { |
if ($target ne 'meta') { |
my $name; |
my $rrargs =''; |
&setrandomnumber(); |
if ( $#$parstack > 0 ) { $rrargs=$$parstack['-2']; } |
my ($truecnt,$falsecnt,$max) = &getfoilcounts($parstack,$safeeval); |
my $style = &Apache::run::run("{$rrargs;".'return $style}',$safeeval); |
my $count=0; |
if ( $style eq 'survey' ) { |
# we will add in 1 of the true statements |
if ($target eq 'web') { |
if (($falsecnt+1)>$max) { $count=$max } else { $count=$falsecnt+1; } |
$result=&displayallfoils(); |
my $answer = int(rand ($count)); |
} elsif ( $target eq 'grade' ) { |
&Apache::lonxml::debug("Answer is $answer, $count from $max, $falsecnt"); |
$result=&storesurvey(); |
if ($target eq 'web') { |
} |
$result=&displayfoils($max,$answer); |
} else { |
} elsif ( $target eq 'grade') { |
my $name; |
if ( defined $ENV{'form.submitted'}) { |
my ($truecnt,$falsecnt,$max) = &getfoilcounts($parstack,$safeeval); |
my $response = $ENV{'form.HWVAL'.$Apache::inputtags::response['-1']}; |
my $count=0; |
if ( $response =~ /[^\s]/) { |
# we will add in 1 of the true statements |
my $id = $Apache::inputtags::response['-1']; |
if (($falsecnt+1)>$max) { $count=$max } else { $count=$falsecnt+1; } |
$Apache::lonhomework::results{"resource.$Apache::inputtags::part.$id.submission"}=$response; |
my $answer = int(rand ($count)); |
&Apache::lonxml::debug("submitted a $response<br />\n"); |
&Apache::lonxml::debug("Answer is $answer, $count from $max, $falsecnt"); |
if ($response == $answer) { |
if ($target eq 'web') { |
$Apache::lonhomework::results{"resource.$Apache::inputtags::part.$id.awarddetail"}='EXACT_ANS'; |
$result=&displayfoils($max,$answer); |
} else { |
} elsif ( $target eq 'grade') { |
$Apache::lonhomework::results{"resource.$Apache::inputtags::part.$id.awarddetail"}='INCORRECT'; |
if ( defined $ENV{'form.submitted'}) { |
|
my $response = $ENV{'form.HWVAL'.$Apache::inputtags::response['-1']}; |
|
if ( $response =~ /[^\s]/) { |
|
my $id = $Apache::inputtags::response['-1']; |
|
$Apache::lonhomework::results{"resource.$Apache::inputtags::part.$id.submission"}=$response; |
|
&Apache::lonxml::debug("submitted a $response<br />\n"); |
|
if ($response == $answer) { |
|
$Apache::lonhomework::results{"resource.$Apache::inputtags::part.$id.awarddetail"}='EXACT_ANS'; |
|
} else { |
|
$Apache::lonhomework::results{"resource.$Apache::inputtags::part.$id.awarddetail"}='INCORRECT'; |
|
} |
} |
} |
} |
} |
} |
} |
Line 92 sub getfoilcounts {
|
Line 118 sub getfoilcounts {
|
return ($truecnt,$falsecnt,$max); |
return ($truecnt,$falsecnt,$max); |
} |
} |
|
|
|
sub displayallfoils { |
|
my $result; |
|
&Apache::lonxml::debug("survey style display"); |
|
my @names = @{ $Apache::response::foilgroup{'names'} }; |
|
my $temp=0; |
|
my $id=$Apache::inputtags::response['-1']; |
|
my $part=$Apache::inputtags::part; |
|
my $lastresponse=$Apache::lonhomework::history{"resource.$part.$id.submission"}; |
|
foreach my $name (@names) { |
|
if ($Apache::response::foilgroup{$name.'.value'} ne 'unused') { |
|
$result.="<br /><input type=\"radio\" name=\"HWVAL$Apache::inputtags::response['-1']\" value=\"$temp\" "; |
|
if ($lastresponse == $temp) { $result .= 'checked="on"'; } |
|
$result .= '>'.$Apache::response::foilgroup{$name.'.text'}."</input>\n"; |
|
$temp++; |
|
} |
|
} |
|
return $result; |
|
} |
|
|
sub displayfoils { |
sub displayfoils { |
my ($max,$answer)=@_; |
my ($max,$answer)=@_; |
my @names = @{ $Apache::response::foilgroup{'names'} }; |
my @names = @{ $Apache::response::foilgroup{'names'} }; |
Line 114 sub displayfoils {
|
Line 159 sub displayfoils {
|
my $whichtrue = rand $#truelist; |
my $whichtrue = rand $#truelist; |
&Apache::lonxml::debug("Max is $max, From $#truelist elms, picking $whichtrue"); |
&Apache::lonxml::debug("Max is $max, From $#truelist elms, picking $whichtrue"); |
my @whichfalse =(); |
my @whichfalse =(); |
while ((($#whichfalse+2) < $max) && ($#falselist > -1)) { |
while ((($#whichfalse+1) < $max) && ($#falselist > -1)) { |
my $afalse=rand $#falselist; |
my $afalse=rand $#falselist; |
&Apache::lonxml::debug("From $#falselist elms, picking $afalse"); |
&Apache::lonxml::debug("From $#falselist elms, picking $afalse"); |
$afalse=splice(@falselist,$afalse,1); |
$afalse=splice(@falselist,$afalse,1); |
Line 135 sub displayfoils {
|
Line 180 sub displayfoils {
|
} |
} |
} else { |
} else { |
my $temp=0; |
my $temp=0; |
|
my $id=$Apache::inputtags::response['-1']; |
|
my $part=$Apache::inputtags::part; |
|
my $lastresponse=$Apache::lonhomework::history{"resource.$part.$id.submission"}; |
foreach $name (@whichfalse) { |
foreach $name (@whichfalse) { |
$result.="<br /><input type=\"radio\" name=\"HWVAL$Apache::inputtags::response['-1']\" value=\"$temp\">".$Apache::response::foilgroup{$name.'.text'}."</input>\n"; |
$result.="<br /><input type=\"radio\" name=\"HWVAL$Apache::inputtags::response['-1']\" value=\"$temp\" "; |
|
if ($lastresponse == $temp) { $result .= 'checked="on"'; } |
|
$result .= '>'.$Apache::response::foilgroup{$name.'.text'}."</input>\n"; |
$temp++; |
$temp++; |
} |
} |
} |
} |
return $result."<br />"; |
return $result."<br />"; |
} |
} |
|
|
|
sub start_conceptgroup { |
|
$Apache::optionresponse::conceptgroup=1; |
|
%Apache::response::conceptgroup={}; |
|
return ''; |
|
} |
|
|
|
sub end_conceptgroup { |
|
my ($target,$token,$parstack,$parser,$safeeval,$style)=@_; |
|
$Apache::optionresponse::conceptgroup=0; |
|
if ($target eq 'web' || $target eq 'grade') { |
|
my @names = @{ $Apache::response::conceptgroup{'names'} }; |
|
my $pick=int rand $#names+1; |
|
my $name=$names[$pick]; |
|
push @{ $Apache::response::foilgroup{'names'} }, $name; |
|
$Apache::response::foilgroup{"$name.text"} = $Apache::response::conceptgroup{"$name.text"}; |
|
$Apache::response::foilgroup{"$name.value"} = $Apache::response::conceptgroup{"$name.value"}; |
|
my $args; |
|
if ( $#$parstack > -1 ) { $args=$$parstack[$#$parstack]; } |
|
my $concept = &Apache::run::run("{$args;".'return $concept}',$safeeval); |
|
$Apache::response::foilgroup{"$name.concept"} = $concept; |
|
&Apache::lonxml::debug("Selecting $name in $concept"); |
|
} |
|
return ''; |
|
} |
|
|
sub start_foil { |
sub start_foil { |
&Apache::lonxml::startredirection; |
&Apache::lonxml::startredirection; |
return ''; |
return ''; |