Diff for /loncom/homework/radiobuttonresponse.pm between versions 1.143 and 1.145

version 1.143, 2009/05/23 05:04:58 version 1.145, 2010/05/03 14:43:50
Line 105  sub start_radiobuttonresponse { Line 105  sub start_radiobuttonresponse {
     $result .= ' \renewcommand{\labelenumi}{\Alph{enumi}.}';      $result .= ' \renewcommand{\labelenumi}{\Alph{enumi}.}';
  }   }
         if($env{'form.pdfFormFields'} eq 'yes' && $Apache::inputtags::status[-1] eq 'CAN_ANSWER') {          if($env{'form.pdfFormFields'} eq 'yes' && $Apache::inputtags::status[-1] eq 'CAN_ANSWER') {
             $result .= &Apache::lonxml::print_pdf_hiddenfield('meta', $env{'user.name'}, $env{'user.domain'});              $result .= '\begin{itemize}';
             $result .= "\n\\\\\n\\\\\n";  
         } else {          } else {
             $result .= '\begin{enumerate}';              $result .= '\begin{enumerate}';
         }          }
Line 122  sub end_radiobuttonresponse { Line 121  sub end_radiobuttonresponse {
     my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_;
     my $result;      my $result;
     if ($target eq 'edit') { $result=&Apache::edit::end_table(); }      if ($target eq 'edit') { $result=&Apache::edit::end_table(); }
     if ($target eq 'tex' and ($env{'form.pdfFormFields'} ne 'yes' or $Apache::inputtags::status[-1] ne 'CAN_ANSWER')) {      if ($target eq 'tex' ) {
         $result .= '\end{enumerate}';           if($env{'form.pdfFormFields'} eq 'yes' and $Apache::inputtags::status[-1] eq 'CAN_ANSWER') {
               $result .= '\end{itemize}';
           } else {
               $result .= '\end{enumerate}';
           }
     }      }
     &Apache::response::end_response;      &Apache::response::end_response;
     pop @Apache::lonxml::namespace;      pop @Apache::lonxml::namespace;
Line 146  sub start_foilgroup { Line 149  sub start_foilgroup {
 }  }
   
 sub storesurvey {  sub storesurvey {
       my ($style) = @_;
     if ( !&Apache::response::submitted() ) { return ''; }      if ( !&Apache::response::submitted() ) { return ''; }
     my $response = $env{'form.HWVAL_'.$Apache::inputtags::response['-1']};      my $response = $env{'form.HWVAL_'.$Apache::inputtags::response['-1']};
     &Apache::lonxml::debug("Here I am!:$response:");      &Apache::lonxml::debug("Here I am!:$response:");
Line 159  sub storesurvey { Line 163  sub storesurvey {
     $Apache::lonhomework::results{"resource.$part.$id.submission"}=      $Apache::lonhomework::results{"resource.$part.$id.submission"}=
  $responsestr;   $responsestr;
     my %previous=&Apache::response::check_for_previous($responsestr,$part,$id);      my %previous=&Apache::response::check_for_previous($responsestr,$part,$id);
     my $ad=$Apache::lonhomework::results{"resource.$part.$id.awarddetail"}='SUBMITTED';      my $ad;
       if ($style eq 'anonsurvey') {
           $ad=$Apache::lonhomework::results{"resource.$part.$id.awarddetail"}='ANONYMOUS';
       } elsif ($style eq 'anonsurveycred') {
           $ad=$Apache::lonhomework::results{"resource.$part.$id.awarddetail"}='ANONYMOUS_CRED';
       } elsif ($style eq 'surveycred') {
           $ad=$Apache::lonhomework::results{"resource.$part.$id.awarddetail"}='SUBMITTED_CREDIT';
       } else {
           $ad=$Apache::lonhomework::results{"resource.$part.$id.awarddetail"}='SUBMITTED';
       }
     &Apache::response::handle_previous(\%previous,$ad);      &Apache::response::handle_previous(\%previous,$ad);
     &Apache::lonxml::debug("submitted a $response<br />\n");      &Apache::lonxml::debug("submitted a $response<br />\n");
     return '';      return '';
Line 224  sub end_foilgroup { Line 237  sub end_foilgroup {
  my $style = $Apache::lonhomework::type;   my $style = $Apache::lonhomework::type;
  my $direction = &Apache::lonxml::get_param('direction',$parstack,   my $direction = &Apache::lonxml::get_param('direction',$parstack,
    $safeeval,'-2');     $safeeval,'-2');
  if ( $style eq 'survey'  && $target ne 'analyze') {   if ( (($style eq 'survey') || ($style eq 'surveycred') || 
                 ($style eq 'anonsurvey') || ($style eq 'anonsurveycred')) 
                && ($target ne 'analyze')) {
     if ($target eq 'web' || $target eq 'tex') {      if ($target eq 'web' || $target eq 'tex') {
  $result=&displayallfoils($direction, $target);   $result=&displayallfoils($direction, $target);
     } elsif ( $target eq 'answer' ) {      } elsif ( $target eq 'answer' ) {
  $result=&displayallanswers();   $result=&displayallanswers();
     } elsif ( $target eq 'grade' ) {      } elsif ( $target eq 'grade' ) {
  $result=&storesurvey();   $result=&storesurvey($style);
     }      }
     $answer_count = scalar(@{$Apache::response::foilgroup{'names'}});      $answer_count = scalar(@{$Apache::response::foilgroup{'names'}});
   
Line 321  sub displayallfoils { Line 336  sub displayallfoils {
     my $i   =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;
  $Apache::lonhomework::history{"resource.$part.$id.submission"};      unless ((($Apache::lonhomework::history{"resource.$part.type"} eq 'anonsurvey') || ($Apache::lonhomework::history{"resource.$part.type"} eq 'anonsurveycred')) && (defined($env{'form.grade_symb'}))) {
           $lastresponse = 
       $Apache::lonhomework::history{"resource.$part.$id.submission"};
       }
     if ($direction eq 'horizontal') { $result.='<table><tr>'; }      if ($direction eq 'horizontal') { $result.='<table><tr>'; }
     my %lastresponse=&Apache::lonnet::str2hash($lastresponse);      my %lastresponse=&Apache::lonnet::str2hash($lastresponse);
     if (&Apache::response::show_answer() ) {      if (&Apache::response::show_answer() ) {
Line 359  sub displayallfoils { Line 377  sub displayallfoils {
  } else {   } else {
     if ($target eq 'tex') {      if ($target eq 'tex') {
         if($env{'form.pdfFormFields'} eq 'yes' && $Apache::inputtags::status[-1] eq 'CAN_ANSWER') {          if($env{'form.pdfFormFields'} eq 'yes' && $Apache::inputtags::status[-1] eq 'CAN_ANSWER') {
                             my $fieldname = $env{'request.symb'}.                              my $fieldname = $env{'request.symb'}.'&part_'. $Apache::inputtags::part
                                            '&part_'. $Apache::inputtags::part.                                              .'&radiobuttonresponse'.'&HWVAL_'.$Apache::inputtags::response['-1'];
                                            '&radiobuttonresponse'.                              $result .= '\item[{'.&Apache::lonxml::print_pdf_radiobutton($fieldname,$temp).'}]'
                                            '&HWVAL_' . $Apache::inputtags::response['-1'];                                         .$Apache::response::foilgroup{$name.'.text'}."\n";
                             my $value = $temp;  
                             my $text = $Apache::response::foilgroup{$name.'.text'};  
                             $result .= &Apache::lonxml::print_pdf_radiobutton($fieldname,  
                                                                              $value,  
                                                                              $text)."\n";  
                         } else {                          } else {
                             $result .= '\item \vskip -2mm ';                              $result .= '\item \vskip -2mm ';
                         }                          }
Line 439  sub whichfoils { Line 452  sub whichfoils {
  &Apache::lonxml::error(&HTML::Entities::encode("No valid value assigned ($Apache::response::foilgroup{$name.'.value'}) for foil $name in <foilgroup>",'<>&"'));   &Apache::lonxml::error(&HTML::Entities::encode("No valid value assigned ($Apache::response::foilgroup{$name.'.value'}) for foil $name in <foilgroup>",'<>&"'));
     }      }
  }   }
  if (!$havetrue && $Apache::lonhomework::type ne 'survey') {   if ((!$havetrue) && 
               ($Apache::lonhomework::type ne 'survey') && 
               ($Apache::lonhomework::type ne 'surveycred') &&
               ($Apache::lonhomework::type ne 'anonsurvey') &&
               ($Apache::lonhomework::type ne 'anonsurveycred')) {
     &Apache::lonxml::error(&mt('There are no true statements available.').'<br />');      &Apache::lonxml::error(&mt('There are no true statements available.').'<br />');
  }   }
     } else {      } else {
Line 499  sub whichfoils { Line 516  sub whichfoils {
  &Apache::lonxml::debug("Answer wants $answer");   &Apache::lonxml::debug("Answer wants $answer");
  my $truename=$truelist[$whichtrue];   my $truename=$truelist[$whichtrue];
  my $dosplice=1;   my $dosplice=1;
  if ($notrue && $Apache::lonhomework::type ne 'survey') {   if (($notrue) && 
               ($Apache::lonhomework::type ne 'survey') &&
               ($Apache::lonhomework::type ne 'surveycred') &&
               ($Apache::lonhomework::type ne 'anonsurvey') &&
               ($Apache::lonhomework::type ne 'anonsurveycred')) {
     $dosplice=0;      $dosplice=0;
     &Apache::lonxml::error(&mt('There are no true statements available.').'<br />');      &Apache::lonxml::error(&mt('There are no true statements available.').'<br />');
  }   }
Line 630  sub displayfoils { Line 651  sub displayfoils {
     $i++;      $i++;
     $bubble_number++;      $bubble_number++;
  } else {   } else {
       if($env{'form.pdfFormFields'} eq 'yes' && $Apache::inputtags::status[-1] eq 'CAN_ANSWER') {                      if($env{'form.pdfFormFields'} eq 'yes' && $Apache::inputtags::status[-1] eq 'CAN_ANSWER') {
                           my $fieldname = $env{'request.symb'}.'&part_'. $Apache::inputtags::part
                          my $fieldname = $env{'request.symb'}.                                          .'&radiobuttonresponse'.'&HWVAL_'.$Apache::inputtags::response['-1'];
                                          '&part_'. $Apache::inputtags::part.                          $result .= '\item[{'.&Apache::lonxml::print_pdf_radiobutton($fieldname,$temp).'}]'
                                          '&radiobuttonresponse'.                                     .$Apache::response::foilgroup{$name.'.text'}."\n";
                                          '&HWVAL_' . $Apache::inputtags::response['-1'];                      } else { 
                          my $value = $temp;                          $result .= '\vspace*{-2 mm}\item '.$Apache::response::foilgroup{$name.'.text'};
                          my $text = $Apache::response::foilgroup{$name.'.text'};                      }
                          $result .= &Apache::lonxml::print_pdf_radiobutton($fieldname, $value, $text).'\newline'."\n";  
                      } else {   
                          $result .= '\vspace*{-2 mm}\item '.$Apache::response::foilgroup{$name.'.text'};  
                      }  
                 }                  }
     }      }
     if ($target ne 'tex' && $direction eq 'horizontal') {      if ($target ne 'tex' && $direction eq 'horizontal') {

Removed from v.1.143  
changed lines
  Added in v.1.145


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