version 1.111, 2007/02/22 01:25:31
|
version 1.119, 2007/06/20 22:50:27
|
Line 31 use strict;
|
Line 31 use strict;
|
use HTML::Entities(); |
use HTML::Entities(); |
use Apache::lonlocal; |
use Apache::lonlocal; |
use Apache::lonnet; |
use Apache::lonnet; |
|
use Apache::response; |
|
|
|
my $bubbles_per_line = 10; |
|
|
BEGIN { |
BEGIN { |
&Apache::lonxml::register('Apache::radiobuttonresponse',('radiobuttonresponse')); |
&Apache::lonxml::register('Apache::radiobuttonresponse',('radiobuttonresponse')); |
Line 39 BEGIN {
|
Line 42 BEGIN {
|
sub start_radiobuttonresponse { |
sub start_radiobuttonresponse { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my $result; |
my $result; |
|
|
#when in a radiobutton response use these |
#when in a radiobutton response use these |
&Apache::lonxml::register('Apache::radiobuttonresponse',('foilgroup','foil','conceptgroup')); |
&Apache::lonxml::register('Apache::radiobuttonresponse',('foilgroup','foil','conceptgroup')); |
push (@Apache::lonxml::namespace,'radiobuttonresponse'); |
push (@Apache::lonxml::namespace,'radiobuttonresponse'); |
Line 142 sub grade_response {
|
Line 146 sub grade_response {
|
my ($answer,@whichfoils)=&whichfoils($max,$randomize); |
my ($answer,@whichfoils)=&whichfoils($max,$randomize); |
if ( !&Apache::response::submitted() ) { return; } |
if ( !&Apache::response::submitted() ) { return; } |
my $response; |
my $response; |
|
|
|
# Need to know how many foils we have so that I know how many |
|
# bubble lines to consume: |
|
|
|
my $numfoils = scalar(@whichfoils); |
|
my $bubble_lines = int($numfoils / $bubbles_per_line); |
|
if (($numfoils % $bubbles_per_line) != 0) { |
|
$bubble_lines++; # Partial line of bubbles too. |
|
} |
|
|
|
|
if ($env{'form.submitted'} eq 'scantron') { |
if ($env{'form.submitted'} eq 'scantron') { |
$response=&Apache::response::getresponse(); |
$response = &Apache::response::getresponse(1,undef,$bubble_lines, |
|
$bubbles_per_line); |
|
|
} else { |
} else { |
$response = $env{'form.HWVAL_'.$Apache::inputtags::response['-1']}; |
$response = $env{'form.HWVAL_'.$Apache::inputtags::response['-1']}; |
} |
} |
|
&Apache::lonxml::increment_counter($bubble_lines-1); |
|
|
if ( $response !~ /[0-9]+/) { return; } |
if ( $response !~ /[0-9]+/) { return; } |
my $part=$Apache::inputtags::part; |
my $part=$Apache::inputtags::part; |
my $id = $Apache::inputtags::response['-1']; |
my $id = $Apache::inputtags::response['-1']; |
Line 208 sub end_foilgroup {
|
Line 227 sub end_foilgroup {
|
} |
} |
$Apache::lonxml::post_evaluate=0; |
$Apache::lonxml::post_evaluate=0; |
} |
} |
|
if ($target eq 'web') { |
|
&Apache::response::setup_prior_tries_hash(\&format_prior_answer, |
|
[\%Apache::response::foilgroup]); |
|
} |
|
|
&Apache::response::poprandomnumber(); |
&Apache::response::poprandomnumber(); |
&Apache::lonxml::increment_counter(); |
&Apache::lonxml::increment_counter(); |
return $result; |
return $result; |
Line 231 sub getfoilcounts {
|
Line 255 sub getfoilcounts {
|
return ($truecnt,$falsecnt); |
return ($truecnt,$falsecnt); |
} |
} |
|
|
|
sub format_prior_answer { |
|
my ($mode,$answer,$other_data) = @_; |
|
my $foil_data = $other_data->[0]; |
|
my %response = &Apache::lonnet::str2hash($answer); |
|
my ($name) = keys(%response); |
|
return '<span class="LC_prior_radiobutton">'. |
|
$foil_data->{$name.'.text'}.'</span>'; |
|
|
|
} |
|
|
sub displayallfoils { |
sub displayallfoils { |
my ($direction, $target)=@_; |
my ($direction, $target)=@_; |
my $result; |
my $result; |
Line 290 sub displayallfoils {
|
Line 324 sub displayallfoils {
|
$i++; |
$i++; |
} else { |
} else { |
$result .= '<label>'; |
$result .= '<label>'; |
$result.="<input type=\"radio\" name=\"HWVAL_$Apache::inputtags::response['-1']\" value=\"$temp\" "; |
$result.="<input |
|
onchange=\"javascript:setSubmittedPart('$part');\" |
|
type=\"radio\" |
|
name=\"HWVAL_$Apache::inputtags::response['-1']\" |
|
value=\"$temp\" "; |
if (defined($lastresponse{$name})) { $result .= 'checked="on"'; } |
if (defined($lastresponse{$name})) { $result .= 'checked="on"'; } |
$result .= ' />'.$Apache::response::foilgroup{$name.'.text'}. |
$result .= ' />'.$Apache::response::foilgroup{$name.'.text'}. |
'</label>'; |
'</label>'; |
Line 490 sub displayfoils {
|
Line 528 sub displayfoils {
|
} else { |
} else { |
my @alphabet = ('A'..'Z'); |
my @alphabet = ('A'..'Z'); |
my $i = 0; |
my $i = 0; |
|
my $bubble_number = 0; |
my $temp=0; |
my $temp=0; |
my $id=$Apache::inputtags::response['-1']; |
my $id=$Apache::inputtags::response['-1']; |
my $part=$Apache::inputtags::part; |
my $part=$Apache::inputtags::part; |
Line 508 sub displayfoils {
|
Line 547 sub displayfoils {
|
} |
} |
if ($target ne 'tex') { |
if ($target ne 'tex') { |
$result.= '<label>'; |
$result.= '<label>'; |
$result.="<input type=\"radio\" name=\"HWVAL_$Apache::inputtags::response['-1']\" value=\"$temp\" "; |
$result.= |
|
"<input type=\"radio\" |
|
onchange=\"javascript:setSubmittedPart('$part');\" |
|
name=\"HWVAL_$Apache::inputtags::response['-1']\" |
|
value=\"$temp\" "; |
if (defined($lastresponse{$name})) { $result .= 'checked="on"'; } |
if (defined($lastresponse{$name})) { $result .= 'checked="on"'; } |
$result .= ' />'.$Apache::response::foilgroup{$name.'.text'}."</label>"; |
$result .= ' />'.$Apache::response::foilgroup{$name.'.text'}."</label>"; |
} else { |
} else { |
if ($Apache::lonhomework::type eq 'exam') { |
if ($Apache::lonhomework::type eq 'exam') { |
$result .= '{\small \textbf{'.$alphabet[$i].'}}$\bigcirc$'.$Apache::response::foilgroup{$name.'.text'}.'\\\\'; #' stupid emacs |
$result .= '{\small \textbf{'.$alphabet[$i].'}}$\bigcirc$'.$Apache::response::foilgroup{$name.'.text'}.'\\\\'; #' stupid emacs |
$i++; |
$i++; |
|
$bubble_number++; |
|
if($bubble_number >= $bubbles_per_line) { |
|
$i = 0; |
|
$bubble_number = 0; |
|
&Apache::lonxml::increment_counter(1); |
|
$result.='\item[\textbf{'.$Apache::lonxml::counter.'}.]'; |
|
} |
} else { |
} else { |
$result .= '\vspace*{-2 mm}\item '.$Apache::response::foilgroup{$name.'.text'}; |
$result .= '\vspace*{-2 mm}\item '.$Apache::response::foilgroup{$name.'.text'}; |
} |
} |