Diff for /loncom/interface/lonnavdisplay.pm between versions 1.35 and 1.39

version 1.35, 2017/11/16 13:41:56 version 1.39, 2022/06/11 04:32:23
Line 39  use Apache::lonnet; Line 39  use Apache::lonnet;
 use Apache::lonlocal;  use Apache::lonlocal;
 use Apache::londocs();  use Apache::londocs();
 use Apache::lonuserstate;  use Apache::lonuserstate;
   use LONCAPA::ltiutils;
   
 sub handler {  sub handler {
     my $r = shift;      my $r = shift;
Line 65  sub real_handler { Line 66  sub real_handler {
 # ------------------------------------------------------------ Get query string  # ------------------------------------------------------------ Get query string
     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['sort',      &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['sort',
                                                                   'showOnlyHomework',                                                                    'showOnlyHomework',
                                                                   'postsymb','register']);                                                                    'postsymb']);
     # 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);
Line 87  sub real_handler { Line 88  sub real_handler {
         my $preamble = '<div id="LC_update_'.$cid.'" class="LC_info">'.          my $preamble = '<div id="LC_update_'.$cid.'" class="LC_info">'.
                        '<br />'.                         '<br />'.
                        &mt('Your course session is being updated because of recent changes by course personnel.').                         &mt('Your course session is being updated because of recent changes by course personnel.').
                        ' '.&mt('Please be patient.').'<br /></div>'.                         ' '.&mt('Please be patient').'.<br /></div>'.
                        '<div style="padding:0;clear:both;margin:0;border:0"></div>';                         '<div style="padding:0;clear:both;margin:0;border:0"></div>';
         $closure = <<ENDCLOSE;          $closure = <<ENDCLOSE;
 <script type="text/javascript">  <script type="text/javascript">
Line 100  ENDCLOSE Line 101  ENDCLOSE
         &Apache::lonhtmlcommon::Update_PrgWin($r,\%prog_state,&mt('Updating course'));          &Apache::lonhtmlcommon::Update_PrgWin($r,\%prog_state,&mt('Updating course'));
         $r->rflush();          $r->rflush();
         my ($furl,$ferr) = &Apache::lonuserstate::readmap("$cdom/$cnum",\%prog_state,$r);          my ($furl,$ferr) = &Apache::lonuserstate::readmap("$cdom/$cnum",\%prog_state,$r);
         &Apache::lonhtmlcommon::Update_PrgWin($r,\%prog_state,&mt('Finished'));          &Apache::lonhtmlcommon::Update_PrgWin($r,\%prog_state,&mt('Finished!'));
         if ($ferr) {          if ($ferr) {
             &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);              &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);
             $r->print($closure.&Apache::loncommon::end_page());              $r->print($closure.&Apache::loncommon::end_page());
Line 125  ENDCLOSE Line 126  ENDCLOSE
         }          }
     }      }
   
       if ($env{'request.lti.login'}) {
           if ($env{'request.lti.uri'} ne '') {
               my $cid = $env{'request.course.id'};
               my $cnum = $env{'course.'.$cid.'.num'};
               my $cdom = $env{'course.'.$cid.'.domain'};
               my ($scope,$url) = &LONCAPA::ltiutils::lti_provider_scope($env{'request.lti.uri'},$cdom,$cnum);
               if (($scope eq 'map') || ($scope eq 'resource')) {
                   &Apache::loncommon::content_type($r,'text/html');
                   $r->header_out(Location => $url);
                   return REDIRECT;
               }
           }
       }
   
     # Create the nav map      # Create the nav map
     my $navmap = Apache::lonnavmaps::navmap->new();      my $navmap = Apache::lonnavmaps::navmap->new();
   
Line 242  ENDCLOSE Line 257  ENDCLOSE
                      ."</span>");                       ."</span>");
         }          }
     } else {      } else {
         my $link = 'navmaps?jumpToFirstHomework';          my $link = '/adm/navmaps?jumpToFirstHomework';
         if ($env{'form.register'}) {  
             $link .= '&amp;register='.$env{'form.register'};   
         }  
         unless ($notools) {          unless ($notools) {
     &Apache::lonnavmaps::add_linkitem(\%toplinkitems,'firsthomework',      &Apache::lonnavmaps::add_linkitem(\%toplinkitems,'firsthomework',
       'location.href="'.$link.'"',        'location.href="'.$link.'"',
Line 265  ENDCLOSE Line 277  ENDCLOSE
         $filterFunc = sub { my $res = shift;           $filterFunc = sub { my $res = shift; 
                             return $res->completable() || $res->is_map();                              return $res->completable() || $res->is_map();
                         };                          };
         my $link = 'navmaps?sort='.$env{'form.sort'};          my $link = '/adm/navmaps?sort='.$env{'form.sort'};
         if ($env{'form.register'}) {  
             $link .= '&amp;register='.$env{'form.register'};  
         }  
  &Apache::lonnavmaps::add_linkitem(\%toplinkitems,'everything',   &Apache::lonnavmaps::add_linkitem(\%toplinkitems,'everything',
   'location.href="'.$link.'"',    'location.href="'.$link.'"',
   'Show everything');    'Show everything');
Line 277  ENDCLOSE Line 286  ENDCLOSE
         $env{'form.condition'} = 1;          $env{'form.condition'} = 1;
  $resource_no_folder_link = 1;   $resource_no_folder_link = 1;
     } else {      } else {
         my $link = 'navmaps?sort='.$env{'form.sort'}.'&amp;showOnlyHomework=1';          my $link = '/adm/navmaps?sort='.$env{'form.sort'}.'&amp;showOnlyHomework=1';
         if ($env{'form.register'}) {  
             $link .= '&amp;register='.$env{'form.register'};  
         }  
         unless ($notools) {          unless ($notools) {
     &Apache::lonnavmaps::add_linkitem(\%toplinkitems,'uncompleted',      &Apache::lonnavmaps::add_linkitem(\%toplinkitems,'uncompleted',
       'location.href="'.$link.'"',        'location.href="'.$link.'"',
Line 302  ENDCLOSE Line 308  ENDCLOSE
                        <option value="duedate"'.$selected{'duedate'}.'>'.&mt('Due Date').'</option>                         <option value="duedate"'.$selected{'duedate'}.'>'.&mt('Due Date').'</option>
                        <option value="discussion"'.$selected{'discussion'}.'>'.&mt('Has New Discussion').'</option>                         <option value="discussion"'.$selected{'discussion'}.'>'.&mt('Has New Discussion').'</option>
                     </select>                      </select>
                     <input type="hidden" name="register" value="'.$env{'form.register'}.'" />  
                  </span>                   </span>
                </form>');                 </form>');
     }      }
Line 345  sub startpage { Line 350  sub startpage {
     # Header      # Header
     my $course_type = &Apache::loncommon::course_type();      my $course_type = &Apache::loncommon::course_type();
     my $title = $course_type . ' Contents';      my $title = $course_type . ' Contents';
     my ($start_page,$args);      my $brcrum = [{href => '/adm/navmaps',
     if ($env{'form.register'}) {                     text => &mt($course_type . ' Contents'),
         $args = {'force_register' => $env{'form.register'}};                     no_mt => 1},
         $start_page = &Apache::loncommon::start_page($title,undef,$args);                   ];
     } else {      my $args = {'bread_crumbs' => $brcrum};
         my $brcrum = [{href => '/adm/navmaps',      my $start_page = &Apache::loncommon::start_page($title,undef,$args);
                        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.      $r->print($start_page.
               '<script type="text/javascript">'."\n".                '<script type="text/javascript">'."\n".
               '// <![CDATA['."\n".                '// <![CDATA['."\n".

Removed from v.1.35  
changed lines
  Added in v.1.39


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