Diff for /loncom/homework/matchresponse.pm between versions 1.81 and 1.82

version 1.81, 2010/12/19 00:54:20 version 1.82, 2011/09/13 21:42:58
Line 173  sub end_itemgroup { Line 173  sub end_itemgroup {
     } elsif ($target eq 'tex') {      } elsif ($target eq 'tex') {
  my $table=' \begin{description}\setlength{\leftmargin}{2em}\setlength{\labelwidth}{1em}\setlength{\itemsep}{0.5pt plus1pt minus2pt}\setlength{\listparindent}{0em} ';   my $table=' \begin{description}\setlength{\leftmargin}{2em}\setlength{\labelwidth}{1em}\setlength{\itemsep}{0.5pt plus1pt minus2pt}\setlength{\listparindent}{0em} ';
  my $i=0;   my $i=0;
           my ($numrows,$bubbles_per_row);
           if ($Apache::lonhomework::type eq 'exam') {
               ($numrows,$bubbles_per_row) = 
                   &Apache::optionresponse::getnumrows(scalar(@names)); 
           } else {
               $numrows = 1;
           }
  foreach my $name (@names) {   foreach my $name (@names) {
     # $Apache::response::itemgroup{$name.'.text'}=~s/\$\$/\$/g;      # $Apache::response::itemgroup{$name.'.text'}=~s/\$\$/\$/g;
     $table.='\item['.$alphabet[$i].'] '.              my $item;
               if (($numrows > 1) && ($bubbles_per_row > 0)) {
                   my $num = 1+int($i/$bubbles_per_row);
                   my $idx = int($i % $bubbles_per_row);
                   if ($idx == 0) {
                       if ($num == 1) {
                           $table .= '\item[\footnotesize {'.&mt('(first line)').'}]';
                       } else {
                           $table .= '\item[\footnotesize {'.&mt('(next line)').'}]';
                       }
                   }
                   $item = $alphabet[$idx];
               } else {
                   $item = $alphabet[$i];
               }
       $table.='\item['.$item.'] '.
  $Apache::response::itemgroup{$name.'.text'};   $Apache::response::itemgroup{$name.'.text'};
     $i++;      $i++;
  }   }
Line 288  sub end_foilgroup { Line 310  sub end_foilgroup {
  ['text','value','location']);   ['text','value','location']);
     #FIXME need to store options in some way      #FIXME need to store options in some way
  }   }
  &Apache::lonxml::increment_counter(&getfoilcounts($max),           my ($numrows,$bubbles_per_row);
    "$part.$response_id");          if (($target eq 'tex') && ($Apache::lonhomework::type eq 'exam')) {
               my $numitems;
               if (ref($Apache::response::itemgroup{'names'}) eq 'ARRAY') {
                   $numitems = scalar(@{ $Apache::response::itemgroup{'names'} });
                   ($numrows,$bubbles_per_row) =
                       &Apache::optionresponse::getnumrows($numitems);
               }
           }
           if ($numrows < 1) {
               $numrows = 1;
           }
           my $increment = &getfoilcounts($max) * $numrows;
    &Apache::lonxml::increment_counter($increment,"$part.$response_id");
  if ($target eq 'analyze') {   if ($target eq 'analyze') {
     &Apache::lonhomework::set_bubble_lines();      &Apache::lonhomework::set_bubble_lines();
  }   }
Line 362  sub grade_response { Line 396  sub grade_response {
     %{ $Apache::response::itemgroup{'letter_name_map'} };      %{ $Apache::response::itemgroup{'letter_name_map'} };
     }      }
     my @items;      my @items;
       my $numitems = scalar(@{ $Apache::response::itemgroup{'names'} });
       my ($numrows,$bubbles_per_row);
       if ($Apache::lonhomework::scantronmode) {
           my $numitems = scalar(@{ $Apache::response::itemgroup{'names'} });
           ($numrows,$bubbles_per_row) =
               &Apache::optionresponse::getnumrows($numitems);
       }
       if ($numrows < 1) {
           $numrows = 1;
       }
       my @alphabet=('A'..'Z');
       my %nums_from_letters;
       for (my $i=0; $i<@alphabet; $i++) {
           $nums_from_letters{$alphabet[$i]} = $i;
       }
     foreach my $name (@whichfoils) {      foreach my $name (@whichfoils) {
  my $response = &Apache::response::getresponse($temp,'letter');          my $response;
           if ($numrows > 1) {
               my $num = $temp;
               my $totalnum;
               for (my $i=0; $i<$numrows; $i++) {
                   my $item = &Apache::response::getresponse($num,'letter');
                   if ($item =~ /^\w$/) {
                       $totalnum = $i*$bubbles_per_row + $nums_from_letters{$item};
                   }
                   $num ++;
               }
               if ($totalnum =~ /^\d+$/) {
                   $response = $alphabet[$totalnum];
               }
               $temp += $numrows;
           } else {
       $response = &Apache::response::getresponse($temp,'letter');
               $temp ++;
           }
  push(@items,$response);   push(@items,$response);
  my $responsename = $letter_name_map{$response};   my $responsename = $letter_name_map{$response};
  my $value=$Apache::response::foilgroup{$name.'.value'};   my $value=$Apache::response::foilgroup{$name.'.value'};
Line 381  sub grade_response { Line 448  sub grade_response {
  } else {   } else {
     $ignored++;      $ignored++;
  }   }
  $temp++;  
     }      }
     my $part=$Apache::inputtags::part;      my $part=$Apache::inputtags::part;
     my $id = $Apache::inputtags::response['-1'];      my $id = $Apache::inputtags::response['-1'];
Line 535  sub displayfoils { Line 601  sub displayfoils {
  my @alphabet=('A'..'Z');   my @alphabet=('A'..'Z');
  my @used_letters=sort(keys(%letter_name_map));   my @used_letters=sort(keys(%letter_name_map));
  my $internal_counter=$Apache::lonxml::counter;   my $internal_counter=$Apache::lonxml::counter;
           my ($numrows,$bubbles_per_row);
           if (($target eq 'tex') && ($Apache::lonhomework::type eq 'exam')) {
               ($numrows,$bubbles_per_row) = 
                   &Apache::optionresponse::getnumrows(scalar(@used_letters));
           } else {
               $numrows = 1;
           }
  foreach my $name (@whichfoils) {   foreach my $name (@whichfoils) {
     my $lastopt=$lastresponse{$name};      my $lastopt=$lastresponse{$name};
     my $last_letter=$name_letter_map{$lastopt};      my $last_letter=$name_letter_map{$lastopt};
Line 618  sub displayfoils { Line 691  sub displayfoils {
     my @emptyItems = ();      my @emptyItems = ();
     for (my $i=0;$i<=$#used_letters;$i++) {push @emptyItems, ' ';}      for (my $i=0;$i<=$#used_letters;$i++) {push @emptyItems, ' ';}
     $question.='\vskip -1 mm\noindent\begin{list}{}{\setlength{\listparindent}{0mm}\setlength{\leftmargin}{2mm}}'      $question.='\vskip -1 mm\noindent\begin{list}{}{\setlength{\listparindent}{0mm}\setlength{\leftmargin}{2mm}}'
  .'\item \hskip -3mm \textbf{'.$internal_counter.'}';   .'\item \hskip -3mm ';
                       if ($numrows == 1) {
                           $question .= '\textbf{'.$internal_counter.'}';
                       } else {
                           my $linetext;
                           for (my $i=0; $i<$numrows; $i++) {
                               $linetext .= $internal_counter+$i.', ';
                           }
                           $linetext =~ s/,\s$//;
                           $question .= '\small {\textbf{'.$linetext.'}} '.
                                        '\hskip 2 mm {\footnotesize '.
                                        &mt('(Bubble once in [_1] lines)',$numrows).
                                        '} \vskip 3 mm';
                       }
                       my $max_width;
     if (&itemdisplay('left') || &itemdisplay('right')) {      if (&itemdisplay('left') || &itemdisplay('right')) {
  $question .= '\vskip -4 mm' . &Apache::optionresponse::bubbles(\@used_letters,\@emptyItems, "", $righttabsize);                          $max_width = $righttabsize;
     }                      }
     else {      $question .= '\vskip -4 mm' . &Apache::optionresponse::bubbles(\@used_letters,\@emptyItems,'',$max_width,$numrows,$bubbles_per_row,$internal_counter);
  $question .= '\vskip -4 mm' . &Apache::optionresponse::bubbles(\@used_letters,\@emptyItems);  
     }  
     $question .= '\end{list} \vskip -8 mm \strut ';      $question .= '\end{list} \vskip -8 mm \strut ';
     $internal_counter++;      $internal_counter += $numrows;
         } else {          } else {
                     if($env{'form.pdfFormFields'} eq 'yes'                       if($env{'form.pdfFormFields'} eq 'yes' 
                             && $Apache::inputtags::status['-1'] eq 'CAN_ANSWER') {                              && $Apache::inputtags::status['-1'] eq 'CAN_ANSWER') {
Line 823  sub insert_foil { Line 908  sub insert_foil {
 <endouttext />  <endouttext />
 </foil>';  </foil>';
 }  }
   
 1;  1;
 __END__  __END__

Removed from v.1.81  
changed lines
  Added in v.1.82


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>