--- loncom/homework/matchresponse.pm 2007/04/05 10:29:58 1.62
+++ loncom/homework/matchresponse.pm 2007/08/29 10:07:42 1.65
@@ -1,7 +1,7 @@
# The LearningOnline Network with CAPA
# Full matching style response
#
-# $Id: matchresponse.pm,v 1.62 2007/04/05 10:29:58 foxr Exp $
+# $Id: matchresponse.pm,v 1.65 2007/08/29 10:07:42 foxr Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -71,6 +71,8 @@ sub start_matchresponse {
} elsif ($target eq 'analyze') {
my $part_id="$Apache::inputtags::part.$id";
push (@{ $Apache::lonhomework::analyze{"parts"} },$part_id);
+ push (@{ $Apache::lonhomework::anaylze{"$part_id.bubble_lines"} },
+ 1);
}
return $result;
}
@@ -415,6 +417,24 @@ sub grade_response {
}
}
+sub format_prior_answer {
+ my ($mode,$answer,$other_data) = @_;
+ my %answer =&Apache::lonnet::str2hash($answer);
+ my $foil_order =$other_data->[0];
+ my %grading =&Apache::lonnet::str2hash($other_data->[1]);
+ my @items =&Apache::lonnet::str2array($other_data->[2]);
+ my $output;
+
+ foreach my $name (@{ $foil_order }) {
+ my $item=shift(@items);
+ $output .= '
'.$item.' |
';
+ }
+ return if (!defined($output));
+
+ $output = '';
+ return $output;
+}
+
sub itemdisplay {
my ($location)=@_;
if ($location eq 'top' &&
@@ -426,6 +446,7 @@ sub itemdisplay {
}
return undef;
}
+
sub displayfoils {
my ($target,$max,$randomize)=@_;
my ($tabsize, $lefttabsize, $righttabsize);
@@ -535,11 +556,9 @@ sub displayfoils {
$question.='\vskip -1 mm\noindent\begin{list}{}{\setlength{\listparindent}{0mm}\setlength{\leftmargin}{2mm}}'
.'\item \hskip -3mm \textbf{'.$internal_counter.'}';
if (&itemdisplay('left') || &itemdisplay('right')) {
- &Apache::lonnet::logthis("Constraining bubbles to $righttabsize - 10");
$question .= &Apache::optionresponse::bubbles(\@used_letters,\@emptyItems, "", $righttabsize);
}
else {
- &Apache::lonnet::logthis("Not constraining bubbles");
$question .= &Apache::optionresponse::bubbles(\@used_letters,\@emptyItems);
}
$question .= '\end{list} \vskip -8 mm \strut ';
@@ -578,6 +597,12 @@ sub displayfoils {
$result='\setlength{\tabcolsep}{1 mm}\begin{tabular}{p{'.$lefttabsize.'}p{'.$righttabsize.'}}\begin{minipage}{'.$lefttabsize.'}'.$result.'\end{minipage}&\begin{minipage}{'.$righttabsize.'}'.$question.'\end{minipage}\end{tabular}';
}
}
+ if ($target eq 'web') {
+ &Apache::response::setup_prior_tries_hash(\&format_prior_answer,
+ [\@whichfoils,
+ 'submissiongrading',
+ 'submissionitems']);
+ }
if ($target ne 'tex') {$result.="
";} else {$result.=' \\\\ ';}
return $result;
}