--- loncom/homework/response.pm 2001/09/14 20:15:35 1.48
+++ loncom/homework/response.pm 2001/11/12 20:27:28 1.51
@@ -9,13 +9,18 @@ package Apache::response;
use strict;
sub BEGIN {
- &Apache::lonxml::register('Apache::response',('responseparam','caparesponse','numericalresponse','stringresponse','radiobuttonresponse','optionresponse','imageresponse','essayresponse','dataresponse'));
+ &Apache::lonxml::register('Apache::response',('responseparam','caparesponse','numericalresponse','formularesponse','stringresponse','radiobuttonresponse','optionresponse','imageresponse','essayresponse','dataresponse'));
}
sub start_response {
my ($parstack,$safeeval)=@_;
my $id= &Apache::lonxml::get_param('id',$parstack,$safeeval);
if ($id eq '') { $id = $Apache::lonxml::curdepth; }
+ if ($#Apache::inputtags::import > -1) {
+ &Apache::lonxml::debug("Turning :$id: into");
+ $id = join('_',@Apache::inputtags::import).'_'.$id;
+ &Apache::lonxml::debug("New :$id:");
+ }
push (@Apache::inputtags::response,$id);
push (@Apache::inputtags::responselist,$id);
@Apache::inputtags::inputlist=();
@@ -179,6 +184,13 @@ sub start_stringresponse {
return &Apache::caparesponse::start_stringresponse($target,$token,$tagstack,$parstack,$parser,$safeeval,$style);
}
+sub start_formularesponse {
+ require Apache::caparesponse;
+ import Apache::caparesponse;
+ my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_;
+ return &Apache::caparesponse::start_formularesponse($target,$token,$tagstack,$parstack,$parser,$safeeval,$style);
+}
+
sub start_numericalresponse {
require Apache::caparesponse;
import Apache::caparesponse;
@@ -345,12 +357,12 @@ sub setup_params {
sub answer_header {
my ($type) = @_;
my $result;
- if ($type eq 'optionresponse') {
+ if ($type eq 'optionresponse' || $type eq 'radiobuttonresponse' ) {
$result = '
Answer for Part:'.
$Apache::inputtags::part. ' |
---|
'."\n";
} else {
- $result = 'Answer for Part:'.$Apache::inputtags::part.
- ' | '."\n";
+ $result = 'Answer for Part:'.
+ $Apache::inputtags::part. ' | '."\n";
}
return $result;
}
@@ -358,7 +370,7 @@ sub answer_header {
sub answer_part {
my ($type,$answer) = @_;
my $result;
- if ($type eq 'optionresponse') {
+ if ($type eq 'optionresponse' || $type eq 'radiobuttonresponse') {
$result = ''.$answer.' | ';
} else {
$result = ''.$answer.' | ';
@@ -369,7 +381,7 @@ sub answer_part {
sub answer_footer {
my ($type) = @_;
my $result;
- if ($type eq 'optionresponse') {
+ if ($type eq 'optionresponse' || $type eq 'radiobuttonresponse') {
$result = '
';
} else {
$result = '
';