version 1.109, 2006/12/08 17:38:35
|
version 1.115, 2007/05/17 10:01:44
|
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; |
|
|
BEGIN { |
BEGIN { |
&Apache::lonxml::register('Apache::radiobuttonresponse',('radiobuttonresponse')); |
&Apache::lonxml::register('Apache::radiobuttonresponse',('radiobuttonresponse')); |
Line 39 BEGIN {
|
Line 40 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; |
|
#----- test/debugging to figure out some crap |
|
|
|
my $partid = $Apache::inputtags::part; |
|
&Apache::lonnet::logthis("Part id = $partid"); |
|
my $bubble_max = &Apache::response::get_response_param($partid, 'numbubbles', 10); |
|
&Apache::lonnet::logthis("numbubbles [10] = $bubble_max"); |
|
|
|
#----- End test/debugging |
#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 179 sub end_foilgroup {
|
Line 188 sub end_foilgroup {
|
$safeeval,'-2'); |
$safeeval,'-2'); |
if ( $style eq 'survey' && $target ne 'analyze') { |
if ( $style eq 'survey' && $target ne 'analyze') { |
if ($target eq 'web' || $target eq 'tex') { |
if ($target eq 'web' || $target eq 'tex') { |
$result=&displayallfoils($direction); |
$result=&displayallfoils($direction, $target); |
} elsif ( $target eq 'answer' ) { |
} elsif ( $target eq 'answer' ) { |
$result=&displayallanswers(); |
$result=&displayallanswers(); |
} elsif ( $target eq 'grade' ) { |
} elsif ( $target eq 'grade' ) { |
Line 206 sub end_foilgroup {
|
Line 215 sub end_foilgroup {
|
('true','false')); |
('true','false')); |
} |
} |
} |
} |
|
$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 230 sub getfoilcounts {
|
Line 245 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)=@_; |
my ($direction, $target)=@_; |
my $result; |
my $result; |
&Apache::lonxml::debug("survey style display"); |
&Apache::lonxml::debug("survey style display"); |
my @names; |
my @names; |
Line 239 sub displayallfoils {
|
Line 264 sub displayallfoils {
|
@names= @{ $Apache::response::foilgroup{'names'} }; |
@names= @{ $Apache::response::foilgroup{'names'} }; |
} |
} |
my $temp=0; |
my $temp=0; |
|
my $i =0; |
my $id=$Apache::inputtags::response['-1']; |
my $id=$Apache::inputtags::response['-1']; |
my $part=$Apache::inputtags::part; |
my $part=$Apache::inputtags::part; |
my $lastresponse= |
my $lastresponse= |
Line 248 sub displayallfoils {
|
Line 274 sub displayallfoils {
|
if (&Apache::response::show_answer() ) { |
if (&Apache::response::show_answer() ) { |
foreach my $name (@names) { |
foreach my $name (@names) { |
if ($Apache::response::foilgroup{$name.'.value'} ne 'unused') { |
if ($Apache::response::foilgroup{$name.'.value'} ne 'unused') { |
if ($direction eq 'horizontal') { |
if (($direction eq 'horizontal') && ($target ne 'tex')) { |
$result.="<td>"; |
$result.="<td>"; |
} else { |
} else { |
$result.="<br />"; |
if ($target eq 'tex') { |
|
$result .= '\item \vskip -2mm '; |
|
} else { |
|
$result.="<br />"; |
|
} |
} |
} |
if (defined($lastresponse{$name})) { |
if (defined($lastresponse{$name})) { |
$result.='<b>'; |
if ($target eq 'tex') { |
|
$result .= '}'; |
|
} else { |
|
$result.='<b>'; |
|
} |
} |
} |
$result .= $Apache::response::foilgroup{$name.'.text'}; |
$result .= $Apache::response::foilgroup{$name.'.text'}; |
if (defined($lastresponse{$name})) { |
if (defined($lastresponse{$name}) && ($target ne 'tex')) { |
$result.='</b>'; |
$result.='</b>'; |
} |
} |
if ($direction eq 'horizontal') { $result.="</td>"; } |
if (($direction eq 'horizontal') && ($target ne 'tex')) { $result.="</td>"; } |
} |
} |
} |
} |
} else { |
} else { |
Line 269 sub displayallfoils {
|
Line 303 sub displayallfoils {
|
if ($direction eq 'horizontal') { |
if ($direction eq 'horizontal') { |
$result.="<td>"; |
$result.="<td>"; |
} else { |
} else { |
$result.="<br />"; |
if ($target eq 'tex') { |
|
$result .= '\item \vskip -2mm '; |
|
} else { |
|
$result.="<br />"; |
|
} |
|
} |
|
if ($target eq 'tex') { |
|
$result .= '$\bigcirc$'.$Apache::response::foilgroup{$name.'.text'}.'\\\\'; #' stupid emacs |
|
$i++; |
|
} else { |
|
$result .= '<label>'; |
|
$result.="<input |
|
onchange=\"javascript:setSubmittedPart('$part');\" |
|
type=\"radio\" |
|
name=\"HWVAL_$Apache::inputtags::response['-1']\" |
|
value=\"$temp\" "; |
|
if (defined($lastresponse{$name})) { $result .= 'checked="on"'; } |
|
$result .= ' />'.$Apache::response::foilgroup{$name.'.text'}. |
|
'</label>'; |
} |
} |
$result .= '<label>'; |
|
$result.="<input type=\"radio\" name=\"HWVAL_$Apache::inputtags::response['-1']\" value=\"$temp\" "; |
|
if (defined($lastresponse{$name})) { $result .= 'checked="on"'; } |
|
$result .= ' />'.$Apache::response::foilgroup{$name.'.text'}. |
|
'</label>'; |
|
$temp++; |
$temp++; |
if ($direction eq 'horizontal') { $result.="</td>"; } |
if ($target ne 'tex') { |
|
if (($direction eq 'horizontal') && ($target ne 'tex')) { $result.="</td>"; } |
|
} else { |
|
$result.='\vskip 0 mm '; |
|
} |
} |
} |
} |
} |
} |
} |
if ($direction eq 'horizontal') { $result.='</tr></table>'; } |
if (($direction eq 'horizontal') && ($target ne 'tex')) { $result.='</tr></table>'; } |
return $result; |
return $result; |
} |
} |
|
|
Line 485 sub displayfoils {
|
Line 536 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 { |