Diff for /rat/lonpageflip.pm between versions 1.80.8.10 and 1.97

version 1.80.8.10, 2018/09/10 19:17:39 version 1.97, 2017/11/16 13:42:01
Line 36  use LONCAPA; Line 36  use LONCAPA;
 use Apache::Constants qw(:common :http REDIRECT);  use Apache::Constants qw(:common :http REDIRECT);
 use Apache::lonnet;  use Apache::lonnet;
 use Apache::loncommon();  use Apache::loncommon();
   use Apache::lonnavmaps();
 use Apache::lonuserstate;  use Apache::lonuserstate;
 use Apache::lonlocal;  use Apache::lonlocal;
 use HTML::TokeParser;  use HTML::TokeParser;
Line 255  sub first_accessible_resource { Line 256  sub first_accessible_resource {
     }      }
 }  }
   
   sub first_answerable_ressymb {
       my $navmap = Apache::lonnavmaps::navmap->new;
       return unless (ref($navmap));
       my $iterator = $navmap->getIterator(undef,undef,undef,1);
       return unless (ref($iterator));
       my ($curRes,$result);
       while ($curRes = $iterator->next()) {
           if (ref($curRes) && $curRes->is_problem()) {
               foreach my $part (@{$curRes->parts()}) {
                   if ($curRes->tries($part) < $curRes->maxtries($part)) {
                       $result = $curRes->link().'?symb='.$curRes->shown_symb();
                       last;
                   }    
               }
           }
       }
       if ($result) {
           return $result; 
       } else {
           return &first_accessible_resource(); 
       }
   }
   
   sub check_http_req {
       my ($srcref) = @_;
       return unless (ref($srcref) eq 'SCALAR');
       my $usehttp;
       if ($env{'request.course.id'}) {
           my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
           my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
           if (($$srcref =~ m{^\Q/public/$cdom/$cnum/syllabus\E($|\?)}) &&
               ($ENV{'SERVER_PORT'} == 443) &&
               ($env{'course.'.$env{'request.course.id'}.'.externalsyllabus'} =~ m{^http://})) {
               $$srcref .= (($$srcref =~/\?/)? '&':'?') . 'usehttp=1';
               $usehttp = 1;
           } elsif (($$srcref =~ m{^\Q/adm/wrapper/ext/\E(?!https:)}) &&
                    ($ENV{'SERVER_PORT'} == 443)) {
               $usehttp = 1;
           }
       }
       return $usehttp;
   }
   
 sub reinited_js {  sub reinited_js {
     my ($url,$cid,$timeout) = @_;      my ($url,$cid,$timeout) = @_;
     if (!$timeout) {      if (!$timeout) {
Line 293  sub handler { Line 337  sub handler {
   my %cachehash=();     my %cachehash=(); 
   my $multichoice=0;    my $multichoice=0;
   my %multichoicehash=();    my %multichoicehash=();
   my %prog_state=();     my %prog_state=();
   my ($redirecturl,$redirectsymb,$enc,$anchor);    my ($redirecturl,$redirectsymb,$enc,$anchor);
   my $next='';    my $next='';
     my $hostname = $r->hostname();
   my @possibilities=();    my @possibilities=();
    &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['postdata']);     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['postdata']);
   if (($env{'form.postdata'})&&($env{'request.course.fn'})) {    if (($env{'form.postdata'})&&($env{'request.course.fn'})) {
Line 313  sub handler { Line 358  sub handler {
               $last=$hash{'last_known'};                $last=$hash{'last_known'};
               untie(%hash);                untie(%hash);
           }            }
         } elsif ($direction eq 'firstanswerable') {
             my $furl = &first_answerable_ressymb();
             my $usehttp = &check_http_req(\$furl);
             if (($usehttp) && ($hostname ne '')) {
                 $furl='http://'.$hostname.$furl;
             } else {
                 $furl=&Apache::lonnet::absolute_url().$furl;
             }
             &Apache::loncommon::content_type($r,'text/html');
             $r->header_out(Location => $furl);
             return REDIRECT;
         } elsif ($direction eq 'endplacement') {
             &Apache::loncommon::content_type($r,'text/html');
             $r->send_http_header;
             $r->print(&Apache::lonplacementtest::showresult());
             return OK;
       }        }
       if ($env{'request.course.id'}) {        if ($env{'request.course.id'}) {
           # Check if course needs to be re-initialized            # Check if course needs to be re-initialized
Line 364  sub handler { Line 425  sub handler {
       }        }
       if ($direction eq 'firstres') {        if ($direction eq 'firstres') {
   my $furl=&first_accessible_resource();    my $furl=&first_accessible_resource();
           $furl=&Apache::lonnet::absolute_url().$furl;            my $usehttp = &check_http_req(\$furl);
             if (($usehttp) && ($hostname ne '')) {
                 $furl='http://'.$hostname.$furl;
             } else {
                 $furl=&Apache::lonnet::absolute_url().$furl;
             }
           if ($reinitcheck eq 'update') {            if ($reinitcheck eq 'update') {
               &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);                &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);
               $r->print(&reinited_js($furl,$env{'request.course.id'},100));                $r->print(&reinited_js($furl,$env{'request.course.id'},100));
Line 378  sub handler { Line 444  sub handler {
       }        }
       if ($direction eq 'return') {         if ($direction eq 'return') { 
 # -------------------------------------------------------- Return to last known  # -------------------------------------------------------- Return to last known
          my $newloc;           my ($newloc,$usehttp);
          if (($last) && (tie(%hash,'GDBM_File',$env{'request.course.fn'}.'.db',           if (($last) && (tie(%hash,'GDBM_File',$env{'request.course.fn'}.'.db',
                         &GDBM_READER(),0640))) {                          &GDBM_READER(),0640))) {
             my ($murl,$id,$fn)=&Apache::lonnet::decode_symb($last);              my ($murl,$id,$fn)=&Apache::lonnet::decode_symb($last);
     $id=$hash{'map_pc_'.&Apache::lonnet::clutter($murl)}.'.'.$id;      $id=$hash{'map_pc_'.&Apache::lonnet::clutter($murl)}.'.'.$id;
     $newloc=$hash{'src_'.$id};      $newloc=$hash{'src_'.$id};
     if ($newloc) {      if ($newloc) {
  if ($hash{'encrypted_'.$id}) { $newloc=&Apache::lonenc::encrypted($newloc); }                  $usehttp = &check_http_req(\$newloc);
    if ($hash{'encrypted_'.$id}) { 
                       $newloc=&Apache::lonenc::encrypted($newloc);
                   } elsif ($newloc =~ m{^(/adm/wrapper/ext/[^\#]+)\#([^\#]+)$}) {
                       $newloc = $1.&escape('#').$2;
                   }
     } else {      } else {
  $newloc='/adm/navmaps';   $newloc='/adm/navmaps';
     }      }
Line 393  sub handler { Line 464  sub handler {
          } else {           } else {
     $newloc='/adm/navmaps';      $newloc='/adm/navmaps';
          }           }
          $newloc=&Apache::lonnet::absolute_url().$newloc;           if (($usehttp) && ($hostname ne '')) {
                $newloc='http://'.$hostname.$newloc;
            } else {
                $newloc=&Apache::lonnet::absolute_url().$newloc
            }
          if ($reinitcheck eq 'update') {           if ($reinitcheck eq 'update') {
              $r->print(&reinited_js($newloc,$env{'request.course.id'},100));               $r->print(&reinited_js($newloc,$env{'request.course.id'},100));
              $r->print(&Apache::loncommon::end_page());               $r->print(&Apache::loncommon::end_page());
              return OK;               return OK;
          } else {           } else {
              &Apache::loncommon::content_type($r,'text/html');       &Apache::loncommon::content_type($r,'text/html');
              $r->header_out(Location => $newloc);       $r->header_out(Location => $newloc);
              return REDIRECT;       return REDIRECT;
          }           }
       }        }
 #  #
Line 416  sub handler { Line 491  sub handler {
              $last=$hash{'last_known'};               $last=$hash{'last_known'};
              untie(%hash);               untie(%hash);
          }           }
            my $newloc;
          if ($last) {           if ($last) {
      $currenturl=&Apache::lonnet::clutter((&Apache::lonnet::decode_symb($last))[2]);       $currenturl=&Apache::lonnet::clutter((&Apache::lonnet::decode_symb($last))[2]);
  } else {   } else {
              my $newloc = &Apache::lonnet::absolute_url().               my $newloc = &Apache::lonnet::absolute_url().
                           '/adm/navmaps';                            '/adm/navmaps'; 
              if ($reinitcheck eq 'update') {               if ($reinitcheck eq 'update') {
                  &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);                   &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);
                  $r->print(&reinited_js($newloc,$env{'request.course.id'},100));                   $r->print(&reinited_js($newloc,$env{'request.course.id'},100));
                  $r->print(&Apache::loncommon::end_page());                   $r->print(&Apache::loncommon::end_page());
                  return OK;                   return OK;
              } else {               } else {
                  &Apache::loncommon::content_type($r,'text/html');           &Apache::loncommon::content_type($r,'text/html');
          $r->header_out(Location => $newloc);           $r->header_out(Location => $newloc); 
          return REDIRECT;           return REDIRECT;
              }               }
          }           }
Line 509  sub handler { Line 585  sub handler {
                      &Apache::lonnet::linklog($redirecturl,$currenturl);                       &Apache::lonnet::linklog($redirecturl,$currenturl);
   }    }
 # ------------------------------------- Check for and display critical messages  # ------------------------------------- Check for and display critical messages
                   my ($redirect, $url) = &Apache::loncommon::critical_redirect(300);                    my ($redirect, $url) = &Apache::loncommon::critical_redirect(300,'flip');
                   unless ($redirect) {                    unless ($redirect) {
                       $url=&Apache::lonnet::absolute_url().$redirecturl;                        my $usehttp = &check_http_req(\$redirecturl);
                         if (($usehttp) && ($hostname ne '')) {
                             $url='http://'.$hostname.$redirecturl;
                         } else {
                             $url=&Apache::lonnet::absolute_url().$redirecturl;
                         }
                       my $addanchor;                        my $addanchor;
                       if (($anchor ne '') && (!$enc || $env{'request.role.adv'})) {                        if (($anchor ne '') && (!$enc || $env{'request.role.adv'})) {
                           $addanchor = 1;                            $addanchor = 1;
Line 524  sub handler { Line 605  sub handler {
                   }                    }
                   if ($reinitcheck eq 'update') {                    if ($reinitcheck eq 'update') {
                       &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);                        &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);
                       $r->print(&reinited_js($url,$env{'request.course.id'},100));                        $r->print(&reinited_js($url,$env{'request.course.id'},100)); 
                       $r->print(&Apache::loncommon::end_page());                        $r->print(&Apache::loncommon::end_page());
                       return OK;                        return OK;
                   } else {                    } else {
Line 549  sub handler { Line 630  sub handler {
      'type' => 'Type',       'type' => 'Type',
                                                      'update' => 'Content updated',                                                       'update' => 'Content updated',
                                                      'expupdate' => 'As a result of a recent update to the sequence of materials, it is not possible to complete the page flip.',                                                       'expupdate' => 'As a result of a recent update to the sequence of materials, it is not possible to complete the page flip.',
                                                      'gonav' => 'Go to the Contents page to select a resource to display.');                                                       'gonav' => 'Go to the Contents page to select a resource to display.',
                                                        );
                   if (&Apache::loncommon::course_type() eq 'Community') {                    if (&Apache::loncommon::course_type() eq 'Community') {
                       $lt{'nav'} = &mt('Community Contents');                        $lt{'nav'} = &mt('Community Contents');
                   }                    }
Line 566  $lt{'pick'}: Line 648  $lt{'pick'}:
 <tr><th>$lt{'titleheader'}</th><th>$lt{'type'}</th></tr>  <tr><th>$lt{'titleheader'}</th><th>$lt{'type'}</th></tr>
 ENDSTART  ENDSTART
                      foreach my $id (@possibilities) {                       foreach my $id (@possibilities) {
                           my $src = $multichoicehash{'src_'.$id};
                           my $usehttp = &check_http_req(\$src);
                           if (($usehttp) && ($hostname ne '')) {
                               $src = 'http://'.$hostname.$src;
                           }
                         $r->print(                          $r->print(
                               '<tr><td><a href="'.                                '<tr><td><a href="'.
   &add_get_param($multichoicehash{'src_'.$id},    &add_get_param($src,
  {'symb' =>   {'symb' =>
       $multichoicehash{'symb_'.$id},        $multichoicehash{'symb_'.$id},
   }).'">'.    }).'">'.
Line 590  ENDSTART Line 677  ENDSTART
                                   .'<p>'.$lt{'expupdate'}.'<br />'                                    .'<p>'.$lt{'expupdate'}.'<br />'
                                   .$lt{'gonav'}.'</p>');                                    .$lt{'gonav'}.'</p>');
                       } else {                        } else {
                           $r->print(                            if (($env{'course.'.$env{'request.course.id'}.'.type'} eq 'Placement') && 
                               &Apache::loncommon::start_page('No Resource')                                (!$env{'request.role.adv'})) {
                              .'<h2>'.$lt{'title'}.'</h2>'                                my ($score,$incomplete) = &Apache::lonplacementtest::check_completion(undef,undef,1); 
                              .'<p>'.$lt{'explain'}.'</p>');                                if ($incomplete) {
                                     $r->print(&Apache::lonplacementtest::showincomplete($incomplete)); 
                                 } else {
                                     $r->print(&Apache::lonplacementtest::showresult(1));
                                 }
                             } else {  
                                 $r->print(
                                     &Apache::loncommon::start_page('No Resource')
                                    .'<h2>'.$lt{'title'}.'</h2>'
                                    .'<p>'.$lt{'explain'}.'</p>');
                             }
                       }                        }
   }    }
                   if ((!@possibilities) && ($reinitcheck))  {                    unless (($env{'course.'.$env{'request.course.id'}.'.type'} eq 'Placement') ||
                       $r->print(                            ($env{'request.role.adv'})) {
                           &Apache::lonhtmlcommon::actionbox(                        if ((!@possibilities) && ($reinitcheck))  {
                               ['<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>'                            $r->print(
                               ]));                                &Apache::lonhtmlcommon::actionbox(
                   } else {                                    ['<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>'
                       $r->print(                                    ]));
                           &Apache::lonhtmlcommon::actionbox(                        } else {
                               ['<a href="/adm/flip?postdata=return:">'.$lt{'back'}.'</a></li>',                            $r->print(
                                '<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>'                                &Apache::lonhtmlcommon::actionbox(
                               ]));                                    ['<a href="/adm/flip?postdata=return:">'.$lt{'back'}.'</a></li>',
                                      '<a href="/adm/navmaps">'.$lt{'nav'}.'</a></li>'
                                     ]));
                         }
   
                   }                    }
                   $r->print(&Apache::loncommon::end_page());                    $r->print(&Apache::loncommon::end_page());
               
Line 617  ENDSTART Line 718  ENDSTART
               if ($reinitcheck eq 'update') {                if ($reinitcheck eq 'update') {
                   &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);                    &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);
                   $r->print(&Apache::loncommon::end_page());                    $r->print(&Apache::loncommon::end_page());
               }                } 
               $env{'user.error.msg'}="/adm/flip:bre:0:1:Course Data Missing";                $env{'user.error.msg'}="/adm/flip:bre:0:1:Course Data Missing";
               return HTTP_NOT_ACCEPTABLE;                 return HTTP_NOT_ACCEPTABLE; 
           }            }

Removed from v.1.80.8.10  
changed lines
  Added in v.1.97


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