Diff for /loncom/interface/lonnavdisplay.pm between versions 1.22.4.7 and 1.22.4.8

version 1.22.4.7, 2017/04/02 13:35:30 version 1.22.4.8, 2018/09/10 23:11:26
Line 62  sub real_handler { Line 62  sub real_handler {
         return REDIRECT;          return REDIRECT;
     }      }
   
   # ------------------------------------------------------------ Get query string
       &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['sort',
                                                                     'showOnlyHomework',
                                                                     'postsymb','register']);
     # Check if course needs to be re-initialized      # Check if course needs to be re-initialized
     my $loncaparev = $r->dir_config('lonVersion');      my $loncaparev = $r->dir_config('lonVersion');
     my ($result,@reinit) = &Apache::loncommon::needs_coursereinit($loncaparev);      my ($result,@reinit) = &Apache::loncommon::needs_coursereinit($loncaparev);
       my %prog_state=();
       my $closure;
   
     if ($result eq 'switch') {      if ($result eq 'switch') {
         &Apache::loncommon::content_type($r,'text/html');          &Apache::loncommon::content_type($r,'text/html');
Line 72  sub real_handler { Line 78  sub real_handler {
         $r->print(&Apache::loncommon::check_release_result(@reinit));          $r->print(&Apache::loncommon::check_release_result(@reinit));
         return OK;          return OK;
     } elsif ($result eq 'update') {      } elsif ($result eq 'update') {
         my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};          my $cid = $env{'request.course.id'};
         my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};          my $cnum = $env{'course.'.$cid.'.num'};
         my ($furl,$ferr) = &Apache::lonuserstate::readmap("$cdom/$cnum");          my $cdom = $env{'course.'.$cid.'.domain'};
           &Apache::loncommon::content_type($r,'text/html');
           $r->send_http_header;
           &startpage($r);
           my $preamble = '<div id="LC_update_'.$cid.'" class="LC_info">'.
                          '<br />'.
                          &mt('Your course session is being updated because of recent changes by course personnel.').
                          ' '.&mt('Please be patient.').'<br /></div>'.
                          '<div style="padding:0;clear:both;margin:0;border:0"></div>';
           $closure = <<ENDCLOSE;
   <script type="text/javascript">
   // <![CDATA[
   \$("#LC_update_$cid").hide('slow');
   // ]]>
   </script>
   ENDCLOSE
           %prog_state = &Apache::lonhtmlcommon::Create_PrgWin($r,undef,$preamble);
           &Apache::lonhtmlcommon::Update_PrgWin($r,\%prog_state,&mt('Updating course'));
           $r->rflush();
           my ($furl,$ferr) = &Apache::lonuserstate::readmap("$cdom/$cnum",\%prog_state,$r);
           &Apache::lonhtmlcommon::Update_PrgWin($r,\%prog_state,&mt('Finished'));
         if ($ferr) {          if ($ferr) {
               &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);
               $r->print($closure.&Apache::loncommon::end_page());
             my $requrl = $r->uri;              my $requrl = $r->uri;
             $env{'user.error.msg'}="$requrl:bre:0:0:Course not initialized";              $env{'user.error.msg'}="$requrl:bre:0:0:Course not initialized";
             $env{'user.reinit'} = 1;              $env{'user.reinit'} = 1;
Line 87  sub real_handler { Line 115  sub real_handler {
     my $navmap = Apache::lonnavmaps::navmap->new();      my $navmap = Apache::lonnavmaps::navmap->new();
   
     if (!defined($navmap)) {      if (!defined($navmap)) {
           if ($result eq 'update') {
               &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);
               $r->print($closure.&Apache::loncommon::end_page());
           }
         my $requrl = $r->uri;          my $requrl = $r->uri;
         $env{'user.error.msg'} = "$requrl:bre:0:0:Course not initialized";          $env{'user.error.msg'} = "$requrl:bre:0:0:Course not initialized";
         $env{'user.reinit'} = 1;          $env{'user.reinit'} = 1;
         return HTTP_NOT_ACCEPTABLE;          return HTTP_NOT_ACCEPTABLE;
     }      }
   
     # Send header, don't cache this page      if ($result eq 'update') {
     &Apache::loncommon::content_type($r,'text/html');          $r->rflush();
     $r->send_http_header;          &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);
           $r->print($closure);
 # ------------------------------------------------------------ Get query string          $r->rflush();
     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['sort','showOnlyHomework','postsymb','register']);  
       
 # ----------------------------------------------------- Force menu registration  
     # Header  
     my $course_type = &Apache::loncommon::course_type();  
     my $title = $course_type . ' Contents';  
     my ($start_page,$args);  
     if ($env{'form.register'}) {  
         $args = {'force_register' => $env{'form.register'}};  
         $start_page = &Apache::loncommon::start_page($title,undef,$args);  
     } else {      } else {
         my $brcrum = [{href => '/adm/navmaps',          # Send header, don't cache this page
                        text => &mt($course_type . ' Contents'),          &Apache::loncommon::content_type($r,'text/html');
                        no_mt => 1},          $r->send_http_header;
                      ];          &startpage($r);
         $args = {'bread_crumbs' => $brcrum};  
         $start_page = &Apache::loncommon::start_page($title,undef,$args);  
     }      }
     $r->print($start_page.  
               '<script type="text/javascript">window.focus();</script>');  
     &startContentScreen($r,'navmaps');      &startContentScreen($r,'navmaps');
     $r->rflush();      unless ($result eq 'update') {
           $r->rflush();
       }
   
     # Check that it's defined      # Check that it's defined
     if (!($navmap->courseMapDefined())) {      if (!($navmap->courseMapDefined())) {
Line 304  sub real_handler { Line 325  sub real_handler {
     return OK;      return OK;
 }  }
   
   sub startpage {
       my ($r) = @_;
   # ----------------------------------------------------- Force menu registration
       # Header
       my $course_type = &Apache::loncommon::course_type();
       my $title = $course_type . ' Contents';
       my ($start_page,$args);
       if ($env{'form.register'}) {
           $args = {'force_register' => $env{'form.register'}};
           $start_page = &Apache::loncommon::start_page($title,undef,$args);
       } else {
           my $brcrum = [{href => '/adm/navmaps',
                          text => &mt($course_type . ' Contents'),
                          no_mt => 1},
                        ];
           $args = {'bread_crumbs' => $brcrum};
           $start_page = &Apache::loncommon::start_page($title,undef,$args);
       }
       $r->print($start_page.
                 '<script type="text/javascript">'."\n".
                 '// <![CDATA['."\n".
                 'window.focus();'."\n".
                 '// ]]>'."\n".
                 '</script>');
       return;
   }
   
 sub startContentScreen {  sub startContentScreen {
     my ($r,$mode)=@_;      my ($r,$mode)=@_;
   

Removed from v.1.22.4.7  
changed lines
  Added in v.1.22.4.8


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