Diff for /loncom/interface/lonmenu.pm between versions 1.366 and 1.369.2.2

version 1.366, 2011/12/28 22:41:02 version 1.369.2.2, 2012/05/14 13:58:04
Line 156  use Apache::lonlocal; Line 156  use Apache::lonlocal;
 use Apache::lonmsg();  use Apache::lonmsg();
 use LONCAPA qw(:DEFAULT :match);  use LONCAPA qw(:DEFAULT :match);
 use HTML::Entities();  use HTML::Entities();
 use Apache::lonwishlist();  
   
 use vars qw(@desklines %category_names %category_members %category_positions   use vars qw(@desklines %category_names %category_members %category_positions 
             $readdesk @primary_menu @secondary_menu);              $readdesk @primary_menu @secondary_menu);
Line 628  c&6&3 Line 627  c&6&3
 c&8&1  c&8&1
 c&8&2  c&8&2
 s&8&3&prt.png&Print&printout[_1]&gopost('/adm/printout',currentURL)&Prepare a printable document  s&8&3&prt.png&Print&printout[_1]&gopost('/adm/printout',currentURL)&Prepare a printable document
   s&9&1&sbkm.png&Bookmark&set[_1]bookmark[_2]&set_bookmark()&Set a bookmark for this resource&&1
   
 ENDMENUITEMS  ENDMENUITEMS
             if (&Apache::lonnet::allowed('bre', $env{'request.course.id'}) eq 'F' && $env{'request.uri'} =~ /^\/res/) {  
                 # wishlist is only available for users with access to resource-pool  
                 # and links can only be set for resources within the resource-pool  
                 $menuitems .= (<<ENDMENUITEMS);  
 s&9&1&wishlist-link.png&Wishlist&wishlistlink[_2]&set_wishlistlink()&Set a link for this resource to wishlist&&1  
 ENDMENUITEMS  
             }  
   
 my $currentURL = &Apache::loncommon::get_symb();  my $currentURL = &Apache::loncommon::get_symb();
 my ($symb_old,$symb_old_enc) = &Apache::loncommon::clean_symb($currentURL);  my ($symb_old,$symb_old_enc) = &Apache::loncommon::clean_symb($currentURL);
Line 665  ENDREALRES Line 659  ENDREALRES
     $menuitems .= (<<ENDMENUITEMS);      $menuitems .= (<<ENDMENUITEMS);
 s&8&3&prt.png&Print&printout[_1]&gopost('/adm/printout',currentURL)&Prepare a printable document  s&8&3&prt.png&Print&printout[_1]&gopost('/adm/printout',currentURL)&Prepare a printable document
 ENDMENUITEMS  ENDMENUITEMS
             if (&Apache::lonnet::allowed('bre', $env{'request.course.id'}) eq 'F') {  
                 # wishlist is only available for users with access to resource-pool  
                 $menuitems .= (<<ENDMENUITEMS);  
 s&9&1&wishlist-link.png&Wishlist&wishlistlink[_2]&set_wishlistlink()&Set a link for this resource to wishlist&&1  
 ENDMENUITEMS  
             }  
  }   }
         my $buttons='';          my $buttons='';
         foreach (split(/\n/,$menuitems)) {          foreach (split(/\n/,$menuitems)) {
Line 761  sub edit_course_upload { Line 749  sub edit_course_upload {
     return $cfile;      return $cfile;
 }  }
   
   sub startupremote {
       my ($lowerurl)=@_;
       if ($env{'environment.remote'} eq 'off') {
        return ('<meta HTTP-EQUIV="Refresh" CONTENT="0.5; url='.$lowerurl.'" />');
       }
   #
   # The Remote actually gets launched!
   #
       my $configmenu=&rawconfig();
       my $esclowerurl=&escape($lowerurl);
       my $message=&mt('"Waiting for Remote Control window to load: "+[_1]','waited');
       return(<<ENDREMOTESTARTUP);
   <script type="text/javascript">
   // <![CDATA[
   var timestart;
   function wheelswitch() {
       if (typeof(document.wheel) != 'undefined') {
           if (typeof(document.wheel.spin) != 'undefined') {
               var date=new Date();
               var waited=Math.round(30-((date.getTime()-timestart)/1000));
               document.wheel.spin.value=$message;
           }
       }
      if (window.status=='|') {
         window.status='/';
      } else {
         if (window.status=='/') {
            window.status='-';
         } else {
            if (window.status=='-') {
               window.status='\\\\';
            } else {
               if (window.status=='\\\\') { window.status='|'; }
            }
         }
      }
   }
   
   // ---------------------------------------------------------- The wait function
   var canceltim;
   function wait() {
      if ((menuloaded==1) || (tim==1)) {
         window.status='Done.';
         if (tim==0) {
            clearTimeout(canceltim);
            $configmenu
            window.location='$lowerurl';
         } else {
             window.location='/adm/remote?action=collapse&url=$esclowerurl';
         }
      } else {
         wheelswitch();
         setTimeout('wait();',200);
      }
   }
   
   function main() {
      canceltim=setTimeout('tim=1;',30000);
      window.status='-';
      var date=new Date();
      timestart=date.getTime();
      wait();
   }
   
   // ]]>
   </script>
   ENDREMOTESTARTUP
   }
   
   sub setflags() {
       return(<<ENDSETFLAGS);
   <script type="text/javascript">
   // <![CDATA[
       menuloaded=0;
       tim=0;
   // ]]>
   </script>
   ENDSETFLAGS
   }
   
   sub maincall() {
       if ($env{'environment.remote'} eq 'off') { return ''; }
       return(<<ENDMAINCALL);
   <script type="text/javascript">
   // <![CDATA[
       main();
   // ]]>
   </script>
   ENDMAINCALL
   }
   
   sub load_remote_msg {
       my ($lowerurl)=@_;
   
       if ($env{'environment.remote'} eq 'off') { return ''; }
   
       my $esclowerurl=&escape($lowerurl);
       my $link=&mt('[_1]Continue[_2] on in Inline Menu mode'
                   ,'<a href="/adm/remote?action=collapse&amp;url='.$esclowerurl.'">'
                   ,'</a>');
       return(<<ENDREMOTEFORM);
   <p>
   <form name="wheel">
   <input name="spin" type="text" size="60" />
   </form>
   </p>
   <p>$link</p>
   ENDREMOTEFORM
   }
   
   sub get_menu_name {
       my $hostid = $Apache::lonnet::perlvar{'lonHostID'};
       $hostid =~ s/\W//g;
       return 'LCmenu'.$hostid;
   }
   
   
   sub reopenmenu {
      if ($env{'environment.remote'} eq 'off') { return ''; }
      my $menuname = &get_menu_name();
      my $nothing = &Apache::lonhtmlcommon::javascript_nothing();
      return('window.open('.$nothing.',"'.$menuname.'","",false);');
   }
   
   
   sub open {
       my $returnval='';
       if ($env{'environment.remote'} eq 'off') {
           return
           '<script type="text/javascript">'."\n"
          .'// <![CDATA['."\n"
          .'self.name="loncapaclient";'."\n"
          .'// ]]>'."\n"
          .'</script>';
       }
       my $menuname = &get_menu_name();
   
   #    unless (shift eq 'unix') {
   # resizing does not work on linux because of virtual desktop sizes
   #       $returnval.=(<<ENDRESIZE);
   #if (window.screen) {
   #    self.resizeTo(screen.availWidth-215,screen.availHeight-55);
   #    self.moveTo(190,15);
   #}
   #ENDRESIZE
   #    }
       $returnval=(<<ENDOPEN);
   // <![CDATA[
   window.status='Opening LON-CAPA Remote Control';
   var menu=window.open("/res/adm/pages/menu.html?inhibitmenu=yes","$menuname",
   "height=375,width=150,scrollbars=no,menubar=no,top=5,left=5,screenX=5,screenY=5");
   self.name='loncapaclient';
   // ]]>
   ENDOPEN
       return '<script type="text/javascript">'.$returnval.'</script>';
   }
   
   
 # ================================================================== Raw Config  # ================================================================== Raw Config
   
 sub clear {  sub clear {
Line 1076  sub check_for_rcrs { Line 1222  sub check_for_rcrs {
     return $showreqcrs;      return $showreqcrs;
 }  }
   
   # ======================================================================= Close
   
   sub close {
       if ($env{'environment.remote'} eq 'off') { return ''; }
       my $menuname = &get_menu_name();
       return(<<ENDCLOSE);
   <script type="text/javascript">
   // <![CDATA[
   window.status='Accessing Remote Control';
   menu=window.open("/adm/rat/empty.html","$menuname",
                    "height=350,width=150,scrollbars=no,menubar=no");
   window.status='Disabling Remote Control';
   menu.active=0;
   menu.autologout=0;
   window.status='Closing Remote Control';
   menu.close();
   window.status='Done.';
   // ]]>
   </script>
   ENDCLOSE
   }
   
 sub dc_popup_js {  sub dc_popup_js {
     my %lt = &Apache::lonlocal::texthash(      my %lt = &Apache::lonlocal::texthash(
                                           more => '(More ...)',                                            more => '(More ...)',
Line 1087  function showCourseID() { Line 1255  function showCourseID() {
     document.getElementById('dccid').style.display='block';      document.getElementById('dccid').style.display='block';
     document.getElementById('dccid').style.textAlign='left';      document.getElementById('dccid').style.textAlign='left';
     document.getElementById('dccid').style.textFace='normal';      document.getElementById('dccid').style.textFace='normal';
     document.getElementById('dccidtext').innerHTML ='<a href="javascript:hideCourseID();">$lt{'less'}</a>';      document.getElementById('dccidtext').innerHTML ='<a href="javascript:hideCourseID();" class="LC_menubuttons_link">$lt{'less'}</a>';
     return;      return;
 }  }
   
 function hideCourseID() {  function hideCourseID() {
     document.getElementById('dccid').style.display='none';      document.getElementById('dccid').style.display='none';
     document.getElementById('dccidtext').innerHTML ='<a href="javascript:showCourseID()">$lt{'more'}</a>';      document.getElementById('dccidtext').innerHTML ='<a href="javascript:showCourseID()" class="LC_menubuttons_link">$lt{'more'}</a>';
     return;      return;
 }  }
   
Line 1129  sub utilityfunctions { Line 1297  sub utilityfunctions {
     my $end_page_annotate =       my $end_page_annotate = 
         &Apache::loncommon::end_page({'js_ready' => 1});          &Apache::loncommon::end_page({'js_ready' => 1});
   
       my $start_page_bookmark =
           &Apache::loncommon::start_page('Bookmarks',undef,
                                          {'only_body' => 1,
                                           'js_ready'  => 1,
                                           'bgcolor'   => '#BBBBBB',});
   
       my $end_page_bookmark =
           &Apache::loncommon::end_page({'js_ready' => 1});
   
     my $confirm_switch = &mt("Editing requires switching to the resource's home server.").'\n'.      my $confirm_switch = &mt("Editing requires switching to the resource's home server.").'\n'.
                          &mt('Switch server?');                           &mt('Switch server?');
   
       my $esc_url=&escape($currenturl);
       my $esc_symb=&escape($currentsymb);
   
 return (<<ENDUTILITY)  return (<<ENDUTILITY)
   
     var currentURL="$currenturl";      var currentURL=unescape("$esc_url");
     var reloadURL="$currenturl";      var reloadURL=unescape("$esc_url");
     var currentSymb="$currentsymb";      var currentSymb=unescape("$esc_symb");
   
 $dc_popup_cid  $dc_popup_cid
   
Line 1243  function group_chat(group) { Line 1422  function group_chat(group) {
    grpchat=window.open(url,winName,'height=320,width=280,resizable=yes,location=no,menubar=no,toolbar=no');     grpchat=window.open(url,winName,'height=320,width=280,resizable=yes,location=no,menubar=no,toolbar=no');
 }  }
   
   function edit_bookmarks() {
      go('');
      w_BookmarkPal_flag=1;
      bookmarkpal=window.open("/adm/bookmarks",
                  "BookmarkPal", "width=500,height=505,scrollbars=0");
   }
   
 function annotate() {  function annotate() {
    w_Annotator_flag=1;     w_Annotator_flag=1;
    annotator=window.open('','Annotator','width=365,height=265,scrollbars=0');     annotator=window.open('','Annotator','width=365,height=265,scrollbars=0');
Line 1256  function annotate() { Line 1442  function annotate() {
    annotator.document.close();     annotator.document.close();
 }  }
   
 function open_Wishlist_Import(rat) {  function set_bookmark() {
    var newWin;     go('');
    if (rat) {     clienttitle=document.title;
        newWin = window.open('/adm/wishlist?inhibitmenu=yes&mode=import&rat='+rat,     clienthref=location.pathname;
                             'wishlistImport','scrollbars=1,resizable=1,menubar=0');     w_bmquery_flag=1;
    }     bmquery=window.open('','bmquery','width=365,height=165,scrollbars=0');
    else {     bmquery.document.write(
        newWin = window.open('/adm/wishlist?inhibitmenu=yes&mode=import',     '$start_page_bookmark'
                             'wishlistImport','scrollbars=1,resizable=1,menubar=0');     +'<center><form method="post"'
    }     +' name="newlink" action="/adm/bookmarks" target="bmquery" '
    newWin.focus();     +'> <table width="340" height="150" '
      +'bgcolor="#FFFFFF" align="center"><tr><td>Link Name:<br /><input '
      +'type="text" name="title" size="45" value="'+clienttitle+'" />'
      +'<br />Address:<br /><input type="text" name="address" size="45" '
      +'value="'+clienthref+'" /><br /><center><input type="submit" '
      +'value="Save" /> <input type="button" value="Close" '
      +'onclick="javascript:window.close();" /></center></td>'
      +'</tr></table></form></center>'
      +'$end_page_bookmark' );
      bmquery.document.close();
 }  }
   
 ENDUTILITY  ENDUTILITY
Line 1657  sub required_privs { Line 1852  sub required_privs {
              '/adm/trackstudent' => 'vsa',               '/adm/trackstudent' => 'vsa',
              '/adm/statistics'   => 'vgr',               '/adm/statistics'   => 'vgr',
              '/adm/setblock'     => 'dcm',               '/adm/setblock'     => 'dcm',
                '/adm/coursedocs'   => 'mdc',
            };             };
     unless ($env{'course.'.$env{'request.course.id'}.'.grading'} eq 'spreadsheet') {      unless ($env{'course.'.$env{'request.course.id'}.'.grading'} eq 'spreadsheet') {
         $privs->{'/adm/classcalc'}   = 'vgr',          $privs->{'/adm/classcalc'}   = 'vgr',

Removed from v.1.366  
changed lines
  Added in v.1.369.2.2


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