Annotation of loncom/interface/lonmenu.pm, revision 1.298

1.1       www         1: # The LearningOnline Network with CAPA
                      2: # Routines to control the menu
                      3: #
1.298   ! raeburn     4: # $Id: lonmenu.pm,v 1.297 2009/10/29 16:15:57 raeburn Exp $
1.11      albertel    5: #
                      6: # Copyright Michigan State University Board of Trustees
                      7: #
                      8: # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
                      9: #
                     10: # LON-CAPA is free software; you can redistribute it and/or modify
                     11: # it under the terms of the GNU General Public License as published by
                     12: # the Free Software Foundation; either version 2 of the License, or
                     13: # (at your option) any later version.
                     14: #
                     15: # LON-CAPA is distributed in the hope that it will be useful,
                     16: # but WITHOUT ANY WARRANTY; without even the implied warranty of
                     17: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     18: # GNU General Public License for more details.
                     19: #
                     20: # You should have received a copy of the GNU General Public License
                     21: # along with LON-CAPA; if not, write to the Free Software
                     22: # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
                     23: #
                     24: # /home/httpd/html/adm/gpl.txt
                     25: #
                     26: # http://www.lon-capa.org/
                     27: #
1.1       www        28: #
1.269     droeschl   29: # There is one parameter controlling the action of this module:
1.48      www        30: #
                     31: # environment.remote - if this is 'on', the routines controll the remote
1.269     droeschl   32: # control, otherwise they render the main window controls; 
1.1       www        33: 
1.244     jms        34: =head1 NAME
                     35: 
                     36: Apache::lonmenu
                     37: 
                     38: =head1 SYNOPSIS
                     39: 
                     40: Coordinates the response to clicking an image.
                     41: 
                     42: This is part of the LearningOnline Network with CAPA project
                     43: described at http://www.lon-capa.org.
                     44: 
                     45: =head1 SUBROUTINES
                     46: 
                     47: =over
                     48: 
                     49: Little texts
                     50: 
                     51: =item initlittle()
                     52: 
                     53: =item menubuttons()
                     54: 
                     55: This gets called at the top of the body section
                     56: 
                     57: =item show_return_link()
                     58: 
                     59: =item registerurl()
                     60: 
                     61: This gets called in the header section
                     62: 
                     63: =item innerregister()
                     64: 
                     65: This gets called in order to register a URL, both with the Remote
                     66: and in the body of the document
                     67: 
                     68: =item loadevents()
                     69: 
                     70: =item unloadevents()
                     71: 
                     72: =item startupremote()
                     73: 
                     74: =item setflags()
                     75: 
                     76: =item maincall()
                     77: 
                     78: =item load_remote_msg()
                     79: 
                     80: =item get_menu_name()
                     81: 
                     82: =item reopenmenu()
                     83: 
                     84: =item open()
                     85: 
                     86: Open the menu
                     87: 
                     88: =item clear()
                     89: 
                     90: =item switch()
                     91: 
                     92: Switch a button or create a link
                     93: Switch acts on the javascript that is executed when a button is clicked.  
                     94: The javascript is usually similar to "go('/adm/roles')" or "cstrgo(..)".
                     95: 
                     96: =item secondlevel()
                     97: 
                     98: =item openmenu()
                     99: 
                    100: =item inlinemenu()
                    101: 
                    102: =item rawconfig()
                    103: 
                    104: =item close()
                    105: 
                    106: =item footer()
                    107: 
                    108: =item utilityfunctions()
                    109: 
                    110: =item serverform()
                    111: 
                    112: =item constspaceform()
                    113: 
                    114: =item get_nav_status()
                    115: 
                    116: =item hidden_button_check()
                    117: 
                    118: =item roles_selector()
                    119: 
                    120: =item jump_to_role()
                    121: 
                    122: =back
                    123: 
                    124: =cut
                    125: 
1.1       www       126: package Apache::lonmenu;
                    127: 
                    128: use strict;
1.152     albertel  129: use Apache::lonnet;
1.47      matthew   130: use Apache::lonhtmlcommon();
1.115     albertel  131: use Apache::loncommon();
1.127     albertel  132: use Apache::lonenc();
1.88      www       133: use Apache::lonlocal;
1.207     foxr      134: use LONCAPA qw(:DEFAULT :match);
1.282     amueller  135: use HTML::Entities();
1.88      www       136: 
1.283     droeschl  137: use vars qw(@desklines %category_names %category_members %category_positions 
                    138:             $readdesk @primary_menu @secondary_menu);
1.88      www       139: 
1.56      www       140: my @inlineremote;
1.38      www       141: 
1.283     droeschl  142: sub prep_menuitem {
1.291     raeburn   143:     my ($menuitem) = @_;
                    144:     return '' unless(ref($menuitem) eq 'ARRAY');
1.283     droeschl  145:     my $link;
                    146:     if ($$menuitem[1]) { # graphical Link
                    147:         $link = "<img class=\"LC_noBorder\""
1.291     raeburn   148:               . " src=\"" . &Apache::loncommon::lonhttpdurl($$menuitem[1]) . "\"" 
                    149:               . " alt=\"" . &mt($$menuitem[2]) . "\" />";
1.283     droeschl  150:     } else {             # textual Link
1.291     raeburn   151:         $link = &mt($$menuitem[3]);
                    152:     }
1.297     raeburn   153:     return '<li><a href="'.$$menuitem[0].'" target="_top">'.$link.'</a></li>';
1.283     droeschl  154: }
                    155: 
                    156: # primary_menu() evaluates @primary_menu and returns XHTML for the menu
                    157: # that contains following links:
                    158: # About, Message, Roles, Help, Logout
                    159: # @primary_menu is filled within the BEGIN block of this module with 
                    160: # entries from mydesk.tab
                    161: sub primary_menu {
                    162:     my $menu;
                    163:     # each element of @primary contains following array:
                    164:     # (link url, icon path, alt text, link text, condition)
                    165:     foreach my $menuitem (@primary_menu) {
                    166:         # evaluate conditions 
1.296     droeschl  167:         next if    ref($menuitem)       ne 'ARRAY';    #
1.283     droeschl  168:         next if    $$menuitem[4]        eq 'nonewmsg'  # show links depending on
1.291     raeburn   169:                 && &Apache::lonmsg::mynewmail();       # whether a new msg 
1.283     droeschl  170:         next if    $$menuitem[4]        eq 'newmsg'    # arrived or not
1.291     raeburn   171:                 && !&Apache::lonmsg::mynewmail();      # 
1.283     droeschl  172:         next if    $$menuitem[4]        !~ /public/    ##we've a public user, 
                    173:                 && $env{'user.name'}    eq 'public'    ##who should not see all 
                    174:                 && $env{'user.domain'}  eq 'public';   ##links
                    175:         next if    $$menuitem[4]        eq 'onlypublic'# hide links which are 
                    176:                 && $env{'user.name'}    ne 'public'    # only visible to public
                    177:                 && $env{'user.domain'}  ne 'public';   # users
                    178:         next if    $$menuitem[4]        eq 'roles'     ##show links depending on
1.291     raeburn   179:                 && &Apache::loncommon::show_course();  ##term 'Courses' or 
1.283     droeschl  180:         next if    $$menuitem[4]        eq 'courses'   ##'Roles' wanted
1.291     raeburn   181:                 && !&Apache::loncommon::show_course(); ##
                    182:         
                    183:             
1.283     droeschl  184:         if ($$menuitem[3] eq 'Help') { # special treatment for helplink
1.291     raeburn   185:             $menu .= '<li>'.&Apache::loncommon::top_nav_help('Help').'</li>';
1.283     droeschl  186:         } else {
1.296     droeschl  187:             my @items = @{$menuitem};
                    188:             $items[0] = 'javascript:'.$menuitem->[0].';';
                    189:             $menu .= &prep_menuitem(\@items);
1.283     droeschl  190:         }
1.291     raeburn   191:     }
1.283     droeschl  192: 
1.291     raeburn   193:     return "<ol class=\"LC_primary_menu LC_right\">$menu</ol>";
1.283     droeschl  194: }
                    195: 
                    196: 
                    197: sub secondary_menu {
                    198:     my $menu;
                    199: 
1.286     raeburn   200:     my $crstype = &Apache::loncommon::course_type();
                    201:     my $canedit = &Apache::lonnet::allowed('mdc', $env{'request.course.id'});
                    202:     my $canviewgrps = &Apache::lonnet::allowed('vcg', $env{'request.course.id'}
                    203:                    . ($env{'request.course.sec'} ? "/$env{'request.course.sec'}"
                    204:                                                  : '')); 
                    205:     my $showlink = &show_return_link();
                    206:     my %groups = &Apache::lonnet::get_active_groups(
                    207:                      $env{'user.domain'}, $env{'user.name'},
                    208:                      $env{'course.' . $env{'request.course.id'} . '.domain'},
                    209:                      $env{'course.' . $env{'request.course.id'} . '.num'});
1.283     droeschl  210:     foreach my $menuitem (@secondary_menu) {
                    211:         # evaluate conditions 
1.296     droeschl  212:         next if    ref($menuitem)  ne 'ARRAY';
1.283     droeschl  213:         next if    $$menuitem[4]   ne 'always'
                    214:                 && !$env{'request.course.id'};
                    215:         next if    $$menuitem[4]   eq 'showreturn'
1.286     raeburn   216:                 && !$showlink
1.283     droeschl  217:                 && !($env{'request.state'} eq 'construct');
                    218:         next if    $$menuitem[4]   =~ /^mdc/
1.286     raeburn   219:                 && !$canedit;
                    220:         next if    $$menuitem[4]  eq 'mdcCourse'
                    221:                 && $crstype eq 'Community';
                    222:         next if    $$menuitem[4]  eq 'mdcCommunity'
                    223:                 && $crstype ne 'Community';
                    224:         next if    $$menuitem[4]  =~ /^remotenav/
1.283     droeschl  225:                 && $env{'environment.remotenavmap'} ne 'on';
1.286     raeburn   226:         next if    $$menuitem[4]  =~ /noremotenav/
1.283     droeschl  227:                 && $env{'environment.remotenavmap'} eq 'on';
1.295     raeburn   228:         next if $$menuitem[4] =~ /^(no|)remotenav$/ 
                    229:                 && $crstype eq 'Community';
                    230:         next if $$menuitem[4] =~ /^(no|)remotenavCommunity$/ 
                    231:                 && $crstype ne 'Community';
1.283     droeschl  232:         next if    $$menuitem[4]   =~ /showgroups$/
1.286     raeburn   233:                 && $canviewgrps
                    234:                 && !%groups;
1.283     droeschl  235: 
1.286     raeburn   236:         if ($$menuitem[3] eq 'Roles' && $env{'request.course.id'}) {
1.283     droeschl  237:             # special treatment for role selector
1.298   ! raeburn   238:             my $roles_selector = &roles_selector(
1.283     droeschl  239:                         $env{'course.' . $env{'request.course.id'} . '.domain'},
                    240:                         $env{'course.' . $env{'request.course.id'} . '.num'}  );
                    241: 
                    242:             $menu .= $roles_selector ? "<li>$roles_selector</li>"
                    243:                                      : '';
1.296     droeschl  244:         } elsif ($env{'environment.remotenavmap'} eq 'on') {
                    245:             # open link using javascript when remote navmap is activated
                    246:             my @items = @{$menuitem}; 
                    247:             if ($menuitem->[4] eq 'remotenav') {
                    248:                 $items[0] = "javascript:gonav('$menuitem->[0]');";
1.291     raeburn   249:             } else {
1.296     droeschl  250:                 $items[0] = "javascript:go('$menuitem->[0]');";
1.291     raeburn   251:             }
1.296     droeschl  252:             $menu .= &prep_menuitem(\@items);
                    253:         } else {
                    254:             $menu .= &prep_menuitem(\@$menuitem);
1.283     droeschl  255:         }
                    256:     }
                    257:     if ($menu =~ /\[url\].*\[symb\]/) {
1.291     raeburn   258:         my $escurl  = &escape( &Apache::lonenc::check_encrypt(
                    259:                              $env{'request.noversionuri'}));
1.283     droeschl  260: 
1.291     raeburn   261:         my $escsymb = &escape( &Apache::lonenc::check_encrypt(
                    262:                              $env{'request.symb'})); 
1.283     droeschl  263: 
                    264:         if (    $env{'request.state'} eq 'construct'
                    265:             and (   $env{'request.noversionuri'} eq '' 
                    266:                  || !defined($env{'request.noversionuri'}))) 
                    267:         {
                    268:             ($escurl = $env{'request.filename'}) =~ 
                    269:                 s{^/home/([^/]+)/public_html/(.*)$}{/priv/$1/$2};
                    270: 
1.291     raeburn   271:             $escurl  = &escape($escurl);
1.283     droeschl  272:         }    
                    273:         $menu =~ s/\[url\]/$escurl/g;
                    274:         $menu =~ s/\[symb\]/$escsymb/g;
                    275:     }
                    276: 
1.285     wenzelju  277:     return "<ul id=\"LC_secondary_menu\">$menu</ul>";
1.283     droeschl  278: }
                    279: 
                    280: 
1.274     www       281: #
                    282: # This routine returns a translated hash for the menu items in the top inline menu row
                    283: # Probably should be in mydesk.tab
                    284: 
1.283     droeschl  285: #SD this sub is deprecated - don't use it
1.88      www       286: sub initlittle {
                    287:     return &Apache::lonlocal::texthash('ret' => 'Return to Last Location',
1.281     raeburn   288: 				       'nav' => 'Course Contents',
1.88      www       289: 				       'main' => 'Main Menu',
1.266     raeburn   290:                                        'roles' => (&Apache::loncommon::show_course()?
1.231     albertel  291:                                                     'Courses':'Roles'),
1.235     raeburn   292:                                        'other' => 'Other Roles',
1.219     albertel  293:                                        'docs' => 'Edit Course',
1.257     hauer     294:                                        'exit' => 'Logout',
1.202     albertel  295:                                        'login' => 'Log In',
1.165     raeburn   296: 				       'launch' => 'Launch Remote Control',
1.188     albertel  297:                                        'groups' => 'Groups',
1.286     raeburn   298:                                        'gdoc' => 'Community Documents',
1.184     raeburn   299:                                        );
1.88      www       300: }
                    301: 
1.283     droeschl  302: #SD this sub is deprecated - don't use it
                    303: #SD functionality is covered by new loncommon::bodytag and primary_menu(), secondary_menu()
1.38      www       304: sub menubuttons {
                    305:     my $forcereg=shift;
1.131     raeburn   306:     my $titletable=shift;
1.274     www       307: #
                    308: # Early-out for pages that should not have a menu, triggered by query string "inhibitmenu=yes"
                    309: #
1.112     albertel  310:     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
                    311: 					    ['inhibitmenu']);
1.152     albertel  312:     if (($env{'form.inhibitmenu'} eq 'yes') ||
1.149     www       313:         ($ENV{'REQUEST_URI'} eq '/adm/logout')) { return ''; }
1.175     albertel  314: 
                    315:     if ($env{'request.noversionuri'} =~ m{^/res/adm/pages/}) { return ''; }
                    316: 
1.163     www       317:     my %lt=&initlittle();
1.55      www       318:     my $navmaps='';
1.59      www       319:     my $reloadlink='';
1.151     www       320:     my $docs='';
1.165     raeburn   321:     my $groups='';
1.235     raeburn   322:     my $roles='<a href="/adm/roles" target="_top">'.$lt{'roles'}.'</a>';
                    323:     my $role_selector;
1.165     raeburn   324:     my $showgroups=0;
1.235     raeburn   325:     my ($cnum,$cdom);
1.274     www       326: #
                    327: # if the URL is hidden, symbs and the non-versioned version of the URL would be encrypted
                    328: #
1.183     www       329:     my $escurl=&escape(&Apache::lonenc::check_encrypt($env{'request.noversionuri'}));
                    330:     my $escsymb=&escape(&Apache::lonenc::check_encrypt($env{'request.symb'}));
1.176     albertel  331: 
1.199     albertel  332:     my $logo=&Apache::loncommon::lonhttpdurl("/adm/lonIcons/minilogo.gif");
1.253     kaisler   333:     $logo = '<a href="/adm/about.html"><img src="'.
                    334: 	$logo.'" alt="LON-CAPA Logo" class="LC_noBorder" /></a>';
1.199     albertel  335: 
1.152     albertel  336:     if ($env{'request.state'} eq 'construct') {
1.274     www       337: #
                    338: # We are in construction space
                    339: #
1.152     albertel  340:         if (($env{'request.noversionuri'} eq '') || (!defined($env{'request.noversionuri'}))) {
                    341:             my $returnurl = $env{'request.filename'};
1.134     raeburn   342:             $returnurl =~ s:^/home/([^/]+)/public_html/(.*)$:/priv/$1/$2:;
1.183     www       343:             $escurl = &escape($returnurl);
1.134     raeburn   344:         }
                    345:     }
1.165     raeburn   346:     if ($env{'request.course.id'}) {
1.274     www       347: #
                    348: # We are in a course
                    349: #
1.235     raeburn   350:         $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
                    351:         $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
1.165     raeburn   352:         my %coursegroups;
1.188     albertel  353:         my $viewgrps_permission =
1.197     raeburn   354: 	    &Apache::lonnet::allowed('vcg',$env{'request.course.id'}.($env{'request.course.sec'}?'/'.$env{'request.course.sec'}:''));
1.165     raeburn   355:         if (!$viewgrps_permission) {
1.235     raeburn   356:             %coursegroups = &Apache::lonnet::get_active_groups($env{'user.domain'},$env{'user.name'},$cdom,$cnum);
1.188     albertel  357: 	}
1.165     raeburn   358:         if ((keys(%coursegroups) > 0) || ($viewgrps_permission)) {
                    359:             $showgroups = 1;
                    360:         }
1.235     raeburn   361:         $role_selector = &roles_selector($cdom,$cnum);
                    362:         if ($role_selector) {
                    363:             $roles = '<span class="LC_nobreak">'.$role_selector.'&nbsp;&nbsp;<a href="/adm/roles" target="_top">'.$lt{'other'}.'</a></span>';
                    364:         }
1.165     raeburn   365:     }
                    366: 
1.267     droeschl  367:     if ($env{'environment.remote'} eq 'off') {
1.48      www       368: # Remote Control is switched off
1.58      www       369: # figure out colors
1.267     droeschl  370:         my %lt=&initlittle();
1.172     albertel  371: 
1.58      www       372:         my $domain=&Apache::loncommon::determinedomain();
1.291     raeburn   373:         my $function=&Apache::loncommon::get_users_function();
1.58      www       374:         my $link=&Apache::loncommon::designparm($function.'.link',$domain);
                    375:         my $alink=&Apache::loncommon::designparm($function.'.alink',$domain);
                    376:         my $vlink=&Apache::loncommon::designparm($function.'.vlink',$domain);
                    377:         my $sidebg=&Apache::loncommon::designparm($function.'.sidebg',$domain);
1.267     droeschl  378: 
                    379:         if ($env{'user.name'} eq 'public' && $env{'user.domain'} eq 'public') {
                    380:             return (<<ENDINLINEMENU);
1.285     wenzelju  381:             <ol class="LC_primary_menu LC_right">
1.271     droeschl  382:                 <li>$logo</li>
                    383:                 <li><a href="/adm/roles" target="_top">$lt{'login'}</a></li>
                    384:             </ol>
                    385:             <hr />
1.156     albertel  386: ENDINLINEMENU
                    387:         }
1.253     kaisler   388:         $roles = '<a href="/adm/roles" target="_top">'.$lt{'roles'}.'</a>';
1.58      www       389: # Do we have a NAV link?
1.152     albertel  390:         if ($env{'request.course.id'}) {
1.141     albertel  391: 	    my $link='/adm/navmaps?postdata='.$escurl.'&amp;postsymb='.
                    392: 		$escsymb;
1.152     albertel  393: 	    if ($env{'environment.remotenavmap'} eq 'on') {
1.141     albertel  394: 		$link="javascript:gonav('".$link."')";
                    395: 	    }
                    396: 	    $navmaps=(<<ENDNAV);
1.253     kaisler   397: <li><a href="$link" target="_top">$lt{'nav'}</a></li>
1.114     albertel  398: ENDNAV
1.286     raeburn   399:             my $is_community = 
                    400:                 (&Apache::loncommon::course_type() eq 'Community');
1.152     albertel  401: 	    if (&Apache::lonnet::allowed('mdc',$env{'request.course.id'})) {
1.286     raeburn   402:                 my $text = ($is_community) ? $lt{'gdoc'} : $lt{'docs'};
1.151     www       403: 		$docs=(<<ENDDOCS);
1.253     kaisler   404: <li><a href="/adm/coursedocs" target="_top">$text</a></li>
1.151     www       405: ENDDOCS
                    406:             }
1.197     raeburn   407:             if ($showgroups) {
                    408:                 $groups =(<<ENDGROUPS);
1.253     kaisler   409: <li><a href="/adm/coursegroups" target="_top">$lt{'groups'}</a></li>
1.197     raeburn   410: ENDGROUPS
                    411:             }
1.228     albertel  412: 	    if (&show_return_link()) {
1.183     www       413:                 my $escreload=&escape('return:');
1.59      www       414:                 $reloadlink=(<<ENDRELOAD);
1.253     kaisler   415: <li><a href="/adm/flip?postdata=$escreload" target="_top">$lt{'ret'}</a></li>
1.59      www       416: ENDRELOAD
                    417:             }
1.235     raeburn   418:             if ($role_selector) {
1.253     kaisler   419:             	#$roles = '<td>'.$role_selector.'</td><td><a href="/adm/roles" target="_top">'.$lt{'other'}.'</a></td>';
                    420: 				$role_selector = '<li>'.$role_selector.'</li>';
1.235     raeburn   421:             }
1.55      www       422:         }
1.163     www       423: 	if (($env{'request.state'} eq 'construct') && ($env{'request.course.id'})) {
1.183     www       424: 	    my $escreload=&escape('return:');
1.163     www       425: 	    $reloadlink=(<<ENDCRELOAD);
1.253     kaisler   426: <li><a href="/adm/flip?postdata=$escreload" target="_top">$lt{'ret'}</a></li>
1.163     www       427: ENDCRELOAD
                    428:         }
1.276     droeschl  429:     my $reg     = $forcereg ? &innerregister($forcereg,$titletable) : '';
                    430:     my $form    = &serverform();
                    431:     my $utility = &utilityfunctions();
                    432: 
                    433:     #Prepare the message link that indicates the arrival of new mail
1.291     raeburn   434:     my $messagelink = &Apache::lonmsg::mynewmail() ? "Message (new)" : "Message";
1.276     droeschl  435:        $messagelink = '<a href="javascript:go(\'/adm/communicate\');">'
                    436:                       . mt($messagelink) .'</a>';
                    437: 
                    438:     my $helplink = &Apache::loncommon::top_nav_help('Help');
1.58      www       439: 	return (<<ENDINLINEMENU);
1.129     albertel  440: <script type="text/javascript">
1.277     bisitz    441: // <![CDATA[
1.150     albertel  442: // BEGIN LON-CAPA Internal
1.116     albertel  443: $utility
1.150     albertel  444: // ]]>
1.48      www       445: </script>
1.285     wenzelju  446: <ol class="LC_primary_menu LC_right">
1.253     kaisler   447: 	<li>$logo</li>
1.256     kaisler   448: 	<li>$messagelink</li>
1.253     kaisler   449: 	<li>$roles</li>
                    450: 	<li>$helplink</li>
                    451: 	<li><a href="/adm/logout" target="_top">$lt{'exit'}</a></li>
                    452: </ol>
1.285     wenzelju  453: <ul id="LC_secondary_menu">
1.253     kaisler   454: <li><a href="/adm/menu" target="_top">$lt{'main'}</a></li>
1.59      www       455: $reloadlink
1.55      www       456: $navmaps
1.151     www       457: $docs
1.165     raeburn   458: $groups
1.253     kaisler   459: $role_selector
1.263     droeschl  460: </ul>
1.168     albertel  461: $form
1.129     albertel  462: <script type="text/javascript">
1.48      www       463: // END LON-CAPA Internal
                    464: </script>
1.58      www       465: $reg
1.48      www       466: ENDINLINEMENU
                    467:     } else {
                    468: 	return '';
                    469:     }
1.72      www       470: }
                    471: 
1.228     albertel  472: sub show_return_link {
                    473:     return (($env{'request.noversionuri'}=~m{^/(res|public)/} &&
                    474: 	     $env{'request.symb'} eq '')
                    475: 	    ||
                    476: 	    ($env{'request.noversionuri'}=~ m{^/cgi-bin/printout.pl})
                    477: 	    ||
                    478: 	    (($env{'request.noversionuri'}=~/^\/adm\//) &&
                    479: 	     ($env{'request.noversionuri'}!~/^\/adm\/wrapper\//) &&
                    480: 	     ($env{'request.noversionuri'}!~
                    481: 	      m[^/adm/.*/(smppg|bulletinboard|aboutme)($|\?)])
                    482: 	     ));
                    483: }
                    484: 
1.38      www       485: 
                    486: sub registerurl {
1.173     albertel  487:     my ($forcereg) = @_;
1.38      www       488:     my $result = '';
1.175     albertel  489:     if ($env{'request.noversionuri'} =~ m{^/res/adm/pages/}) { return ''; }
1.66      albertel  490:     my $force_title='';
1.152     albertel  491:     if ($env{'request.state'} eq 'construct') {
1.66      albertel  492: 	$force_title=&Apache::lonxml::display_title();
                    493:     }
1.269     droeschl  494:     if (($env{'environment.remote'} eq 'off') ||
1.152     albertel  495:         ((($env{'request.publicaccess'}) || 
1.83      www       496:          (!&Apache::lonnet::is_on_map(
1.183     www       497: 	   &unescape($env{'request.noversionuri'})))) &&
1.38      www       498:         (!$forcereg))) {
1.277     bisitz    499:  	return
                    500:         $result
                    501:        .'<script type="text/javascript">'."\n"
                    502:        .'// <![CDATA['."\n"
                    503:        .'function LONCAPAreg(){;} function LONCAPAstale(){}'."\n"
                    504:        .'// ]]>'."\n"
                    505:        .'</script>'
                    506:        .$force_title;
1.38      www       507:     }
1.41      www       508: # Graphical display after login only
1.174     albertel  509:     if ($env{'request.registered'} && !$forcereg) { return ''; }
1.173     albertel  510:     $result.=&innerregister($forcereg);
1.66      albertel  511:     return $result.$force_title;
1.40      www       512: }
                    513: 
                    514: sub innerregister {
1.173     albertel  515:     my ($forcereg, $titletable) = @_;
1.40      www       516:     my $result = '';
1.120     raeburn   517:     my ($uname,$thisdisfn);
1.152     albertel  518:     my $const_space = ($env{'request.state'} eq 'construct');
1.131     raeburn   519:     my $is_const_dir = 0;
1.120     raeburn   520: 
1.175     albertel  521:     if ($env{'request.noversionuri'} =~ m{^/res/adm/pages/}) { return ''; }
1.40      www       522: 
1.174     albertel  523:     $env{'request.registered'} = 1;
1.40      www       524: 
1.267     droeschl  525:     my $noremote = ($env{'environment.remote'} eq 'off');
1.49      www       526:     
1.177     albertel  527:     undef(@inlineremote);
1.56      www       528: 
1.38      www       529:     my $reopen=&Apache::lonmenu::reopenmenu();
1.40      www       530: 
1.38      www       531:     my $newmail='';
1.267     droeschl  532: 
                    533:     if (&Apache::lonmsg::newmail() && !$noremote) { 
                    534:         # We have new mail and remote is up
                    535:         $newmail= 'swmenu.setstatus("you have","messages");';
1.233     www       536:     } 
1.276     droeschl  537: 
1.288     raeburn   538:     my ($breadcrumb,$separator);
1.267     droeschl  539:     if ($noremote
1.177     albertel  540: 	     && ($env{'request.symb'}) 
                    541: 	     && ($env{'request.course.id'})) {
1.267     droeschl  542: 
                    543:         my ($mapurl,$rid,$resurl) = &Apache::lonnet::decode_symb(&Apache::lonnet::symbread());
                    544:         my $coursetitle = $env{'course.'.$env{'request.course.id'}.'.description'};
                    545: 
                    546:         my $maptitle = &Apache::lonnet::gettitle($mapurl);
                    547:         my $restitle = &Apache::lonnet::gettitle(&Apache::lonnet::symbread());
1.289     raeburn   548:         my @crumbs = ({text  => "Course Contents", 
                    549:                        href  => "Javascript:gonav('/adm/navmaps')"});
                    550: 
                    551:         if ($mapurl ne $env{'course.'.$env{'request.course.id'}.'.url'}) { 
                    552:             push(@crumbs, {text  => '...',
                    553:                            no_mt => 1});
                    554:         }
1.268     droeschl  555: 
                    556:         push @crumbs, {text => $maptitle, no_mt => 1} if ($maptitle 
                    557:                                                    && $maptitle ne 'default.sequence' 
                    558:                                                    && $maptitle ne $coursetitle);
                    559: 
                    560:         push @crumbs, {text => $restitle, no_mt => 1} if $restitle; 
                    561: 
1.291     raeburn   562:         &Apache::lonhtmlcommon::clear_breadcrumbs();
                    563:         &Apache::lonhtmlcommon::add_breadcrumb(@crumbs);
                    564:         $breadcrumb .= &Apache::lonhtmlcommon::breadcrumbs(undef,undef,0);
1.288     raeburn   565: 	unless (($env{'request.state'} eq 'edit') || ($newmail) ||
                    566: 		($env{'request.state'} eq 'construct') ||
                    567: 		($env{'form.register'})) {
                    568:             $separator = &Apache::loncommon::head_subbox();
                    569:         }
1.267     droeschl  570:         #
1.65      www       571:     }
1.152     albertel  572:     if ($env{'request.state'} eq 'construct') {
1.131     raeburn   573:         $newmail = $titletable;
1.267     droeschl  574:     } 
                    575:     my $timesync   = ( $noremote ? '' : 'swmenu.syncclock(1000*'.time.');' );
                    576:     my $tablestart = ( $noremote ? '<table id="LC_menubuttons">' : '');
                    577:     my $tableend   = ( $noremote ? '</table>' : '');
1.41      www       578: # =============================================================================
                    579: # ============================ This is for URLs that actually can be registered
1.296     droeschl  580:     if (($env{'request.noversionuri'}!~m{^/(res/)*adm/}) || ($forcereg)) {
1.40      www       581: # -- This applies to homework problems for users with grading privileges
1.152     albertel  582: 	my $crs='/'.$env{'request.course.id'};
                    583: 	if ($env{'request.course.sec'}) {
                    584: 	    $crs.='_'.$env{'request.course.sec'};
1.107     albertel  585: 	}
                    586: 	$crs=~s/\_/\//g;
                    587: 
1.38      www       588:         my $hwkadd='';
1.152     albertel  589:         if ($env{'request.symb'} ne '' &&
1.161     albertel  590: 	    $env{'request.filename'}=~/\.(problem|exam|quiz|assess|survey|form|task)$/) {
1.79      www       591: 	    if (&Apache::lonnet::allowed('mgr',$crs)) {
1.259     bisitz    592: 		$hwkadd.=&switch('','',7,2,'pgrd.gif','problem[_1]','grades[_4]',
1.40      www       593:                        "gocmd('/adm/grades','gradingmenu')",
                    594:                        'Modify user grades for this assessment resource');
1.154     www       595:             } elsif (&Apache::lonnet::allowed('vgr',$crs)) {
                    596: 		$hwkadd.=&switch('','',7,2,'subm.gif','view sub-[_1]','missions[_1]',
                    597:                        "gocmd('/adm/grades','submission')",
                    598: 		       'View user submissions for this assessment resource');
1.38      www       599:             }
1.107     albertel  600: 	}
1.152     albertel  601: 	if ($env{'request.symb'} ne '' &&
1.145     albertel  602: 	    &Apache::lonnet::allowed('opa',$crs)) {
1.107     albertel  603: 	    $hwkadd.=&switch('','',7,3,'pparm.gif','problem[_2]','parms[_2]',
                    604: 			     "gocmd('/adm/parmset','set')",
1.196     www       605: 			     'Modify parameter settings for this resource');
1.38      www       606: 	}
1.40      www       607: # -- End Homework
1.38      www       608:         ###
                    609:         ### Determine whether or not to display the 'cstr' button for this
                    610:         ### resource
                    611:         ###
                    612:         my $editbutton = '';
1.258     raeburn   613:         my $noeditbutton = 1;
                    614:         my ($cnum,$cdom);
                    615:         if ($env{'request.course.id'}) {
                    616:             $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
                    617:             $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                    618:         }
1.152     albertel  619:         if ($env{'user.author'}) {
1.234     raeburn   620:             if ($env{'request.role'}=~/^(aa|ca|au)/) {
1.274     www       621: #
                    622: # We have the role of an author
                    623: #
1.38      www       624:                 # Set defaults for authors
                    625:                 my ($top,$bottom) = ('con-','struct');
1.152     albertel  626:                 my $action = "go('/priv/".$env{'user.name'}."');";
                    627:                 my $cadom  = $env{'request.role.domain'};
                    628:                 my $caname = $env{'user.name'};
1.236     bisitz    629:                 my $desc = "Enter my construction space";
1.38      www       630:                 # Set defaults for co-authors
1.152     albertel  631:                 if ($env{'request.role'} =~ /^ca/) { 
1.206     albertel  632:                     ($cadom,$caname)=($env{'request.role'}=~/($match_domain)\/($match_username)$/);
1.38      www       633:                     ($top,$bottom) = ('co con-','struct');
                    634:                     $action = "go('/priv/".$caname."');";
                    635:                     $desc = "Enter construction space as co-author";
1.234     raeburn   636:                 } elsif ($env{'request.role'} =~ /^aa/) {
                    637:                     ($cadom,$caname)=($env{'request.role'}=~/($match_domain)\/($match_username)$/);
                    638:                     ($top,$bottom) = ('co con-','struct');
                    639:                     $action = "go('/priv/".$caname."');";
                    640:                     $desc = "Enter construction space as assistant co-author";
1.38      www       641:                 }
                    642:                 # Check that we are on the correct machine
                    643:                 my $home = &Apache::lonnet::homeserver($caname,$cadom);
1.109     albertel  644: 		my $allowed=0;
                    645: 		my @ids=&Apache::lonnet::current_machine_ids();
                    646: 		foreach my $id (@ids) { if ($id eq $home) { $allowed=1; } }
                    647: 		if (!$allowed) {
                    648: 		    $editbutton=&switch('','',6,1,$top,,$bottom,$action,$desc);
1.258     raeburn   649:                     $noeditbutton = 0;
1.38      www       650:                 }
                    651:             }
1.274     www       652: #
                    653: # We are an author for some stuff, but currently do not have the role of author.
                    654: # Figure out if we have authoring privileges for the resource we are looking at.
                    655: # This should maybe become a privilege check in lonnet
                    656: #
1.38      www       657:             ##
                    658:             ## Determine if user can edit url.
                    659:             ##
                    660:             my $cfile='';
                    661:             my $cfuname='';
                    662:             my $cfudom='';
1.258     raeburn   663:             my $uploaded;
1.152     albertel  664:             if ($env{'request.filename'}) {
                    665:                 my $file=&Apache::lonnet::declutter($env{'request.filename'});
1.258     raeburn   666:                 if (defined($cnum) && defined($cdom)) {
                    667:                     $uploaded = &is_course_upload($file,$cnum,$cdom);
                    668:                 }
                    669:                 if (!$uploaded) {
                    670:                     $file=~s/^($match_domain)\/($match_username)/\/priv\/$2/;
                    671:                     # Check that the user has permission to edit this resource
                    672:                     ($cfuname,$cfudom)=&Apache::loncacc::constructaccess($file,$1);
                    673:                     if (defined($cfudom)) {
                    674: 		        my $home=&Apache::lonnet::homeserver($cfuname,$cfudom);
                    675: 		        my $allowed=0;
                    676: 		        my @ids=&Apache::lonnet::current_machine_ids();
                    677: 		        foreach my $id (@ids) { if ($id eq $home) { $allowed=1; } }
                    678: 		        if ($allowed) {
                    679:                             $cfile=$file;
                    680:                         }
1.38      www       681:                     }
                    682:                 }
1.258     raeburn   683:             }
1.38      www       684:             # Finally, turn the button on or off
1.120     raeburn   685:             if ($cfile && !$const_space) {
1.40      www       686:                 $editbutton=&switch
1.212     www       687:                     ('','',6,1,'pcstr.gif','edit[_1]','resource[_2]',
1.38      www       688:                      "go('".$cfile."');","Edit this resource");
1.258     raeburn   689:                 $noeditbutton = 0;
1.38      www       690:             } elsif ($editbutton eq '') {
1.191     www       691:                 $editbutton=&clear(6,1);
1.38      www       692:             }
                    693:         }
1.258     raeburn   694:         if (($noeditbutton) && ($env{'request.filename'})) { 
                    695:             if (&Apache::lonnet::allowed('mdc',$env{'request.course.id'})) {
                    696:                 my $file=&Apache::lonnet::declutter($env{'request.filename'});
                    697:                 if (defined($cnum) && defined($cdom)) {
                    698:                     if (&is_course_upload($file,$cnum,$cdom)) {
                    699:                         my $cfile = &edit_course_upload($file,$cnum,$cdom);
                    700:                         if ($cfile) {
                    701:                             $editbutton=&switch
                    702:                                         ('','',6,1,'pcstr.gif','edit[_1]',
                    703:                                          'resource[_2]',"go('".$cfile."');",
                    704:                                          'Edit this resource');
                    705:                         }
                    706:                     }
                    707:                 }
                    708:             }
                    709:         }
1.38      www       710:         ###
                    711:         ###
1.41      www       712: # Prepare the rest of the buttons
1.120     raeburn   713:         my $menuitems;
                    714:         if ($const_space) {
1.274     www       715: #
                    716: # We are in construction space
                    717: #
1.128     albertel  718: 	    my ($uname,$thisdisfn) =
1.152     albertel  719: 		($env{'request.filename'}=~m|^/home/([^/]+)/public_html/(.*)|);
1.121     raeburn   720:             my $currdir = '/priv/'.$uname.'/'.$thisdisfn;
1.131     raeburn   721:             if ($currdir =~ m-/$-) {
                    722:                 $is_const_dir = 1;
                    723:             } else {
1.267     droeschl  724:                 $currdir =~ s|[^/]+$||;
1.200     foxr      725: 		my $cleandisfn = &Apache::loncommon::escape_single($thisdisfn);
1.208     albertel  726: 		my $esc_currdir = &Apache::loncommon::escape_single($currdir);
1.274     www       727: #
                    728: # Probably should be in mydesk.tab
                    729: #
1.131     raeburn   730:                 $menuitems=(<<ENDMENUITEMS);
1.208     albertel  731: s&6&1&list.gif&list[_1]&dir[_1]&golist('$esc_currdir')&List current directory
1.200     foxr      732: s&6&2&rtrv.gif&retrieve[_1]&version[_1]&gocstr('/adm/retrieve','/~$uname/$cleandisfn')&Retrieve old version
1.259     bisitz    733: s&6&3&pub.gif&publish[_1]&resource[_3]&gocstr('/adm/publish','/~$uname/$cleandisfn')&Publish this resource
1.200     foxr      734: s&7&1&del.gif&delete[_1]&resource[_2]&gocstr('/adm/cfile?action=delete','/~$uname/$cleandisfn')&Delete this resource
                    735: s&7&2&prt.gif&prepare[_1]&printout[_1]&gocstr('/adm/printout','/~$uname/$cleandisfn')&Prepare a printable document
1.120     raeburn   736: ENDMENUITEMS
1.131     raeburn   737:             }
1.203     foxr      738:         } elsif ( defined($env{'request.course.id'}) && 
                    739: 		 $env{'request.symb'} ne '' ) {
1.274     www       740: #
                    741: # We are in a course and looking at a registred URL
                    742: # Should probably be in mydesk.tab
                    743: #
1.120     raeburn   744: 	    $menuitems=(<<ENDMENUITEMS);
1.41      www       745: c&3&1
1.209     www       746: s&2&1&back.gif&backward[_1]&&gopost('/adm/flip','back:'+currentURL)&Go to the previous resource in the course sequence&&1
                    747: s&2&3&forw.gif&forward[_1]&&gopost('/adm/flip','forward:'+currentURL)&Go to the next resource in the course sequence&&3
1.77      www       748: c&6&3
                    749: c&8&1
                    750: c&8&2
1.106     www       751: s&8&3&prt.gif&prepare[_1]&printout[_1]&gopost('/adm/printout',currentURL)&Prepare a printable document
1.209     www       752: s&9&1&sbkm.gif&set[_1]&bookmark[_2]&set_bookmark()&Set a bookmark for this resource&&1
1.41      www       753: ENDMENUITEMS
1.216     albertel  754: 
1.243     tempelho  755: my $currentURL = &Apache::loncommon::get_symb();
                    756: my ($symb_old,$symb_old_enc) = &Apache::loncommon::clean_symb($currentURL);
                    757: my $annotation = &Apache::loncommon::get_annotation($symb_old,$symb_old_enc);
                    758: $menuitems.="s&9&3&";
                    759: if(length($annotation) > 0){
                    760: 	$menuitems.="anot2.gif";
                    761: }else{
                    762: 	$menuitems.="anot.gif";
                    763: }
                    764: $menuitems.="&anno-[_1]&tations[_1]&annotate()&";
                    765: $menuitems.="Make notes and annotations about this resource&&1\n";
                    766: 
1.279     raeburn   767:             unless ($noremote) { 
                    768:                 my $showreqcrs = &check_for_rcrs();
                    769:                 if ($showreqcrs) {
                    770:                     $menuitems.="s&8&1&rcrs.gif&request[_1]&course[_16]".
                    771:                                 "&go('/adm/requestcourse')&Course requests\n";
                    772:                 }
                    773:             }
1.193     raeburn   774:             unless ($env{'request.noversionuri'}=~/\/(bulletinboard|smppg|navmaps|syllabus|aboutme)(\?|$)/) {
1.294     raeburn   775: 		if ((!$env{'request.enc'}) && ($env{'request.noversionuri'} !~ m{^/adm/wrapper/ext/})) {
1.216     albertel  776: 		    $menuitems.=(<<ENDREALRES);
1.259     bisitz    777: s&6&3&catalog.gif&catalog[_2]&info[_1]&catalog_info()&Show Metadata
1.216     albertel  778: ENDREALRES
                    779:                 }
1.120     raeburn   780: 	        $menuitems.=(<<ENDREALRES);
1.106     www       781: s&8&1&eval.gif&evaluate[_1]&this[_1]&gopost('/adm/evaluate',currentURL,1)&Provide my evaluation of this resource
                    782: s&8&2&fdbk.gif&feedback[_1]&discuss[_1]&gopost('/adm/feedback',currentURL,1)&Provide feedback messages or contribute to the course discussion about this resource
1.77      www       783: ENDREALRES
1.120     raeburn   784: 	    }
                    785:         }
1.203     foxr      786: 	if ($env{'request.uri'} =~ /^\/res/) {
                    787: 	    $menuitems .= (<<ENDMENUITEMS);
                    788: s&8&3&prt.gif&prepare[_1]&printout[_1]&gopost('/adm/printout',currentURL)&Prepare a printable document
                    789: ENDMENUITEMS
                    790: 	}
1.41      www       791:         my $buttons='';
                    792:         foreach (split(/\n/,$menuitems)) {
                    793: 	    my ($command,@rest)=split(/\&/,$_);
1.220     raeburn   794:             my $idx=10*$rest[0]+$rest[1];
                    795:             if (&hidden_button_check() eq 'yes') {
                    796:                 if ($idx == 21 ||$idx == 23) {
                    797:                     $buttons.=&switch('','',@rest);
                    798:                 } else {
                    799:                     $buttons.=&clear(@rest);
                    800:                 }
                    801:             } else {  
                    802:                 if ($command eq 's') {
                    803: 	            $buttons.=&switch('','',@rest);
                    804:                 } else {
                    805:                     $buttons.=&clear(@rest);
                    806:                 }
1.41      www       807:             }
                    808:         }
1.148     albertel  809: 
1.267     droeschl  810:         if ($noremote) {
1.148     albertel  811: 	    my $addremote=0;
1.267     droeschl  812: 	    foreach (@inlineremote) { if ($_ ne '') { $addremote=1; last;} }
1.148     albertel  813: 	    my $inlinebuttons='';
                    814: 	    if ($addremote) {
1.267     droeschl  815:             # Registered, textual output
1.218     www       816:                     if ($env{'environment.icons'} eq 'iconsonly') {
1.220     raeburn   817:                         $inlinebuttons=(<<ENDARROWSINLINE);
1.218     www       818: <tr><td>
                    819: $inlineremote[21] $inlineremote[23]
1.220     raeburn   820: ENDARROWSINLINE
                    821:                         if (&hidden_button_check() ne 'yes') {
                    822:                             $inlinebuttons .= (<<ENDINLINEICONS);
1.218     www       823: $inlineremote[61] $inlineremote[63]
                    824: $inlineremote[71] $inlineremote[72] $inlineremote[73]
                    825: $inlineremote[81] $inlineremote[82] $inlineremote[83]
                    826: $inlineremote[91] $inlineremote[92] $inlineremote[93]</td></tr>
                    827: ENDINLINEICONS
1.220     raeburn   828:                         }
1.218     www       829:                     } else {
1.223     albertel  830: 			if ($inlineremote[21] ne '' || $inlineremote[23] ne '') {
                    831: 			    $inlinebuttons=(<<ENDFIRSTLINE);
1.129     albertel  832: <tr><td>$inlineremote[21]</td><td>&nbsp;</td><td>$inlineremote[23]</td></tr>
1.220     raeburn   833: ENDFIRSTLINE
1.223     albertel  834:                         }
1.220     raeburn   835:                         if (&hidden_button_check() ne 'yes') { 
1.223     albertel  836: 			    foreach my $row (6..9) {
                    837: 				if ($inlineremote[${row}.'1'] ne ''
                    838: 				    || $inlineremote[$row.'2'] ne ''
                    839: 				    || $inlineremote[$row.'3'] ne '') {
                    840: 				    $inlinebuttons .= <<"ENDLINE";
                    841: <tr><td>$inlineremote["${row}1"]</td><td>$inlineremote["${row}2"]</td><td>$inlineremote["${row}3"]</td></tr>
                    842: ENDLINE
                    843: 				}
                    844: 			    }
                    845: 			}
                    846: 		    }
1.103     www       847: 	    }
1.41      www       848: 	    $result =(<<ENDREGTEXT);
1.129     albertel  849: <script type="text/javascript">
1.42      www       850: // BEGIN LON-CAPA Internal
                    851: </script>
1.41      www       852: $timesync
1.267     droeschl  853: $breadcrumb
1.58      www       854: $tablestart
1.56      www       855: $inlinebuttons
1.227     albertel  856: $tableend
1.224     albertel  857: $newmail
1.288     raeburn   858: $separator
1.129     albertel  859: <script type="text/javascript">
1.64      www       860: // END LON-CAPA Internal
1.42      www       861: </script>
                    862: 
1.41      www       863: ENDREGTEXT
                    864: # Registered, graphical output
                    865:         } else {
1.152     albertel  866: 	    my $requri=&Apache::lonnet::clutter(&Apache::lonnet::fixversion((split(/\?/,$env{'request.noversionuri'}))[0]));
1.183     www       867: 	    $requri=&Apache::lonenc::check_encrypt(&unescape($requri));
1.152     albertel  868: 	    my $cursymb=&Apache::lonenc::check_encrypt($env{'request.symb'});
1.113     albertel  869: 	    my $navstatus=&get_nav_status();
1.140     albertel  870: 	    my $clearcstr;
1.148     albertel  871: 
1.152     albertel  872: 	    if ($env{'user.adv'}) { $clearcstr='clearbut(6,1)'; }
1.41      www       873: 	    $result = (<<ENDREGTHIS);
1.38      www       874:      
1.129     albertel  875: <script type="text/javascript">
1.277     bisitz    876: // <![CDATA[
1.150     albertel  877: // BEGIN LON-CAPA Internal
1.42      www       878: var swmenu=null;
1.38      www       879: 
                    880:     function LONCAPAreg() {
                    881: 	  swmenu=$reopen;
                    882:           swmenu.clearTimeout(swmenu.menucltim);
                    883:           $timesync
                    884:           $newmail
1.41      www       885:           $buttons
1.84      www       886: 	  swmenu.currentURL="$requri";
1.85      www       887:           swmenu.reloadURL=swmenu.currentURL+window.location.search;
1.125     albertel  888:           swmenu.currentSymb="$cursymb";
                    889:           swmenu.reloadSymb="$cursymb";
1.38      www       890:           swmenu.currentStale=0;
1.113     albertel  891: 	  $navstatus
1.38      www       892:           $hwkadd
                    893:           $editbutton
                    894:     }
                    895: 
                    896:     function LONCAPAstale() {
                    897: 	  swmenu=$reopen
                    898:           swmenu.currentStale=1;
                    899:           if (swmenu.reloadURL!='' && swmenu.reloadURL!= null) { 
                    900:              swmenu.switchbutton
                    901:              (3,1,'reload.gif','return','location','go(reloadURL)','Return to the last known location in the course sequence');
                    902: 	  }
                    903:           swmenu.clearbut(7,2);
                    904:           swmenu.clearbut(7,3);
                    905:           swmenu.menucltim=swmenu.setTimeout(
                    906:  'clearbut(2,1);clearbut(2,3);clearbut(8,1);clearbut(8,2);clearbut(8,3);'+
1.140     albertel  907:  'clearbut(9,1);clearbut(9,3);clearbut(6,3);$clearcstr',
1.38      www       908: 			  2000);
                    909:       }
                    910: 
1.150     albertel  911: // END LON-CAPA Internal 
1.277     bisitz    912: // ]]>
1.38      www       913: </script>
                    914: ENDREGTHIS
1.41      www       915:         }
                    916: # =============================================================================
1.38      www       917:     } else {
1.41      www       918: # ========================================== This can or will not be registered
1.267     droeschl  919:         if ($noremote) {
1.269     droeschl  920: # Not registered
1.267     droeschl  921:             $result= (<<ENDDONOTREGTEXT);
1.41      www       922: ENDDONOTREGTEXT
                    923:         } else {
                    924: # Not registered, graphical
                    925:            $result = (<<ENDDONOTREGTHIS);
1.38      www       926: 
1.129     albertel  927: <script type="text/javascript">
1.277     bisitz    928: // <![CDATA[
1.38      www       929: // BEGIN LON-CAPA Internal
1.42      www       930: var swmenu=null;
1.38      www       931: 
                    932:     function LONCAPAreg() {
                    933: 	  swmenu=$reopen
                    934:           $timesync
                    935:           swmenu.currentStale=1;
                    936:           swmenu.clearbut(2,1);
                    937:           swmenu.clearbut(2,3);
                    938:           swmenu.clearbut(8,1);
                    939:           swmenu.clearbut(8,2);
                    940:           swmenu.clearbut(8,3);
                    941:           if (swmenu.currentURL) {
                    942:              swmenu.switchbutton
                    943:               (3,1,'reload.gif','return','location','go(currentURL)');
                    944:  	  } else {
                    945: 	      swmenu.clearbut(3,1);
                    946:           }
                    947:     }
                    948: 
                    949:     function LONCAPAstale() {
                    950:     }
                    951: 
                    952: // END LON-CAPA Internal
1.277     bisitz    953: // ]]>
1.38      www       954: </script>
                    955: ENDDONOTREGTHIS
1.41      www       956:        }
                    957: # =============================================================================
1.38      www       958:     }
                    959:     return $result;
                    960: }
                    961: 
1.258     raeburn   962: sub is_course_upload {
                    963:     my ($file,$cnum,$cdom) = @_;
                    964:     my $uploadpath = &LONCAPA::propath($cdom,$cnum);
                    965:     $uploadpath =~ s{^\/}{};
                    966:     if (($file =~ m{^\Q$uploadpath\E/userfiles/docs/}) ||
                    967:         ($file =~ m{^userfiles/\Q$cdom\E/\Q$cnum\E/docs/})) {
                    968:         return 1;
                    969:     }
                    970:     return;
                    971: }
                    972: 
                    973: sub edit_course_upload {
                    974:     my ($file,$cnum,$cdom) = @_;
                    975:     my $cfile;
                    976:     if ($file =~/\.(htm|html|css|js|txt)$/) {
                    977:         my $ext = $1;
                    978:         my $url = &Apache::lonnet::hreflocation('',$file);
                    979:         my $home = &Apache::lonnet::homeserver($cnum,$cdom);
                    980:         my @ids=&Apache::lonnet::current_machine_ids();
                    981:         my $dest;
                    982:         if ($home && grep(/^\Q$home\E$/,@ids)) {
                    983:             $dest = $url.'?forceedit=1';
                    984:         } else {
                    985:             unless (&Apache::lonnet::get_locks()) {
                    986:                 $dest = '/adm/switchserver?otherserver='.
                    987:                         $home.'&role='.$env{'request.role'}.
                    988:                         '&url='.$url.'&forceedit=1';
                    989:             }
                    990:         }
                    991:         if ($dest) {
                    992:             $cfile = &HTML::Entities::encode($dest,'"<>&');
                    993:         }
                    994:     }
                    995:     return $cfile;
                    996: }
                    997: 
1.38      www       998: sub loadevents() {
1.152     albertel  999:     if ($env{'request.state'} eq 'construct' ||
1.175     albertel 1000: 	$env{'request.noversionuri'} =~ m{^/res/adm/pages/}) { return ''; }
1.38      www      1001:     return 'LONCAPAreg();';
                   1002: }
                   1003: 
                   1004: sub unloadevents() {
1.152     albertel 1005:     if ($env{'request.state'} eq 'construct' ||
1.175     albertel 1006: 	$env{'request.noversionuri'} =~ m{^/res/adm/pages/}) { return ''; }
1.38      www      1007:     return 'LONCAPAstale();';
                   1008: }
1.30      www      1009: 
1.32      www      1010: 
                   1011: sub startupremote {
                   1012:     my ($lowerurl)=@_;
1.269     droeschl 1013:     if ($env{'environment.remote'} eq 'off') {
1.34      www      1014:      return ('<meta HTTP-EQUIV="Refresh" CONTENT="0.5; url='.$lowerurl.'" />');
                   1015:     }
1.49      www      1016: #
                   1017: # The Remote actually gets launched!
                   1018: #
1.32      www      1019:     my $configmenu=&rawconfig();
1.183     www      1020:     my $esclowerurl=&escape($lowerurl);
1.119     www      1021:     my $message=&mt('"Waiting for Remote Control window to load: "+[_1]','waited');
1.32      www      1022:     return(<<ENDREMOTESTARTUP);
1.129     albertel 1023: <script type="text/javascript">
1.277     bisitz   1024: // <![CDATA[
1.118     albertel 1025: var timestart;
1.35      www      1026: function wheelswitch() {
1.118     albertel 1027:     if (typeof(document.wheel) != 'undefined') {
                   1028: 	if (typeof(document.wheel.spin) != 'undefined') {
                   1029: 	    var date=new Date();
                   1030: 	    var waited=Math.round(30-((date.getTime()-timestart)/1000));
                   1031: 	    document.wheel.spin.value=$message;
                   1032: 	}
                   1033:     }
1.35      www      1034:    if (window.status=='|') { 
                   1035:       window.status='/'; 
                   1036:    } else {
                   1037:       if (window.status=='/') {
                   1038:          window.status='-';
                   1039:       } else {
                   1040:          if (window.status=='-') { 
                   1041:             window.status='\\\\'; 
                   1042:          } else {
                   1043:             if (window.status=='\\\\') { window.status='|'; }
                   1044:          }
                   1045:       }
                   1046:    } 
                   1047: }
                   1048: 
1.32      www      1049: // ---------------------------------------------------------- The wait function
                   1050: var canceltim;
                   1051: function wait() {
                   1052:    if ((menuloaded==1) || (tim==1)) {
1.35      www      1053:       window.status='Done.';
1.32      www      1054:       if (tim==0) {
                   1055:          clearTimeout(canceltim);
                   1056:          $configmenu
                   1057:          window.location='$lowerurl';  
                   1058:       } else {
1.52      www      1059: 	  window.location='/adm/remote?action=collapse&url=$esclowerurl';
1.32      www      1060:       }
                   1061:    } else {
1.35      www      1062:       wheelswitch();
                   1063:       setTimeout('wait();',200);
1.32      www      1064:    }
                   1065: }
                   1066: 
                   1067: function main() {
1.52      www      1068:    canceltim=setTimeout('tim=1;',30000);
1.35      www      1069:    window.status='-';
1.118     albertel 1070:    var date=new Date();
                   1071:    timestart=date.getTime();
1.32      www      1072:    wait();
                   1073: }
                   1074: 
1.277     bisitz   1075: // ]]>
1.32      www      1076: </script>
                   1077: ENDREMOTESTARTUP
                   1078: }
                   1079: 
                   1080: sub setflags() {
                   1081:     return(<<ENDSETFLAGS);
1.129     albertel 1082: <script type="text/javascript">
1.277     bisitz   1083: // <![CDATA[
1.32      www      1084:     menuloaded=0;
                   1085:     tim=0;
1.277     bisitz   1086: // ]]>
1.32      www      1087: </script>
                   1088: ENDSETFLAGS
                   1089: }
                   1090: 
                   1091: sub maincall() {
1.269     droeschl 1092:     if ($env{'environment.remote'} eq 'off') { return ''; }
1.32      www      1093:     return(<<ENDMAINCALL);
1.129     albertel 1094: <script type="text/javascript">
1.277     bisitz   1095: // <![CDATA[
1.32      www      1096:     main();
1.277     bisitz   1097: // ]]>
1.32      www      1098: </script>
                   1099: ENDMAINCALL
                   1100: }
1.118     albertel 1101: 
                   1102: sub load_remote_msg {
                   1103:     my ($lowerurl)=@_;
                   1104: 
1.269     droeschl 1105:     if ($env{'environment.remote'} eq 'off') { return ''; }
1.118     albertel 1106: 
1.183     www      1107:     my $esclowerurl=&escape($lowerurl);
1.261     bisitz   1108:     my $link=&mt('[_1]Continue[_2] on in Inline Menu mode'
                   1109:                 ,'<a href="/adm/remote?action=collapse&amp;url='.$esclowerurl.'">'
                   1110:                 ,'</a>');
1.118     albertel 1111:     return(<<ENDREMOTEFORM);
                   1112: <p>
                   1113: <form name="wheel">
1.119     www      1114: <input name="spin" type="text" size="60" />
1.118     albertel 1115: </form>
                   1116: </p>
                   1117: <p>$link</p>
                   1118: ENDREMOTEFORM
                   1119: }
1.230     albertel 1120: 
                   1121: sub get_menu_name {
                   1122:     my $hostid = $Apache::lonnet::perlvar{'lonHostID'};
                   1123:     $hostid =~ s/\W//g;
                   1124:     return 'LCmenu'.$hostid;
                   1125: }
                   1126: 
1.30      www      1127: 
                   1128: sub reopenmenu {
1.269     droeschl 1129:    if ($env{'environment.remote'} eq 'off') { return ''; }
1.230     albertel 1130:    my $menuname = &get_menu_name();
1.47      matthew  1131:    my $nothing = &Apache::lonhtmlcommon::javascript_nothing();
                   1132:    return('window.open('.$nothing.',"'.$menuname.'","",false);');
1.30      www      1133: } 
                   1134: 
1.1       www      1135: 
                   1136: sub open {
1.22      www      1137:     my $returnval='';
1.269     droeschl 1138:     if ($env{'environment.remote'} eq 'off') { 
1.277     bisitz   1139: 	return
                   1140:         '<script type="text/javascript">'."\n"
                   1141:        .'// <![CDATA['."\n"
                   1142:        .'self.name="loncapaclient";'."\n"
                   1143:        .'// ]]>'."\n"
                   1144:        .'</script>';
1.111     albertel 1145:     }
1.230     albertel 1146:     my $menuname = &get_menu_name();
1.222     albertel 1147:     
                   1148: #    unless (shift eq 'unix') {
1.22      www      1149: # resizing does not work on linux because of virtual desktop sizes
1.222     albertel 1150: #       $returnval.=(<<ENDRESIZE);
                   1151: #if (window.screen) {
                   1152: #    self.resizeTo(screen.availWidth-215,screen.availHeight-55);
                   1153: #    self.moveTo(190,15);
                   1154: #}
                   1155: #ENDRESIZE
                   1156: #    }
1.277     bisitz   1157:     $returnval=(<<ENDOPEN);
                   1158: // <![CDATA[
1.35      www      1159: window.status='Opening LON-CAPA Remote Control';
1.272     droeschl 1160: var menu=window.open("/res/adm/pages/menu.html?inhibitmenu=yes","$menuname",
1.191     www      1161: "height=375,width=150,scrollbars=no,menubar=no,top=5,left=5,screenX=5,screenY=5");
1.71      www      1162: self.name='loncapaclient';
1.277     bisitz   1163: // ]]>
1.1       www      1164: ENDOPEN
1.129     albertel 1165:     return '<script type="text/javascript">'.$returnval.'</script>';
1.1       www      1166: }
                   1167: 
1.2       www      1168: 
                   1169: # ================================================================== Raw Config
                   1170: 
1.3       www      1171: sub clear {
                   1172:     my ($row,$col)=@_;
1.269     droeschl 1173:     unless ($env{'environment.remote'} eq 'off') {
1.275     www      1174:        if (($row<1) || ($row>13)) { return ''; }
1.35      www      1175:        return "\n".qq(window.status+='.';swmenu.clearbut($row,$col););
1.56      www      1176:    } else { 
                   1177:        $inlineremote[10*$row+$col]='';
                   1178:        return ''; 
                   1179:    }
1.3       www      1180: }
                   1181: 
1.40      www      1182: # ============================================ Switch a button or create a link
1.25      matthew  1183: # Switch acts on the javascript that is executed when a button is clicked.  
                   1184: # The javascript is usually similar to "go('/adm/roles')" or "cstrgo(..)".
1.40      www      1185: 
1.2       www      1186: sub switch {
1.209     www      1187:     my ($uname,$udom,$row,$col,$img,$top,$bot,$act,$desc,$cat,$nobreak)=@_;
1.2       www      1188:     $act=~s/\$uname/$uname/g;
                   1189:     $act=~s/\$udom/$udom/g;
1.88      www      1190:     $top=&mt($top);
                   1191:     $bot=&mt($bot);
                   1192:     $desc=&mt($desc);
1.238     www      1193:     if (($env{'environment.remote'} ne 'off') || ($env{'environment.icons'} eq 'classic')) {
                   1194:        $img=&mt($img);
                   1195:     }
1.209     www      1196:     my $idx=10*$row+$col;
                   1197:     $category_members{$cat}.=':'.$idx;
                   1198: 
1.269     droeschl 1199:     unless ($env{'environment.remote'} eq 'off') {
1.275     www      1200:        if (($row<1) || ($row>13)) { return ''; }
1.50      www      1201: # Remote
1.34      www      1202:        return "\n".
1.35      www      1203:  qq(window.status+='.';swmenu.switchbutton($row,$col,"$img","$top","$bot","$act","$desc"););
1.34      www      1204:    } else {
1.50      www      1205: # Inline Remote
1.213     www      1206:        if ($env{'environment.icons'} ne 'classic') {
                   1207:           $img=~s/\.gif$/\.png/;
                   1208:        }
1.41      www      1209:        if ($nobreak==2) { return ''; }
1.34      www      1210:        my $text=$top.' '.$bot;
1.78      www      1211:        $text=~s/\s*\-\s*//gs;
1.105     www      1212: 
1.99      www      1213:        my $pic=
1.225     albertel 1214: 	   '<img alt="'.$text.'" src="'.
                   1215: 	   &Apache::loncommon::lonhttpdurl('/res/adm/pages/'.$img).
1.250     harmsja  1216: 	   '" align="'.($nobreak==3?'right':'left').'" class="LC_noBorder" />';
1.177     albertel 1217:        if ($env{'browser.interface'} eq 'faketextual') {
1.274     www      1218: # Main Menu
1.103     www      1219: 	   if ($nobreak==3) {
1.209     www      1220: 	       $inlineremote[$idx]="\n".
1.177     albertel 1221: 		   '<td class="LC_menubuttons_text" align="right">'.$text.
1.247     harmsja  1222: 		   '</td><td align="left">'.
1.103     www      1223: 		   '<a href="javascript:'.$act.';">'.$pic.'</a></td></tr>';
                   1224: 	   } elsif ($nobreak) {
1.209     www      1225: 	       $inlineremote[$idx]="\n<tr>".
1.247     harmsja  1226: 		   '<td align="left">'.
1.177     albertel 1227: 		   '<a href="javascript:'.$act.';">'.$pic.'</a></td>
1.215     www      1228:                     <td class="LC_menubuttons_text" align="left"><a class="LC_menubuttons_link" href="javascript:'.$act.';"><span class="LC_menubuttons_inline_text">'.$text.'</span></a></td>';
1.103     www      1229: 	   } else {
1.209     www      1230: 	       $inlineremote[$idx]="\n<tr>".
1.247     harmsja  1231: 		   '<td align="left">'.
1.103     www      1232: 		   '<a href="javascript:'.$act.';">'.$pic.
1.177     albertel 1233: 		   '</a></td><td class="LC_menubuttons_text" colspan="3">'.
1.215     www      1234: 		   '<a class="LC_menubuttons_link" href="javascript:'.$act.';"><span class="LC_menubuttons_inline_text">'.$desc.'</span></a></td></tr>';
1.103     www      1235: 	   }
1.94      www      1236:        } else {
1.103     www      1237: # Inline Menu
1.218     www      1238:            if ($env{'environment.icons'} eq 'iconsonly') {
                   1239:               $inlineremote[$idx]='<a title="'.$desc.'" href="javascript:'.$act.';">'.$pic.'</a>';
                   1240:            } else {
                   1241: 	      $inlineremote[$idx]=
1.215     www      1242: 		   '<a class="LC_menubuttons_link" href="javascript:'.$act.';">'.$pic.
                   1243: 		   '<span class="LC_menubuttons_inline_text">'.$desc.'</span></a>';
1.218     www      1244:            }
1.94      www      1245:        }
1.34      www      1246:    }
1.56      www      1247:     return '';
1.2       www      1248: }
                   1249: 
                   1250: sub secondlevel {
                   1251:     my $output='';
                   1252:     my 
1.209     www      1253:     ($uname,$udom,$rol,$crs,$pub,$con,$row,$col,$prt,$img,$top,$bot,$act,$desc,$cat)=@_;
1.2       www      1254:     if ($prt eq 'any') {
1.209     www      1255: 	   $output.=&switch($uname,$udom,$row,$col,$img,$top,$bot,$act,$desc,$cat);
1.2       www      1256:     } elsif ($prt=~/^r(\w+)/) {
                   1257:         if ($rol eq $1) {
1.209     www      1258:            $output.=&switch($uname,$udom,$row,$col,$img,$top,$bot,$act,$desc,$cat);
1.2       www      1259:         }
                   1260:     }
                   1261:     return $output;
                   1262: }
                   1263: 
1.18      www      1264: sub openmenu {
1.230     albertel 1265:     my $menuname = &get_menu_name();
1.269     droeschl 1266:     if ($env{'environment.remote'} eq 'off') { return ''; }
1.47      matthew  1267:     my $nothing = &Apache::lonhtmlcommon::javascript_nothing();
                   1268:     return "window.open(".$nothing.",'".$menuname."');";
1.18      www      1269: }
                   1270: 
1.56      www      1271: sub inlinemenu {
1.210     albertel 1272:     undef(@inlineremote);
                   1273:     undef(%category_members);
1.275     www      1274: # calling rawconfig with "1" will evaluate mydesk.tab, even if there is no active remote control
1.56      www      1275:     &rawconfig(1);
1.214     albertel 1276:     my $output='<table id="LC_mainmenu"><tr>';
1.209     www      1277:     for (my $col=1; $col<=2; $col++) {
1.241     riegler  1278:         $output.='<td class="LC_mainmenu_col_fieldset">';
1.209     www      1279:         for (my $row=1; $row<=8; $row++) {
                   1280:             foreach my $cat (keys(%category_members)) {
                   1281:                if ($category_positions{$cat} ne "$col,$row") { next; }
1.247     harmsja  1282:                #$output.='<table><tr><td colspan="4" class="LC_menubuttons_category">'.&mt($category_names{$cat}).'</td></tr>';
1.270     bisitz   1283:                $output.='<div class="LC_Box">';
1.250     harmsja  1284: 	       $output.='<h4 class="LC_hcell">'.&mt($category_names{$cat}).'</h4>';
1.247     harmsja  1285:                $output.='<table>';
1.240     riegler  1286:                my %active=();
                   1287:                foreach my $menu_item (split(/\:/,$category_members{$cat})) {
                   1288:                   if ($inlineremote[$menu_item]) {
                   1289:                      $active{$menu_item}=1;
                   1290:                   }
                   1291:                }  
                   1292:                foreach my $item (sort(keys(%active))) {
                   1293:                   $output.=$inlineremote[$item];
                   1294:                }
                   1295:                $output.='</table>';
1.245     harmsja  1296:                $output.='</div>';
1.240     riegler  1297:             }
                   1298:          }
                   1299:          $output.="</td>";
                   1300:     }
                   1301:     $output.="</tr></table>";
                   1302:     return $output;
                   1303: }
                   1304: 
1.2       www      1305: sub rawconfig {
1.274     www      1306: #
                   1307: # This evaluates mydesk.tab
                   1308: # Need to add more positions and more privileges to deal with all
                   1309: # menu items.
                   1310: #
1.34      www      1311:     my $textualoverride=shift;
                   1312:     my $output='';
1.269     droeschl 1313:     unless ($env{'environment.remote'} eq 'off') {
1.35      www      1314:        $output.=
                   1315:  "window.status='Opening Remote Control';var swmenu=".&openmenu().
                   1316: "\nwindow.status='Configuring Remote Control ';";
1.34      www      1317:     } else {
                   1318:        unless ($textualoverride) { return ''; }
                   1319:     }
1.152     albertel 1320:     my $uname=$env{'user.name'};
                   1321:     my $udom=$env{'user.domain'};
                   1322:     my $adv=$env{'user.adv'};
1.266     raeburn  1323:     my $show_course=&Apache::loncommon::show_course();
1.152     albertel 1324:     my $author=$env{'user.author'};
1.5       www      1325:     my $crs='';
1.295     raeburn  1326:     my $crstype='';
1.152     albertel 1327:     if ($env{'request.course.id'}) {
                   1328:        $crs='/'.$env{'request.course.id'};
                   1329:        if ($env{'request.course.sec'}) {
                   1330: 	   $crs.='_'.$env{'request.course.sec'};
1.7       www      1331:        }
1.8       www      1332:        $crs=~s/\_/\//g;
1.295     raeburn  1333:        $crstype = &Apache::loncommon::course_type();
1.5       www      1334:     }
1.152     albertel 1335:     my $pub=($env{'request.state'} eq 'published');
                   1336:     my $con=($env{'request.state'} eq 'construct');
                   1337:     my $rol=$env{'request.role'};
                   1338:     my $requested_domain = $env{'request.role.domain'};
1.184     raeburn  1339:     foreach my $line (@desklines) {
1.209     www      1340:         my ($row,$col,$pro,$prt,$img,$top,$bot,$act,$desc,$cat)=split(/\:/,$line);
1.3       www      1341:         $prt=~s/\$uname/$uname/g;
                   1342:         $prt=~s/\$udom/$udom/g;
1.295     raeburn  1343:         if ($prt =~ /\$crs/) {
                   1344:             next unless ($env{'request.course.id'});
                   1345:             next if ($crstype eq 'Community');
                   1346:             $prt=~s/\$crs/$crs/g;
                   1347:         } elsif ($prt =~ /\$cmty/) {
                   1348:             next unless ($env{'request.course.id'});
                   1349:             next if ($crstype ne 'Community');
                   1350:             $prt=~s/\$cmty/$crs/g;
                   1351:         }
1.25      matthew  1352:         $prt=~s/\$requested_domain/$requested_domain/g;
1.211     www      1353:         if ($category_names{$cat}!~/\w/) { $cat='oth'; }
1.3       www      1354:         if ($pro eq 'clear') {
1.4       www      1355: 	    $output.=&clear($row,$col);
1.3       www      1356:         } elsif ($pro eq 'any') {
1.2       www      1357:                $output.=&secondlevel(
1.209     www      1358: 	  $uname,$udom,$rol,$crs,$pub,$con,$row,$col,$prt,$img,$top,$bot,$act,$desc,$cat);
1.2       www      1359: 	} elsif ($pro eq 'smp') {
                   1360:             unless ($adv) {
                   1361:                $output.=&secondlevel(
1.209     www      1362:           $uname,$udom,$rol,$crs,$pub,$con,$row,$col,$prt,$img,$top,$bot,$act,$desc,$cat);
1.2       www      1363:             }
                   1364:         } elsif ($pro eq 'adv') {
                   1365:             if ($adv) {
                   1366:                $output.=&secondlevel(
1.209     www      1367: 	  $uname,$udom,$rol,$crs,$pub,$con,$row,$col,$prt,$img,$top,$bot,$act,$desc,$cat);
1.2       www      1368:             }
1.231     albertel 1369: 	} elsif ($pro eq 'shc') {
                   1370:             if ($show_course) {
                   1371:                $output.=&secondlevel(
                   1372:           $uname,$udom,$rol,$crs,$pub,$con,$row,$col,$prt,$img,$top,$bot,$act,$desc,$cat);
                   1373:             }
                   1374:         } elsif ($pro eq 'nsc') {
                   1375:             if (!$show_course) {
                   1376:                $output.=&secondlevel(
                   1377: 	  $uname,$udom,$rol,$crs,$pub,$con,$row,$col,$prt,$img,$top,$bot,$act,$desc,$cat);
                   1378:             }
1.81      matthew  1379:         } elsif (($pro=~/^p(\w+)/) && ($prt)) {
1.295     raeburn  1380:             my $priv = $1;
                   1381:             if ($priv =~ /^mdc(Course|Community)/) {
                   1382:                 if ($crstype eq $1) {
                   1383:                     $priv = 'mdc';
                   1384:                 } else {
                   1385:                     next;
                   1386:                 }
                   1387:             }
                   1388: 	    if (&Apache::lonnet::allowed($priv,$prt)) {
1.209     www      1389:                $output.=&switch($uname,$udom,$row,$col,$img,$top,$bot,$act,$desc,$cat);
1.4       www      1390:             }
1.295     raeburn  1391:         } elsif ($pro eq 'course')  {
                   1392:             if (($env{'request.course.fn'}) && ($crstype ne 'Community')) {
1.209     www      1393:                $output.=&switch($uname,$udom,$row,$col,$img,$top,$bot,$act,$desc,$cat);
1.81      matthew  1394: 	    }
1.295     raeburn  1395:         } elsif ($pro eq 'community')  {
                   1396:             if (($env{'request.course.fn'}) && ($crstype eq 'Community')) {
                   1397:                $output.=&switch($uname,$udom,$row,$col,$img,$top,$bot,$act,$desc,$cat);
                   1398:             }
1.124     matthew  1399:         } elsif ($pro =~ /^courseenv_(.*)$/) {
                   1400:             my $key = $1;
1.295     raeburn  1401:             if (($env{'course.'.$env{'request.course.id'}.'.'.$key}) && 
                   1402:                 ($crstype ne 'Community')) {
                   1403:                 $output.=&switch($uname,$udom,$row,$col,$img,$top,$bot,$act,$desc,$cat);
                   1404:             }
                   1405:         } elsif ($pro =~ /^communityenv_(.*)$/) {
                   1406:             my $key = $1;
                   1407:             if (($env{'course.'.$env{'request.course.id'}.'.'.$key}) && 
                   1408:                 ($crstype eq 'Community')) {
1.209     www      1409:                 $output.=&switch($uname,$udom,$row,$col,$img,$top,$bot,$act,$desc,$cat);
1.124     matthew  1410:             }
1.81      matthew  1411:         } elsif ($pro =~ /^course_(.*)$/) {
                   1412:             # Check for permissions inside of a course
1.295     raeburn  1413:             if (($env{'request.course.id'}) && ($crstype ne 'Community') && 
1.152     albertel 1414:                 (&Apache::lonnet::allowed($1,$env{'request.course.id'}.
                   1415:             ($env{'request.course.sec'}?'/'.$env{'request.course.sec'}:''))
1.81      matthew  1416:                  )) {
1.209     www      1417:                 $output.=&switch($uname,$udom,$row,$col,$img,$top,$bot,$act,$desc,$cat);
1.26      www      1418: 	    }
1.295     raeburn  1419:         } elsif ($pro =~ /^community_(.*)$/) {
                   1420:             # Check for permissions inside of a community
                   1421:             if (($env{'request.course.id'}) && ($crstype eq 'Community') &&   
                   1422:                 (&Apache::lonnet::allowed($1,$env{'request.course.id'}.
                   1423:             ($env{'request.course.sec'}?'/'.$env{'request.course.sec'}:''))
                   1424:                  )) {
                   1425:                 $output.=&switch($uname,$udom,$row,$col,$img,$top,$bot,$act,$desc,$cat);
                   1426:             }
1.4       www      1427:         } elsif ($pro eq 'author') {
                   1428:             if ($author) {
1.152     albertel 1429:                 if ((($prt eq 'rca') && ($env{'request.role'}=~/^ca/)) ||
1.234     raeburn  1430:                     (($prt eq 'raa') && ($env{'request.role'}=~/^aa/)) || 
1.152     albertel 1431:                     (($prt eq 'rau') && ($env{'request.role'}=~/^au/))) {
1.19      matthew  1432:                     # Check that we are on the correct machine
1.29      matthew  1433:                     my $cadom=$requested_domain;
1.152     albertel 1434:                     my $caname=$env{'user.name'};
1.234     raeburn  1435:                     if (($prt eq 'rca') || ($prt eq 'raa')) {
1.29      matthew  1436: 		       ($cadom,$caname)=
1.206     albertel 1437:                                ($env{'request.role'}=~/($match_domain)\/($match_username)$/);
1.29      matthew  1438:                     }                       
                   1439:                     $act =~ s/\$caname/$caname/g;
1.19      matthew  1440:                     my $home = &Apache::lonnet::homeserver($caname,$cadom);
1.109     albertel 1441: 		    my $allowed=0;
                   1442: 		    my @ids=&Apache::lonnet::current_machine_ids();
                   1443: 		    foreach my $id (@ids) { if ($id eq $home) { $allowed=1; } }
                   1444: 		    if ($allowed) {
1.209     www      1445:                         $output.=&switch($caname,$cadom,
                   1446:                                         $row,$col,$img,$top,$bot,$act,$desc,$cat);
1.19      matthew  1447:                     }
1.6       www      1448:                 }
1.2       www      1449:             }
1.248     raeburn  1450:         } elsif ($pro eq 'tools') {
                   1451:             my @tools = ('aboutme','blog','portfolio');
                   1452:             if (grep(/^\Q$prt\E$/,@tools)) {
1.249     raeburn  1453:                 if (!&Apache::lonnet::usertools_access($env{'user.name'},
1.251     raeburn  1454:                                                        $env{'user.domain'},
                   1455:                                                        $prt,undef,'tools')) {
                   1456:                     $output.=&clear($row,$col);
                   1457:                     next;
                   1458:                 }
1.278     raeburn  1459:             } elsif (($prt eq 'reqcrsnsc') || ($prt eq 'reqcrsshc')) {
                   1460:                 if (($prt eq 'reqcrsnsc') && ($show_course))   {
                   1461:                     next;
                   1462:                 }
                   1463:                 if (($prt eq 'reqcrsshc') && (!$show_course)) {
                   1464:                     next;
                   1465:                 }
1.279     raeburn  1466:                 my $showreqcrs = &check_for_rcrs();
1.251     raeburn  1467:                 if (!$showreqcrs) {
1.248     raeburn  1468:                     $output.=&clear($row,$col);
                   1469:                     next;
                   1470:                 }
                   1471:             }
                   1472:             $prt='any';
                   1473:             $output.=&secondlevel(
                   1474:           $uname,$udom,$rol,$crs,$pub,$con,$row,$col,$prt,$img,$top,$bot,$act,$desc,$cat);
1.2       www      1475:         }
1.13      harris41 1476:     }
1.269     droeschl 1477:     unless ($env{'environment.remote'} eq 'off') {
1.35      www      1478:        $output.="\nwindow.status='Synchronizing Time';swmenu.syncclock(1000*".time.");\nwindow.status='Remote Control Configured.';";
1.123     www      1479:        if (&Apache::lonmsg::newmail()) { 
                   1480: 	   $output.='swmenu.setstatus("you have","messages");';
                   1481:        }
1.34      www      1482:     }
1.123     www      1483: 
1.2       www      1484:     return $output;
                   1485: }
                   1486: 
1.279     raeburn  1487: sub check_for_rcrs {
                   1488:     my $showreqcrs = 0;
1.280     raeburn  1489:     my @reqtypes = ('official','unofficial','community');
                   1490:     foreach my $type (@reqtypes) {
1.279     raeburn  1491:         if (&Apache::lonnet::usertools_access($env{'user.name'},
                   1492:                                               $env{'user.domain'},
                   1493:                                               $type,undef,'requestcourses')) {
                   1494:             $showreqcrs = 1;
                   1495:             last;
                   1496:         }
                   1497:     }
1.280     raeburn  1498:     if (!$showreqcrs) {
                   1499:         foreach my $type (@reqtypes) {
                   1500:             if ($env{'environment.reqcrsotherdom.'.$type} ne '') {
                   1501:                 $showreqcrs = 1;
                   1502:                 last;
                   1503:             }
                   1504:         }
                   1505:     }
1.279     raeburn  1506:     return $showreqcrs;
                   1507: }
                   1508: 
1.2       www      1509: # ======================================================================= Close
1.1       www      1510: 
                   1511: sub close {
1.269     droeschl 1512:     if ($env{'environment.remote'} eq 'off') { return ''; }
1.230     albertel 1513:     my $menuname = &get_menu_name();
1.1       www      1514:     return(<<ENDCLOSE);
1.129     albertel 1515: <script type="text/javascript">
1.277     bisitz   1516: // <![CDATA[
1.35      www      1517: window.status='Accessing Remote Control';
1.30      www      1518: menu=window.open("/adm/rat/empty.html","$menuname",
1.1       www      1519:                  "height=350,width=150,scrollbars=no,menubar=no");
1.35      www      1520: window.status='Disabling Remote Control';
                   1521: menu.active=0;
1.31      www      1522: menu.autologout=0;
1.35      www      1523: window.status='Closing Remote Control';
1.1       www      1524: menu.close();
1.35      www      1525: window.status='Done.';
1.277     bisitz   1526: // ]]>
1.1       www      1527: </script>
                   1528: ENDCLOSE
                   1529: }
                   1530: 
                   1531: # ====================================================================== Footer
                   1532: 
                   1533: sub footer {
                   1534: 
1.33      www      1535: }
                   1536: 
1.122     albertel 1537: sub nav_control_js {
1.152     albertel 1538:     my $nav=($env{'environment.remotenavmap'} eq 'on');
1.122     albertel 1539:     return (<<NAVCONTROL);
                   1540:     var w_loncapanav_flag="$nav";
                   1541: 
                   1542: 
                   1543: function gonav(url) {
                   1544:    if (w_loncapanav_flag != 1) {
                   1545:       gopost(url,'');
                   1546:    }  else {
                   1547:       navwindow=window.open(url,
                   1548:                   "loncapanav","height=600,width=400,scrollbars=1"); 
                   1549:    }
                   1550: }
                   1551: NAVCONTROL
                   1552: }
                   1553: 
1.42      www      1554: sub utilityfunctions {
1.132     raeburn  1555:     my $caller = shift;
1.269     droeschl 1556:     unless ($env{'environment.remote'} eq 'off' || 
                   1557:             $caller eq '/adm/menu') { 
                   1558:             return ''; }
                   1559:             
1.152     albertel 1560:     my $currenturl=&Apache::lonnet::clutter(&Apache::lonnet::fixversion((split(/\?/,$env{'request.noversionuri'}))[0]));
1.293     raeburn  1561:     if ($currenturl =~ m{^/adm/wrapper/ext/}) {
                   1562:         if ($env{'request.external.querystring'}) {
                   1563:             $currenturl .= ($currenturl=~/\?/)?'&':'?'.$env{'request.external.querystring'};
                   1564:         }
                   1565:     }
1.183     www      1566:     $currenturl=&Apache::lonenc::check_encrypt(&unescape($currenturl));
1.125     albertel 1567:     
1.152     albertel 1568:     my $currentsymb=&Apache::lonenc::check_encrypt($env{'request.symb'});
1.122     albertel 1569:     my $nav_control=&nav_control_js();
1.175     albertel 1570: 
                   1571:     my $start_page_annotate = 
                   1572:         &Apache::loncommon::start_page('Annotator',undef,
                   1573: 				       {'only_body' => 1,
                   1574: 					'js_ready'  => 1,
                   1575: 					'bgcolor'   => '#BBBBBB',
                   1576: 					'add_entries' => {
                   1577: 					    'onload' => 'javascript:document.goannotate.submit();'}});
                   1578: 
1.205     albertel 1579:     my $end_page_annotate = 
                   1580:         &Apache::loncommon::end_page({'js_ready' => 1});
                   1581: 
1.175     albertel 1582:     my $start_page_bookmark = 
                   1583:         &Apache::loncommon::start_page('Bookmarks',undef,
                   1584: 				       {'only_body' => 1,
                   1585: 					'js_ready'  => 1,
                   1586: 					'bgcolor'   => '#BBBBBB',});
                   1587: 
1.205     albertel 1588:     my $end_page_bookmark = 
1.175     albertel 1589:         &Apache::loncommon::end_page({'js_ready' => 1});
                   1590: 
1.42      www      1591: return (<<ENDUTILITY)
                   1592: 
                   1593:     var currentURL="$currenturl";
                   1594:     var reloadURL="$currenturl";
                   1595:     var currentSymb="$currentsymb";
                   1596: 
1.114     albertel 1597: $nav_control
                   1598: 
1.42      www      1599: function go(url) {
                   1600:    if (url!='' && url!= null) {
                   1601:        currentURL = null;
                   1602:        currentSymb= null;
                   1603:        window.location.href=url;
                   1604:    }
                   1605: }
                   1606: 
1.297     raeburn  1607: function gotop(url) {
                   1608:     if (url!='' && url!= null) {
                   1609:         top.location.href = url;
                   1610:     }
                   1611: }
                   1612: 
1.42      www      1613: function gopost(url,postdata) {
                   1614:    if (url!='') {
                   1615:       this.document.server.action=url;
                   1616:       this.document.server.postdata.value=postdata;
                   1617:       this.document.server.command.value='';
                   1618:       this.document.server.url.value='';
                   1619:       this.document.server.symb.value='';
                   1620:       this.document.server.submit();
                   1621:    }
                   1622: }
                   1623: 
                   1624: function gocmd(url,cmd) {
                   1625:    if (url!='') {
                   1626:       this.document.server.action=url;
                   1627:       this.document.server.postdata.value='';
                   1628:       this.document.server.command.value=cmd;
                   1629:       this.document.server.url.value=currentURL;
                   1630:       this.document.server.symb.value=currentSymb;
                   1631:       this.document.server.submit();
                   1632:    }
1.57      www      1633: }
                   1634: 
1.121     raeburn  1635: function gocstr(url,filename) {
                   1636:     if (url == '/adm/cfile?action=delete') {
                   1637:         this.document.cstrdelete.filename.value = filename
                   1638:         this.document.cstrdelete.submit();
                   1639:         return;
                   1640:     }
1.137     raeburn  1641:     if (url == '/adm/printout') {
                   1642:         this.document.cstrprint.postdata.value = filename
                   1643:         this.document.cstrprint.curseed.value = 0;
                   1644:         this.document.cstrprint.problemtype.value = 0;
1.138     raeburn  1645:         if (this.document.lonhomework) {
                   1646:             if ((this.document.lonhomework.rndseed) && (this.document.lonhomework.rndseed.value != null) && (this.document.lonhomework.rndseed.value != '')) {
                   1647:                 this.document.cstrprint.curseed.value = this.document.lonhomework.rndseed.value
                   1648:             }
                   1649:             if (this.document.lonhomework.problemtype) {
1.164     albertel 1650: 		if (this.document.lonhomework.problemtype.value) {
                   1651: 		    this.document.cstrprint.problemtype.value = 
                   1652: 			this.document.lonhomework.problemtype.value;
                   1653: 		} else if (this.document.lonhomework.problemtype.options) {
                   1654: 		    for (var i=0; i<this.document.lonhomework.problemtype.options.length; i++) {
                   1655: 			if (this.document.lonhomework.problemtype.options[i].selected) {
                   1656: 			    if (this.document.lonhomework.problemtype.options[i].value != null && this.document.lonhomework.problemtype.options[i].value != '') { 
                   1657: 				this.document.cstrprint.problemtype.value = this.document.lonhomework.problemtype.options[i].value
                   1658: 				}
                   1659: 			}
                   1660: 		    }
                   1661: 		}
                   1662: 	    }
                   1663: 	}
1.137     raeburn  1664:         this.document.cstrprint.submit();
                   1665:         return;
                   1666:     }
1.121     raeburn  1667:     if (url !='') {
                   1668:         this.document.constspace.filename.value = filename;
                   1669:         this.document.constspace.action = url;
                   1670:         this.document.constspace.submit();
                   1671:     }
                   1672: }
                   1673: 
1.131     raeburn  1674: function golist(url) {
                   1675:    if (url!='' && url!= null) {
                   1676:        currentURL = null;
                   1677:        currentSymb= null;
                   1678:        top.location.href=url;
                   1679:    }
                   1680: }
                   1681: 
                   1682: 
1.121     raeburn  1683: 
1.57      www      1684: function catalog_info() {
1.102     albertel 1685:    loncatinfo=window.open(window.location.pathname+'.meta',"LONcatInfo",'height=320,width=280,resizable=yes,scrollbars=yes,location=no,menubar=no,toolbar=no');
1.57      www      1686: }
                   1687: 
                   1688: function chat_win() {
1.290     raeburn  1689:    lonchat=window.open('/res/adm/pages/chatroom.html',"LONchat",'height=320,width=480,resizable=yes,location=no,menubar=no,toolbar=no');
1.42      www      1690: }
1.169     raeburn  1691: 
                   1692: function group_chat(group) {
                   1693:    var url = '/adm/groupchat?group='+group;
                   1694:    var winName = 'LONchat_'+group;
                   1695:    grpchat=window.open(url,winName,'height=320,width=280,resizable=yes,location=no,menubar=no,toolbar=no');
                   1696: }
1.175     albertel 1697: 
                   1698: function edit_bookmarks() {
                   1699:    go('');
                   1700:    w_BookmarkPal_flag=1;
                   1701:    bookmarkpal=window.open("/adm/bookmarks",
                   1702:                "BookmarkPal", "width=400,height=505,scrollbars=0");
                   1703: }
                   1704: 
                   1705: function annotate() {
                   1706:    w_Annotator_flag=1;
                   1707:    annotator=window.open('','Annotator','width=365,height=265,scrollbars=0');
                   1708:    annotator.document.write(
                   1709:    '$start_page_annotate'
                   1710:   +"<form name='goannotate' target='Annotator' method='post' "
                   1711:   +"action='/adm/annotations'>"
1.217     albertel 1712:   +"<input type='hidden' name='symbnew' value='"+currentSymb+"' />"
1.181     albertel 1713:   +"<\\/form>"
1.205     albertel 1714:   +'$end_page_annotate');
1.175     albertel 1715:    annotator.document.close();
                   1716: }
                   1717: 
                   1718: function set_bookmark() {
                   1719:    go('');
                   1720:    clienttitle=document.title;
                   1721:    clienthref=location.pathname;
                   1722:    w_bmquery_flag=1;
                   1723:    bmquery=window.open('','bmquery','width=365,height=165,scrollbars=0');
                   1724:    bmquery.document.write(
                   1725:    '$start_page_bookmark'
1.260     bisitz   1726:    +'<center><form method="post"'
                   1727:    +' name="newlink" action="/adm/bookmarks" target="bmquery" '
                   1728:    +'> <table width="340" height="150" '
                   1729:    +'bgcolor="#FFFFFF" align="center"><tr><td>Link Name:<br /><input '
                   1730:    +'type="text" name="title" size="45" value="'+clienttitle+'" />'
                   1731:    +'<br />Address:<br /><input type="text" name="address" size="45" '
                   1732:    +'value="'+clienthref+'" /><br /><center><input type="submit" '
                   1733:    +'value="Save" /> <input type="button" value="Close" '
                   1734:    +'onclick="javascript:window.close();" /></center></td>'
                   1735:    +'</tr></table></form></center>'
1.205     albertel 1736:    +'$end_page_bookmark' );
1.175     albertel 1737:    bmquery.document.close();
                   1738: }
                   1739: 
1.42      www      1740: ENDUTILITY
                   1741: }
                   1742: 
                   1743: sub serverform {
                   1744:     return(<<ENDSERVERFORM);
1.181     albertel 1745: <form name="server" action="/adm/logout" method="post" target="_top">
1.42      www      1746: <input type="hidden" name="postdata" value="none" />
                   1747: <input type="hidden" name="command" value="none" />
                   1748: <input type="hidden" name="url" value="none" />
                   1749: <input type="hidden" name="symb" value="none" />
                   1750: </form>
                   1751: ENDSERVERFORM
                   1752: }
1.113     albertel 1753: 
1.121     raeburn  1754: sub constspaceform {
                   1755:     return(<<ENDCONSTSPACEFORM);
1.181     albertel 1756: <form name="constspace" action="/adm/logout" method="post" target="_top">
1.121     raeburn  1757: <input type="hidden" name="filename" value="" />
                   1758: </form>
1.181     albertel 1759: <form name="cstrdelete" action="/adm/cfile" method="post" target="_top">
1.121     raeburn  1760: <input type="hidden" name="action" value="delete" /> 
                   1761: <input type="hidden" name="filename" value="" />
                   1762: </form>
1.181     albertel 1763: <form name="cstrprint" action="/adm/printout" target="_parent" method="post">
1.137     raeburn  1764: <input type="hidden" name="postdata" value="" />
                   1765: <input type="hidden" name="curseed" value="" />
                   1766: <input type="hidden" name="problemtype" value="" />
                   1767: </form>
                   1768: 
1.121     raeburn  1769: ENDCONSTSPACEFORM
                   1770: }
                   1771: 
                   1772: 
1.113     albertel 1773: sub get_nav_status {
                   1774:     my $navstatus="swmenu.w_loncapanav_flag=";
1.152     albertel 1775:     if ($env{'environment.remotenavmap'} eq 'on') {
1.113     albertel 1776: 	$navstatus.="1";
                   1777:     } else {
                   1778: 	$navstatus.="-1";
                   1779:     }
                   1780:     return $navstatus;
                   1781: }
                   1782: 
1.220     raeburn  1783: sub hidden_button_check {
                   1784:     my $hidden;
                   1785:     if ($env{'request.course.id'} eq '') {
                   1786:         return;
                   1787:     }
                   1788:     if ($env{'request.role.adv'}) {
                   1789:         return;
                   1790:     }
1.232     raeburn  1791:     my $buttonshide = &Apache::lonnet::EXT('resource.0.buttonshide');
                   1792:     return $buttonshide; 
1.220     raeburn  1793: }
1.184     raeburn  1794: 
1.235     raeburn  1795: sub roles_selector {
                   1796:     my ($cdom,$cnum) = @_;
1.298   ! raeburn  1797:     my $crstype = &Apache::loncommon::course_type();
1.235     raeburn  1798:     my $now = time;
1.262     raeburn  1799:     my (%courseroles,%seccount);
1.235     raeburn  1800:     my $is_cc;
                   1801:     my $role_selector;
1.298   ! raeburn  1802:     my $ccrole;
        !          1803:     if ($crstype eq 'Community') {
        !          1804:         $ccrole = 'co';
        !          1805:     } else {
        !          1806:         $ccrole = 'cc';
        !          1807:     } 
        !          1808:     if ($env{'user.role.'.$ccrole.'./'.$cdom.'/'.$cnum}) {
        !          1809:         my ($start,$end) = split(/\./,$env{'user.role.'.$ccrole.'./'.$cdom.'/'.$cnum});
1.235     raeburn  1810:         
                   1811:         if ((($start) && ($start<0)) || 
                   1812:             (($end) && ($end<$now))  ||
                   1813:             (($start) && ($now<$start))) {
                   1814:             $is_cc = 0;
                   1815:         } else {
                   1816:             $is_cc = 1;
                   1817:         }
                   1818:     }
                   1819:     if ($is_cc) {
1.264     raeburn  1820:         &get_all_courseroles($cdom,$cnum,\%courseroles,\%seccount);
1.235     raeburn  1821:     } else {
1.262     raeburn  1822:         my %gotnosection;
1.235     raeburn  1823:         foreach my $item (keys(%env)) {
1.239     raeburn  1824:             if ($item =~ m-^user\.role\.([^.]+)\./\Q$cdom\E/\Q$cnum\E/?(\w*)$-) {
1.235     raeburn  1825:                 my $role = $1;
                   1826:                 my $sec = $2;
                   1827:                 next if ($role eq 'gr');
                   1828:                 my ($start,$end) = split(/\./,$env{$item});
                   1829:                 next if (($start && $start > $now) || ($end && $end < $now));
                   1830:                 if ($sec eq '') {
1.239     raeburn  1831:                     if (!$gotnosection{$role}) {
                   1832:                         $seccount{$role} ++;
                   1833:                         $gotnosection{$role} = 1;
                   1834:                     }
1.235     raeburn  1835:                 }
                   1836:                 if (ref($courseroles{$role}) eq 'ARRAY') {
1.239     raeburn  1837:                     if ($sec ne '') {
1.264     raeburn  1838:                         if (!grep(/^\Q$sec\E$/,@{$courseroles{$role}})) {
1.239     raeburn  1839:                             push(@{$courseroles{$role}},$sec);
                   1840:                             $seccount{$role} ++;
                   1841:                         }
                   1842:                     }
                   1843:                 } else {
                   1844:                     @{$courseroles{$role}} = ();
                   1845:                     if ($sec ne '') {
                   1846:                         $seccount{$role} ++;
1.235     raeburn  1847:                         push(@{$courseroles{$role}},$sec);
                   1848:                     }
                   1849:                 }
                   1850:             }
                   1851:         }
                   1852:     }
1.286     raeburn  1853:     my $switchtext;
                   1854:     if ($crstype eq 'Community') {
                   1855:         $switchtext = &mt('Switch community role to...')
                   1856:     } else {
                   1857:         $switchtext = &mt('Switch course role to...')
                   1858:     }
1.298   ! raeburn  1859:     my @roles_order = ($ccrole,'in','ta','ep','ad','st');
1.235     raeburn  1860:     if (keys(%courseroles) > 1) {
1.239     raeburn  1861:         $role_selector = &jump_to_role($cdom,$cnum,\%seccount,\%courseroles);
1.235     raeburn  1862:         $role_selector .= '<form name="rolechooser" method="post" action="/adm/roles">
                   1863:                           <select name="switchrole" onchange="javascript:adhocRole('."'switchrole'".')">';
1.286     raeburn  1864:         $role_selector .= '<option value="">'.$switchtext.'</option>';
1.235     raeburn  1865:         foreach my $role (@roles_order) {
                   1866:             if (defined($courseroles{$role})) {
1.298   ! raeburn  1867:                 $role_selector .= "\n".'<option value="'.$role.'">'.&Apache::lonnet::plaintext($role,$crstype).'</option>'; 
1.235     raeburn  1868:             }
                   1869:         }
                   1870:         foreach my $role (sort(keys(%courseroles))) {
                   1871:             if ($role =~ /^cr/) {
                   1872:                 $role_selector .= "\n".'<option value="'.$role.'">'.&Apache::lonnet::plaintext($role).'</option>'; 
                   1873:             }
                   1874:         }
                   1875:         $role_selector .= '</select>'."\n".
                   1876:                '<input type="hidden" name="destinationurl" value="'.
1.282     amueller 1877:                &HTML::Entities::encode($ENV{'REQUEST_URI'}).'" />'."\n".
1.235     raeburn  1878:                '<input type="hidden" name="gotorole" value="1" />'."\n".
                   1879:                '<input type="hidden" name="selectrole" value="" />'."\n".
                   1880:                '<input type="hidden" name="switch" value="1" />'."\n".
                   1881:                '</form>';
                   1882:     }
                   1883:     return $role_selector;
                   1884: }
                   1885: 
1.262     raeburn  1886: sub get_all_courseroles {
                   1887:     my ($cdom,$cnum,$courseroles,$seccount) = @_;
                   1888:     unless ((ref($courseroles) eq 'HASH') && (ref($seccount) eq 'HASH')) {
                   1889:         return;
                   1890:     }
                   1891:     my ($result,$cached) = 
                   1892:         &Apache::lonnet::is_cached_new('getcourseroles',$cdom.'_'.$cnum);
                   1893:     if (defined($cached)) {
                   1894:         if (ref($result) eq 'HASH') {
                   1895:             if ((ref($result->{'roles'}) eq 'HASH') && 
                   1896:                 (ref($result->{'seccount'}) eq 'HASH')) {
                   1897:                 %{$courseroles} = %{$result->{'roles'}};
                   1898:                 %{$seccount} = %{$result->{'seccount'}};
                   1899:                 return;
                   1900:             }
                   1901:         }
                   1902:     }
                   1903:     my %gotnosection;
                   1904:     my %adv_roles =
                   1905:          &Apache::lonnet::get_course_adv_roles($env{'request.course.id'},1);
                   1906:     foreach my $role (keys(%adv_roles)) {
                   1907:         my ($urole,$usec) = split(/:/,$role);
                   1908:         if (!$gotnosection{$urole}) {
                   1909:             $seccount->{$urole} ++;
                   1910:             $gotnosection{$urole} = 1;
                   1911:         }
                   1912:         if (ref($courseroles->{$urole}) eq 'ARRAY') {
                   1913:             if ($usec ne '') {
                   1914:                 if (!grep(/^Q$usec\E$/,@{$courseroles->{$urole}})) {
                   1915:                     push(@{$courseroles->{$urole}},$usec);
                   1916:                     $seccount->{$urole} ++;
                   1917:                 }
                   1918:             }
                   1919:         } else {
                   1920:             @{$courseroles->{$urole}} = ();
                   1921:             if ($usec ne '') {
                   1922:                 $seccount->{$urole} ++;
                   1923:                 push(@{$courseroles->{$urole}},$usec);
                   1924:             }
                   1925:         }
                   1926:     }
                   1927:     my %sections_count = &Apache::loncommon::get_sections($cdom,$cnum,['st']);
                   1928:     @{$courseroles->{'st'}} = ();
                   1929:     if (keys(%sections_count) > 0) {
                   1930:         push(@{$courseroles->{'st'}},keys(%sections_count));
                   1931:         $seccount->{'st'} = scalar(keys(%sections_count)); 
                   1932:     }
                   1933:     my $rolehash = {
                   1934:                      'roles'    => $courseroles,
                   1935:                      'seccount' => $seccount,
                   1936:                    };
                   1937:     &Apache::lonnet::do_cache_new('getcourseroles',$cdom.'_'.$cnum,$rolehash);
                   1938:     return;
                   1939: }
                   1940: 
1.235     raeburn  1941: sub jump_to_role {
1.239     raeburn  1942:     my ($cdom,$cnum,$seccount,$courseroles) = @_;
                   1943:     my %lt = &Apache::lonlocal::texthash(
                   1944:                 this => 'This role has section(s) associated with it.',
                   1945:                 ente => 'Enter a specific section.',
                   1946:                 orlb => 'Enter a specific section, or leave blank for no section.',
                   1947:                 avai => 'Available sections are:',
                   1948:                 youe => 'You entered an invalid section choice:',
                   1949:                 plst => 'Please try again',
                   1950:     );
                   1951:     my $js;
                   1952:     if (ref($courseroles) eq 'HASH') {
                   1953:         $js = '    var secpick = new Array("'.$lt{'ente'}.'","'.$lt{'orlb'}.'");'."\n". 
                   1954:               '    var numsec = new Array();'."\n".
                   1955:               '    var rolesections = new Array();'."\n".
                   1956:               '    var rolenames = new Array();'."\n".
                   1957:               '    var roleseclist = new Array();'."\n";
                   1958:         my @items = keys(%{$courseroles});
                   1959:         for (my $i=0; $i<@items; $i++) {
                   1960:             $js .= '    rolenames['.$i.'] = "'.$items[$i].'";'."\n";
                   1961:             my ($secs,$secstr);
                   1962:             if (ref($courseroles->{$items[$i]}) eq 'ARRAY') {
                   1963:                 my @sections = sort { $a <=> $b } @{$courseroles->{$items[$i]}};
                   1964:                 $secs = join('","',@sections);
                   1965:                 $secstr = join(', ',@sections);
                   1966:             }
                   1967:             $js .= '    rolesections['.$i.'] = new Array("'.$secs.'");'."\n".
                   1968:                    '    roleseclist['.$i.'] = "'.$secstr.'";'."\n".
                   1969:                    '    numsec['.$i.'] = "'.$seccount->{$items[$i]}.'";'."\n";
                   1970:         }
                   1971:     }
1.273     droeschl 1972:     return <<"END";
1.235     raeburn  1973: <script type="text/javascript">
1.273     droeschl 1974: //<![CDATA[
1.235     raeburn  1975: function adhocRole(roleitem) {
1.239     raeburn  1976:     $js
1.235     raeburn  1977:     var newrole =  document.rolechooser.elements[roleitem].options[document.rolechooser.elements[roleitem].selectedIndex].value;
                   1978:     if (newrole == '') {
                   1979:         return; 
                   1980:     } 
1.239     raeburn  1981:     var fullrole = newrole+'./$cdom/$cnum';
                   1982:     var selidx = '';
                   1983:     for (var i=0; i<rolenames.length; i++) {
                   1984:         if (rolenames[i] == newrole) {
                   1985:             selidx = i;
                   1986:         }
                   1987:     }
                   1988:     var secok = 1;
                   1989:     var secchoice = '';
                   1990:     if (selidx >= 0) {
                   1991:         if (numsec[selidx] > 1) {
                   1992:             secok = 0;
                   1993:             var numrolesec = rolesections[selidx].length;
                   1994:             var msgidx = numsec[selidx] - numrolesec;
                   1995:             secchoice = prompt("$lt{'this'}\\n"+secpick[msgidx]+"\\n$lt{'avai'} "+roleseclist[selidx],"");
                   1996:             if (secchoice == '') {
                   1997:                 if (msgidx > 0) {
                   1998:                     secok = 1;
                   1999:                 }
                   2000:             } else {
                   2001:                 for (var j=0; j<rolesections[selidx].length; j++) {
                   2002:                     if (rolesections[selidx][j] == secchoice) {
                   2003:                         secok = 1;
                   2004:                     }
                   2005:                 }
                   2006:             }
                   2007:         } else {
                   2008:             if (rolesections[selidx].length == 1) {
                   2009:                 secchoice = rolesections[selidx][0];
                   2010:             }
                   2011:         }
                   2012:     }
                   2013:     if (secok == 1) {
                   2014:         if (secchoice != '') {
                   2015:             fullrole += '/'+secchoice;
                   2016:         }
                   2017:     } else {
                   2018:         document.rolechooser.elements[roleitem].selectedIndex = 0;
                   2019:         if (secchoice != null) {
                   2020:             alert("$lt{'youe'} \\""+secchoice+"\\".\\n $lt{'plst'}");
                   2021:         }
                   2022:         return;
                   2023:     }
                   2024:     if (fullrole == "$env{'request.role'}") {
1.235     raeburn  2025:         return;
                   2026:     }
                   2027:     itemid = retrieveIndex('gotorole');
                   2028:     if (itemid != -1) {
1.239     raeburn  2029:         document.rolechooser.elements[itemid].name = fullrole;
1.235     raeburn  2030:     }
1.239     raeburn  2031:     document.rolechooser.elements[roleitem].options[document.rolechooser.elements[roleitem].selectedIndex].value = fullrole;
1.235     raeburn  2032:     document.rolechooser.selectrole.value = '1';
                   2033:     document.rolechooser.submit();
                   2034:     return;
                   2035: }
                   2036: 
                   2037: function retrieveIndex(item) {
                   2038:     for (var i=0;i<document.rolechooser.elements.length;i++) {
                   2039:         if (document.rolechooser.elements[i].name == item) {
                   2040:             return i;
                   2041:         }
                   2042:     }
                   2043:     return -1;
                   2044: }
1.273     droeschl 2045: // ]]>
1.235     raeburn  2046: </script>
                   2047: END
                   2048: }
                   2049: 
                   2050: 
1.2       www      2051: # ================================================================ Main Program
                   2052: 
1.16      harris41 2053: BEGIN {
1.166     albertel 2054:     if (! defined($readdesk)) {
1.283     droeschl 2055:         {
                   2056:             my $tabfile = $Apache::lonnet::perlvar{'lonTabDir'}.'/mydesk.tab';
                   2057:             if ( CORE::open( my $config,"<$tabfile") ) {
                   2058:                 while (my $configline=<$config>) {
                   2059:                     $configline=(split(/\#/,$configline))[0];
                   2060:                     $configline=~s/^\s+//;
                   2061:                     chomp($configline);
1.209     www      2062:                     if ($configline=~/^cat\:/) {
1.283     droeschl 2063:                         my @entries=split(/\:/,$configline);
                   2064:                         $category_positions{$entries[2]}=$entries[1];
                   2065:                         $category_names{$entries[2]}=$entries[3];
                   2066:                     } elsif ($configline=~/^prim\:/) {
                   2067:                         my @entries = (split(/\:/, $configline))[1..5];
                   2068:                         push @primary_menu, \@entries;
                   2069:                     } elsif ($configline=~/^scnd\:/) {
                   2070:                         my @entries = (split(/\:/, $configline))[1..5];
                   2071:                         push @secondary_menu, \@entries; 
                   2072:                     } elsif ($configline) {
                   2073:                         push(@desklines,$configline);
                   2074:                     }
                   2075:                 }
                   2076:                 CORE::close($config);
                   2077:             }
                   2078:         }
                   2079:         $readdesk='done';
1.2       www      2080:     }
                   2081: }
1.30      www      2082: 
1.1       www      2083: 1;
                   2084: __END__
                   2085: 

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