Diff for /rat/lonpage.pm between versions 1.115 and 1.122

version 1.115, 2016/05/30 04:50:39 version 1.122, 2017/02/22 22:10:20
Line 184  sub handler { Line 184  sub handler {
   if (($env{'request.course.fn'}) && (!$env{'form.forceselect'})) {    if (($env{'request.course.fn'}) && (!$env{'form.forceselect'})) {
       my $fn=$env{'request.course.fn'};        my $fn=$env{'request.course.fn'};
       if (-e "$fn.db") {        if (-e "$fn.db") {
             my %buttonshide;
             my $hostname = $r->hostname();
           if (tie(%hash,'GDBM_File',"$fn.db",&GDBM_READER(),0640)) {            if (tie(%hash,'GDBM_File',"$fn.db",&GDBM_READER(),0640)) {
 # ------------------------------------------------------------------- Hash tied  # ------------------------------------------------------------------- Hash tied
               my $firstres=$hash{'map_start_'.$requrl};                my $firstres=$hash{'map_start_'.$requrl};
Line 300  sub handler { Line 302  sub handler {
                       $lcm*=($#colcont+1)/euclid($lcm,($#colcont+1));                        $lcm*=($#colcont+1)/euclid($lcm,($#colcont+1));
                       foreach (@colcont) {                        foreach (@colcont) {
                           my $src=$hash{'src_'.$_};                            my $src=$hash{'src_'.$_};
                             my $plainsrc = $src;
                           my ($extension)=($src=~/\.(\w+)$/);                            my ($extension)=($src=~/\.(\w+)$/);
   $cellexternal{$_}=($hash{'ext_'.$_} eq 'true:');    $cellexternal{$_}=($hash{'ext_'.$_} eq 'true:');
   if ($hash{'encrypted_'.$_}) {    if ($hash{'encrypted_'.$_}) {
       $src=&Apache::lonenc::encrypted($src);        $src=&Apache::lonenc::encrypted($src);
   }    }
                             my ($mapid,$resid)=split(/\./,$_);
                             my $symb=&Apache::lonnet::encode_symb($hash{'map_id_'.$mapid},$resid,$src);
                             unless ($env{'request.role.adv'}) {
                                 $buttonshide{$symb} = &Apache::lonnet::EXT("resource.0.buttonshide",$symb);
                             }
                           $cellemb{$_}=                            $cellemb{$_}=
       &Apache::loncommon::fileembstyle($extension);        &Apache::loncommon::fileembstyle($extension);
                           if ($cellexternal{$_}) {                            if ($cellexternal{$_}) {
Line 315  ENDEXT Line 323  ENDEXT
                               }                                }
                           } elsif ($cellemb{$_} eq 'ssi') {                            } elsif ($cellemb{$_} eq 'ssi') {
 # --------------------------------------------------------- This is an SSI cell  # --------------------------------------------------------- This is an SSI cell
       my ($mapid,$resid)=split(/\./,$_);  
       my $symb=&Apache::lonnet::encode_symb($hash{'map_id_'.$mapid},$resid,$src);  
         
       my $prefix=$_.'_';        my $prefix=$_.'_';
                               my $idprefix= join('_',($mapid,$resid,''));                                my $idprefix= join('_',($mapid,$resid,''));
                               my %posthash=('request.prefix' => $prefix,                                my %posthash=('request.prefix' => $prefix,
Line 355  ENDEXT Line 360  ENDEXT
                               my $output=Apache::lonnet::ssi($src,%posthash);                                my $output=Apache::lonnet::ssi($src,%posthash);
       $output=~s|//(\s*<!--)? BEGIN LON-CAPA Internal.+?// END LON-CAPA Internal\s*(-->)?\s||gs;        $output=~s|//(\s*<!--)? BEGIN LON-CAPA Internal.+?// END LON-CAPA Internal\s*(-->)?\s||gs;
                               if (($target eq 'tex') || ($target eq 'tex_answer')) {                                if (($target eq 'tex') || ($target eq 'tex_answer')) {
   $output =~ s/^([^&]+)\\begin{document}//;    $output =~ s/^([^&]+)\\begin\{document}//;
   $output =~ s/\\end{document}//;    $output =~ s/\\end\{document}//;
 #  $output = '\parbox{\minipagewidth}{ '.$output.' }';  #  $output = '\parbox{\minipagewidth}{ '.$output.' }';
                                   #some additional cleanup necessary for LateX (due to limitations of table environment                                     #some additional cleanup necessary for LateX (due to limitations of table environment 
   $output =~ s/(\\vskip\s*\d+mm)\s*(\\\\)+/$1/g;    $output =~ s/(\\vskip\s*\d+mm)\s*(\\\\)+/$1/g;
Line 471  ENDEXT Line 476  ENDEXT
                                   $output=~                                    $output=~
                                       s/\<(input[^\>]+\Qonfocus=\"javascript:disableAutoComplete\E)\(\'([^\']+)\'\)(;\")/\<$1('$idprefix$2')$3/gsi;                                        s/\<(input[^\>]+\Qonfocus=\"javascript:disableAutoComplete\E)\(\'([^\']+)\'\)(;\")/\<$1('$idprefix$2')$3/gsi;
                                   unless ($hastimer) {                                    unless ($hastimer) {
                                       if ($src =~ /$LONCAPA::assess_re/) {                                        if ($plainsrc =~ /$LONCAPA::assess_re/) {
                                           %Apache::lonhomework::history =                                            %Apache::lonhomework::history =
                                               &Apache::lonnet::restore($symb,$courseid,$domain,$name);                                                &Apache::lonnet::restore($symb,$courseid,$domain,$name);
                                           my $type = 'problem';                                            my $type = 'problem';
                                           if ($src =~ /\.task$/) {                                            if ($extension eq 'task') {
                                               $type = 'Task';                                                $type = 'Task';
                                           }                                            }
                                           my ($status,$accessmsg,$slot_name,$slot) =                                            my ($status,$accessmsg,$slot_name,$slot) =
                                               &Apache::lonhomework::check_slot_access('0',$type,$symb,$pagesymb);                                                &Apache::lonhomework::check_slot_access('0',$type,$symb);
                                           undef(%Apache::lonhomework::history);                                            undef(%Apache::lonhomework::history);
                                           my $probstatus = &Apache::lonnet::EXT("resource.0.problemstatus",$symb);                                            my $probstatus = &Apache::lonnet::EXT("resource.0.problemstatus",$symb);
                                           if (($status eq 'CAN_ANSWER') || (($status eq 'CANNOT_ANSWER') &&                                             if (($status eq 'CAN_ANSWER') || (($status eq 'CANNOT_ANSWER') && 
Line 676  ENDEXT Line 681  ENDEXT
                                   &add_countdown_timer($currdisp,$donebuttontime,$donebuttonextras);                                    &add_countdown_timer($currdisp,$donebuttontime,$donebuttonextras);
                               }                                }
                           }                            }
                             my $pagebuttonshide;
                             if (keys(%buttonshide)) {
                                 my %uniquebuttonhide;
                                 foreach my $item (values(%buttonshide)) {
                                     if (exists($uniquebuttonhide{$item})) {
                                         $uniquebuttonhide{$item} ++;
                                     } else {
                                         $uniquebuttonhide{$item} = 1;
                                     }
                                 }
                                 if (keys(%uniquebuttonhide) == 1) {
                                     if (lc((keys(%uniquebuttonhide))[0]) eq 'yes') {
                                         $pagebuttonshide = 'yes';
                                     }
                                 }
                             }
 # ------------------------------------------------------------------ Start body  # ------------------------------------------------------------------ Start body
   $r->print(&Apache::loncommon::start_page(undef,$allscript,    $r->print(&Apache::loncommon::start_page(undef,$allscript,
    {'force_register' => 1,     {'force_register' => 1,
     'bgcolor'        => '#ffffff',}));      'bgcolor'        => '#ffffff',
       'hide_buttons'   => $pagebuttonshide}));
 # ------------------------------------------------------------------ Start form  # ------------------------------------------------------------------ Start form
   if ($nforms) {    if ($nforms) {
       my $fmtag = '<form name="lonhomework" method="post"  enctype="multipart/form-data"';        my $fmtag = '<form name="lonhomework" method="post"  enctype="multipart/form-data"';
Line 725  ENDEXT Line 747  ENDEXT
                           my $avespan=$lcm/($#colcont+1);                            my $avespan=$lcm/($#colcont+1);
                           for ($j=0;$j<=$#colcont;$j++) {                            for ($j=0;$j<=$#colcont;$j++) {
                               my $rid=$colcont[$j];                                my $rid=$colcont[$j];
       my $metainfo =&get_buttons(\%hash,$rid).'<br />';        my $metainfo =&get_buttons(\%hash,$rid,\%buttonshide,$hostname).'<br />';
     unless (($target eq 'tex') || ($target eq 'tex_answer')) {      unless (($target eq 'tex') || ($target eq 'tex_answer')) {
  $r->print('<td colspan="'.$avespan.'"');   $r->print('<td colspan="'.$avespan.'"');
     }      }
Line 853  ENDEXT Line 875  ENDEXT
 }  }
   
 sub get_buttons {  sub get_buttons {
     my ($hash,$rid) = @_;      my ($hash,$rid,$buttonshide,$hostname) = @_;
   
     my $metainfo = '';      my $metainfo = '';
     my $esrc=&Apache::lonnet::declutter($hash->{'src_'.$rid});      my $esrc=&Apache::lonnet::declutter($hash->{'src_'.$rid});
Line 862  sub get_buttons { Line 884  sub get_buttons {
   $resid,    $resid,
   $hash->{'src_'.$rid});    $hash->{'src_'.$rid});
     unless ($env{'request.role.adv'}) {      unless ($env{'request.role.adv'}) {
         if (&Apache::lonnet::EXT('resource.0.buttonshide',$symb)) {          if ($buttonshide->{$symb} eq 'yes') {
             return;              return;
         }          }
     }      }
Line 932  sub get_buttons { Line 954  sub get_buttons {
         if ($cfile ne '') {          if ($cfile ne '') {
             my $jscall = &Apache::lonhtmlcommon::jump_to_editres($cfile,$home,$switchserver,              my $jscall = &Apache::lonhtmlcommon::jump_to_editres($cfile,$home,$switchserver,
                                                                  $forceedit,1,$symb,undef,                                                                   $forceedit,1,$symb,undef,
                                                                  &escape($env{'form.title'}));                                                                   &escape($env{'form.title'}),
                                                                    $hostname);
             if ($jscall) {              if ($jscall) {
                 my $icon = 'pcstr.png';                  my $icon = 'pcstr.png';
                 my $label = &mt('Edit');                  my $label = &mt('Edit');
Line 962  sub add_countdown_timer { Line 985  sub add_countdown_timer {
             $type = $donebuttonextras->{'type'};              $type = $donebuttonextras->{'type'};
         } else {          } else {
             $donebuttontext = &mt('Done');              $donebuttontext = &mt('Done');
               $type = 'map';
         }          }
         $donebutton =           $donebutton = 
             &Apache::lonmenu::done_button_js($type,'','',$proctor,$donebuttontext);              &Apache::lonmenu::done_button_js($type,'','',$proctor,$donebuttontext);

Removed from v.1.115  
changed lines
  Added in v.1.122


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>
500 Internal Server Error

Internal Server Error

The server encountered an internal error or misconfiguration and was unable to complete your request.

Please contact the server administrator at root@localhost to inform them of the time this error occurred, and the actions you performed just before this error.

More information about this error may be available in the server error log.