Diff for /rat/lonwrapper.pm between versions 1.12 and 1.16

version 1.12, 2003/04/15 03:53:03 version 1.16, 2004/09/18 16:32:17
Line 45  use Apache::lonmenu; Line 45  use Apache::lonmenu;
   
 sub handler {  sub handler {
   my $r=shift;    my $r=shift;
   $r->content_type('text/html');    &Apache::loncommon::content_type($r,'text/html');
   $r->send_http_header;    $r->send_http_header;
   
   return OK if $r->header_only;    return OK if $r->header_only;
Line 54  sub handler { Line 54  sub handler {
                                           ['wrapperdisplay']);                                            ['wrapperdisplay']);
   my $orgurl=$r->uri;    my $orgurl=$r->uri;
   my $url=$orgurl;    my $url=$orgurl;
     $orgurl.=(($orgurl=~/\?/)?'&':'?').$ENV{'QUERY_STRING'};
     $orgurl.=(($orgurl=~/\?/)?'&':'?').'wrapperdisplay=menu';
   $url=~s/^\/adm\/wrapper//;    $url=~s/^\/adm\/wrapper//;
   $url=~s/^\/ext\//http\:\/\//;    $url=~s/^\/ext\//http\:\/\//;
     $url=~s|:|:|g;
   if ($ENV{'form.wrapperdisplay'} eq 'menu') {    if ($ENV{'form.wrapperdisplay'} eq 'menu') {
 #  #
 # Producing the menu buttons  # Producing the menu buttons
Line 66  sub handler { Line 69  sub handler {
 #  #
 # Actual URL  # Actual URL
 #  #
       if ($url=~/^\/uploaded\//) {        if ($url=~/\.(problem|exam|quiz|assess|survey|form|library)$/) {
   $url=&Apache::lonnet::tokenwrapper($url);  #
       }  # This is uploaded homework
       $url.=(($url=~/\?/)?'&':'?').$ENV{'QUERY_STRING'}; #reappend the query arguments  #
       my $events='onLoad="'.&Apache::lonmenu::loadevents.            $ENV{'request.state'}='uploaded';
   '" onUnload="'.&Apache::lonmenu::unloadevents.'"';            &Apache::lonhomework::renderpage($r,$url);
       my $script=&Apache::lonmenu::registerurl(1,undef);        } else {
   #
   # This is not homework
   #
     $url.=(($url=~/\?/)?'&':'?').$ENV{'QUERY_STRING'}; 
                                                    # reappend the query arguments
     my $events='onLoad="'.&Apache::lonmenu::loadevents.
         '" onUnload="'.&Apache::lonmenu::unloadevents.'"';
     my $script=&Apache::lonmenu::registerurl(1,undef);
   
       if ($ENV{'browser.interface'} eq 'textual') {    if ($ENV{'browser.interface'} eq 'textual') {
 #  #
 # ssi-based rendering for text-based interface  # ssi-based rendering for text-based interface
 #  #
   $r->print('<html><head>'.        $r->print('<html><head>'.
                 &Apache::lonmenu::registerurl(1).   &Apache::lonmenu::registerurl(1).
                 '</head><body bgcolor="#FFFFFF">'.   '</head><body bgcolor="#FFFFFF">'.
                 &Apache::lonmenu::menubuttons(1).   &Apache::lonmenu::menubuttons(1).
                 &Apache::lonnet::ssi_body($url).'</body></html>');   &Apache::lonnet::ssi_body($url).'</body></html>');
       } elsif ($ENV{'environment.remote'} eq 'off') {    } elsif ($ENV{'environment.remote'} eq 'off') {
 #  #
 # This is inline remote  # This is inline remote
 #   # 
   $r->print(<<ENDDOCUMENTINL);        $r->print(<<ENDDOCUMENTINL);
 <html>  <html>
 <head>  <head>
 $script  $script
 </head>  </head>
 <frameset rows="180,*" border=0 $events>  <frameset rows="180,*" border=0 $events>
 <frame src="$orgurl?wrapperdisplay=menu">  <frame src="$orgurl">
 <frame src="$url">  <frame src="$url">
 </frameset>  </frameset>
 </html>  </html>
 ENDDOCUMENTINL  ENDDOCUMENTINL
       } else {            } else {
 #  #
 # frame-based rendering for graphical interface  # frame-based rendering for graphical interface
 #  #
Line 113  $script Line 124  $script
 </frameset>  </frameset>
 </html>  </html>
 ENDDOCUMENT  ENDDOCUMENT
       }            }
   }        } # not homework
     } # not just the menu
   return OK;    return OK;
 }  } # handler
   
 1;  1;
 __END__  __END__

Removed from v.1.12  
changed lines
  Added in v.1.16


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