Diff for /rat/lonwrapper.pm between versions 1.38 and 1.46

version 1.38, 2010/03/03 21:33:20 version 1.46, 2013/10/22 23:13:54
Line 33  use strict; Line 33  use strict;
 use Apache::Constants qw(:common);  use Apache::Constants qw(:common);
 use Apache::lonenc();  use Apache::lonenc();
 use Apache::lonnet;  use Apache::lonnet;
   use Apache::lonlocal;
   use Apache::loncommon();
   use Apache::lonhtmlcommon();
   use Apache::lonextresedit();
   
 # ================================================================ Main Handler  # ================================================================ Main Handler
 sub wrapper {  sub wrapper {
     my $url = shift;      my ($url,$brcrum,$absolute,$is_ext) = @_;
   
     my $startpage =  Apache::loncommon::start_page('Menu',undef,      my $forcereg;
   { 'force_register' =>1, 'bgcolor'   => '#FFFFFF',}) ;      unless ($env{'form.folderpath'}) {
     my $endpage =  Apache::loncommon::end_page();          $forcereg = 1;
       }
     # javascript will position the iframe if window was resized (or zoomed)  
     return <<ENDFRAME;      my %lt = &Apache::lonlocal::texthash(
     $startpage                                            'noif' => 'No iframe support.',
     <script type="text/javascript">                                            'show' => 'Show content in pop-up window',
     \$(document).ready( function() {                                          );
         \$(window).unbind('resize').resize(function(){  
             var header = \$('#LC_head_subbox')[0] ?  \$('#LC_head_subbox') :  \$('#LC_breadcrumbs');      my $noiframe = &Apache::loncommon::modal_link($url,$lt{'show'},500,400);
             var pos = header.height() + header.position().top + 5;      my $args = {'bgcolor' => '#FFFFFF'};
             \$('.iframecontainer').css('top', pos);      if ($forcereg) {
           $args->{'force_register'} = $forcereg;
       }
       if (ref($brcrum) eq 'ARRAY') {
           $args->{'bread_crumbs'} = $brcrum;
       }
       if ($absolute) {
           $args->{'use_absolute'} = $absolute; 
       }
   
       my $startpage = &Apache::loncommon::start_page('Menu',undef,$args);
       my $endpage = &Apache::loncommon::end_page();
   
       if ($env{'browser.mobile'}) {
           return <<ENDFRAME;
           $startpage
           <div style="overflow:scroll; -webkit-overflow-scrolling:touch;">
           <iframe src="$url" height="100%" width="100%" frameborder="0">
               $lt{'noif'} $noiframe
           </iframe>
           </div>
           $endpage
   ENDFRAME
       } else {
           my $script = &Apache::lonhtmlcommon::scripttag(<<SCRIPT);
           \$(document).ready( function() {
               \$(window).unbind('resize').resize(function(){
                   var header;
                   var offset = 5;
                   var height = 0;
                   var hdrtop = 0;
                   if (\$('div.LC_head_subbox:first').length) {
                       header = \$('div.LC_head_subbox:first');
                       offset = 9;
                   } else {
                       if (\$('#LC_breadcrumbs').length) {
                           header = \$('#LC_breadcrumbs');
                       }
                   }
                   if (header.length) {
                       height = header.height();
                       hdrtop = header.position().top;
                   }
                   var pos = height + hdrtop + offset;
                   \$('.LC_iframecontainer').css('top', pos);
               });
         });          });
     });          window.onload = function(){  \$(window).trigger('resize') };
     window.onload = function(){  \$(window).trigger('resize') };  SCRIPT
     </script>          # javascript will position the iframe if window was resized (or zoomed)
           return <<ENDFRAME;
     <div class="LC_iframecontainer">          $startpage
         <iframe src="$url">No iframe support!</iframe>          $script
     </div>          <div class="LC_iframecontainer">
     $endpage              <iframe src="$url">$lt{'noif'} $noiframe</iframe>
           </div>
           $endpage
 ENDFRAME  ENDFRAME
       }
 }  }
   
 sub handler {  sub handler {
Line 71  sub handler { Line 123  sub handler {
     return OK if $r->header_only;      return OK if $r->header_only;
   
     my $url = $r->uri;      my $url = $r->uri;
     my $is_ext;      my ($is_ext,$brcrum,$absolute);
   
     for ($url){      for ($url){
         s|^/adm/wrapper||;          s|^/adm/wrapper||;
Line 80  sub handler { Line 132  sub handler {
         s|&colon;|:|g;                        s|&colon;|:|g;              
     }      }
   
       if ($is_ext) {
           my $hostname = $r->hostname();
           my $lonhost = &Apache::lonnet::host_from_dns($hostname);
           if ($lonhost) {
               my $actual = &Apache::lonnet::absolute_url($hostname);
               my $expected = $Apache::lonnet::protocol{$lonhost}.'://'.$hostname; 
               unless ($actual eq $expected) {
                   $absolute = $expected;
               }
           }
           &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
               ['forceedit','register','folderpath','symb','idx','title']);
           if (($env{'form.forceedit'}) &&
               (&Apache::lonnet::allowed('mdc',$env{'request.course.id'})) &&
               (($env{'form.folderpath'} =~ /^supplemental/) ||
                ($env{'form.symb'} =~ /^uploaded/))) {
               $r->print(
                   &Apache::lonextresedit::display_editor($url,$env{'form.folderpath'},
                                                          $env{'form.symb'},
                                                          $env{'form.idx'}));
               return OK;
           } elsif ($env{'form.folderpath'} =~ /^supplemental/) {
               my $crstype = &Apache::loncommon::course_type();
               my $title = $env{'form.title'};
               if ($title eq '') {
                   $title = &mt('External Resource');
               }
               $brcrum =
                   &Apache::lonhtmlcommon::docs_breadcrumbs(undef,$crstype,undef,$title,1);
           }
       }
   
 #  #
 # Actual URL  # Actual URL
 #  #
     if ($url=~/\.(problem|exam|quiz|assess|survey|form|library)$/) {      if ($url=~/$LONCAPA::assess_re/) {
 #  #
 # This is uploaded homework  # This is uploaded homework
 #  #
Line 95  sub handler { Line 179  sub handler {
 #  #
         if ($is_ext) {          if ($is_ext) {
             $ENV{'QUERY_STRING'} =~ s/(^|\&)symb=[^\&]*/$1/;              $ENV{'QUERY_STRING'} =~ s/(^|\&)symb=[^\&]*/$1/;
             $ENV{'QUERY_STRING'} =~ s/\&$//;                $ENV{'QUERY_STRING'} =~ s/\&$//;
         }          }
   
         unless ($ENV{'QUERY_STRING'} eq '') {          unless ($ENV{'QUERY_STRING'} eq '') {
Line 105  sub handler { Line 189  sub handler {
         # encrypt url if not external          # encrypt url if not external
         &Apache::lonenc::check_encrypt(\$url) if $url !~ /^https?\:/ ;          &Apache::lonenc::check_encrypt(\$url) if $url !~ /^https?\:/ ;
   
         $r->print( wrapper($url) );          $r->print( wrapper($url,$brcrum,$absolute,$is_ext) );
   
     } # not just the menu      } # not just the menu
           
Line 132  described at http://www.lon-capa.org. Line 216  described at http://www.lon-capa.org.
   
 =over  =over
   
 =item wrapper($url)  =item wrapper($url,$brcrum,$absolute,$is_ext)
   
 Wraps $url in an iframe and generates a page for it.  =over
 Returns markup for the entire page.  
   
 =item handler()  =item $url
   
 =back  url to display by including in an iframe within a
   LON-CAPA page which has a standard LON-CAPA inline menu.
   
 =cut  =item $brcrum
   
   breadcrumbs for unregistered urls
   (i.e., external resources in Supplemental Content).
   
   =item $absolute
   
   contains protocol (http or https) followed by
   the hostname, if menu items in the standard LON-CAPA
   interface created by the call to loncommon::start_page()
   within &wrapper() need to use absolute URLs rather than
   relative URLs.
   
   That will be the case where an external resource has been 
   served from port 80, when the server customarily serves
   requests using Apache/SSL (i.e., port 443). mod_rewrite 
   is used to switch requests for external resources 
   from https:// to http:// where the the URL of the remote site 
   specified in the resource itself is http://.
   
   This is done to avoid default mixed content blocking
   in Firefox 23 and later, when serving from Apache/SSL.
   
   =item $is_ext
   
   true if URL is for an external resource.
   
   =back
   
   Returns markup for the entire page.
   
   =item handler()
   
   =back
   
   =cut
   

Removed from v.1.38  
changed lines
  Added in v.1.46


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