--- loncom/interface/Attic/lonremote.pm 2003/04/02 21:23:04 1.2 +++ loncom/interface/Attic/lonremote.pm 2004/07/15 19:59:46 1.13 @@ -1,7 +1,7 @@ # The LearningOnline Network # User Authentication Module # -# $Id: lonremote.pm,v 1.2 2003/04/02 21:23:04 www Exp $ +# $Id: lonremote.pm,v 1.13 2004/07/15 19:59:46 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -25,13 +25,7 @@ # # http://www.lon-capa.org/ # -# 5/21/99,5/22,5/25,5/26,5/27,5/29,6/2,6/11,6/14,6/15 -# 16/11,12/16, -# 1/14,2/24,2/28,2/29,3/7,5/29,5/30,5/31,6/1,6/5,6/29, -# 7/1,7/10,10/2,10/5,10/9,10/26,10/30,11/10, -# 05/28,05/29 Gerd Kortemeyer -# 07/28,08/03 Gerd Kortemeyer -# 8/20 Gerd Kortemeyer +### package Apache::lonremote; @@ -40,38 +34,56 @@ use Apache::Constants qw(:common); use Apache::loncommon(); use Apache::lonnet(); use Apache::lonmenu(); +use Apache::lonlocal; sub launchremote { my ($r,$lowerurl)=@_; + &Apache::lonnet::put('environment',{'remote' => 'on'}); + &Apache::lonnet::appenv('environment.remote' => 'on'); # -------------------------------------------------------- Menu script and info -# my $windowinfo=&Apache::lonmenu::open($clientos); -# my $startupremote=&Apache::lonmenu::startupremote($lowerurl); -# my $setflags=&Apache::lonmenu::setflags(); -# my $maincall=&Apache::lonmenu::maincall(); + my $windowinfo=&Apache::lonmenu::open($ENV{'browser.os'}); + my $startupremote=&Apache::lonmenu::startupremote($lowerurl); + my $setflags=&Apache::lonmenu::setflags(); + my $maincall=&Apache::lonmenu::maincall(); my $bodytag=&Apache::loncommon::bodytag('Launch Remote Control'); + my $message=&mt("Launching of the Remote Control menu will fail if pop-up window filters are active. To use the Remote Control, disable the filter for this site."); $r->print(< The LearningOnline Network with CAPA +$startupremote $bodytag +$setflags +$windowinfo +$maincall +$message ENDLAUNCH - &Apache::lonnet::put('environment',{'remote' => 'on'}); - &Apache::lonnet::appenv('environment.remote' => 'on'); } sub collapseremote { my ($r,$lowerurl)=@_; # -------------------------------------------------------- Menu script and info my $bodytag=&Apache::loncommon::bodytag('Collapse Remote Control'); + my $windowinfo=&Apache::lonmenu::close(); +# my $switch=''; + my $message='

'.&mt("The external menu (Remote Control) has been disabled, and you will be working with the smaller inline menu.\nYou may have either closed the Remote Control window, or it was blocked by a pop-up window filter in your browser.\nTo use the Remote Control, disable the filter for this site, and re-launch the Remote Control from the inline menu.").'

'; + if ($ENV{'request.role'} =~ /^(ca|au)\./) { + $message.='

'.&mt(" Authoring roles require use of the remote control. In order to Author you will need to disable popups filtering for this site.").'

'; + } $r->print(< The LearningOnline Network with CAPA $bodytag +$windowinfo +

+$message +

+Continue ENDCOLLAPSE @@ -81,7 +93,8 @@ ENDCOLLAPSE sub handler { my $r = shift; - &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['action']); + &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, + ['action','url']); unless ($ENV{'form.action'}) { if ($ENV{'environment.remote'} eq 'on') { $ENV{'form.action'}='collapse'; @@ -89,10 +102,18 @@ sub handler { $ENV{'form.action'}='launch'; } } + + my $lowerurl=$ENV{'form.url'}; + unless ($lowerurl) { $lowerurl='/adm/menu'; } + + &Apache::loncommon::content_type($r,'text/html'); + $r->send_http_header; + return OK if $r->header_only; + if ($ENV{'form.action'} eq 'launch') { - &launchremote($r); + &launchremote($r,$lowerurl); } else { - &collapseremote($r); + &collapseremote($r,$lowerurl); } return OK; }