--- loncom/interface/lonmenu.pm 2003/02/20 22:04:18 1.44 +++ loncom/interface/lonmenu.pm 2003/04/04 21:21:51 1.56 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # Routines to control the menu # -# $Id: lonmenu.pm,v 1.44 2003/02/20 22:04:18 www Exp $ +# $Id: lonmenu.pm,v 1.56 2003/04/04 21:21:51 www Exp $ # # Copyright Michigan State University Board of Trustees # @@ -25,21 +25,27 @@ # # http://www.lon-capa.org/ # -# (TeX Conversion Module # -# 05/29/00,05/30 Gerd Kortemeyer) +# There are two parameters controlling the action of this module: +# +# browser.interface - if this is 'textual', it overrides the second parameter +# and goes to screen reader PDA mode +# +# environment.remote - if this is 'on', the routines controll the remote +# control, otherwise they render the main window controls; ignored it +# browser.interface is 'textual' # -# 10/05,05/28,05/30,06/01,06/08,06/09,07/04,08/07 Gerd Kortemeyer -# 02/15/02 Matthew Hall package Apache::lonmenu; use strict; use Apache::lonnet; use Apache::Constants qw(:common); +use Apache::lonhtmlcommon(); use Apache::loncommon; use Apache::File; use vars qw(@desklines $readdesk); +my @inlineremote; # ============================= This gets called at the top of the body section @@ -47,19 +53,53 @@ sub menubuttons { my $forcereg=shift; my $target =shift; my $registration=shift; - unless ($ENV{'browser.interface'} eq 'textual') { return ''; } + my $navmaps=''; + my $escurl=&Apache::lonnet::escape($ENV{'REQUEST_URI'}); + my $escsymb=&Apache::lonnet::escape($ENV{'request.symb'}); + if ($ENV{'browser.interface'} eq 'textual') { # Textual display only - my $output=(<Navigate Contents +ENDNAV + } + my $output=(< // BEGIN LON-CAPA Internal -Main Menu
+Main Menu +$navmaps
ENDMAINMENU - if ($registration) { $output.=&innerregister($forcereg,$target); } - return $output."
"; + if ($registration) { $output.=&innerregister($forcereg,$target); } + return $output."
"; + } elsif ($ENV{'environment.remote'} eq 'off') { +# Remote Control is switched off + if ($ENV{'request.course.id'}) { + $navmaps=(<Navigate Contents +ENDNAVREM + } + my $output=(< +// BEGIN LON-CAPA Internal + +
+Main Menu +$navmaps +Launch Remote Control +
+ +ENDINLINEMENU + if ($registration) { $output.=&innerregister($forcereg,$target); } + return $output."
"; + } else { + return ''; + } } # ====================================== This gets called in the header section @@ -70,12 +110,13 @@ sub registerurl { my $result = ''; if ($target eq 'edit') { - $result .="\n"; } if (($ENV{'browser.interface'} eq 'textual') || + ($ENV{'environment.remote'} eq 'off') || ((($ENV{'request.publicaccess'}) || (!&Apache::lonnet::is_on_map($ENV{'REQUEST_URI'}))) && (!$forcereg))) { @@ -98,7 +139,14 @@ sub innerregister { $Apache::lonxml::registered=1; - my $textual=($ENV{'browser.interface'} eq 'textual'); + my $textinter=($ENV{'browser.interface'} eq 'textual'); + my $noremote=($ENV{'environment.remote'} eq 'off'); + + my $textual=($textinter || $noremote); + + @inlineremote=(); + undef @inlineremote; + my $reopen=&Apache::lonmenu::reopenmenu(); my $newmail=''; @@ -214,6 +262,8 @@ ENDMENUITEMS # Registered, textual output my $utility=&utilityfunctions(); my $form=&serverform(); + my $inlinebuttons= + join('',map { (defined($_)?$_:'') } @inlineremote); $result =(< // BEGIN LON-CAPA Internal @@ -221,9 +271,7 @@ $utility $timesync $newmail -$buttons -$hwkadd -$editbutton +$inlinebuttons $form