Diff for /rat/lonwrapper.pm between versions 1.77 and 1.78

version 1.77, 2021/10/19 00:16:32 version 1.78, 2022/08/28 02:41:30
Line 39  use Apache::lonhtmlcommon(); Line 39  use Apache::lonhtmlcommon();
 use Apache::lonextresedit();  use Apache::lonextresedit();
 use Apache::lonexttool();  use Apache::lonexttool();
 use Apache::lonhomework();  use Apache::lonhomework();
   use Apache::lonnavmaps();
 use LONCAPA qw(:DEFAULT :match);  use LONCAPA qw(:DEFAULT :match);
 use HTML::Entities();  use HTML::Entities();
   use Digest::MD5();
   
 # ================================================================ Main Handler  # ================================================================ Main Handler
 sub wrapper {  sub wrapper {
     my ($r,$url,$brcrum,$absolute,$is_ext,$is_pdf,$exttool,$linktext,$explanation,      my ($r,$url,$brcrum,$absolute,$is_ext,$is_pdf,$exttool,$linktext,$explanation,
         $title,$width,$height) = @_;          $title,$width,$height,$reuse) = @_;
   
     my $forcereg;      my $forcereg;
     unless ($env{'form.folderpath'}) {      unless ($env{'form.folderpath'}) {
Line 69  sub wrapper { Line 71  sub wrapper {
         } elsif ($env{'form.anchor'} ne '') {          } elsif ($env{'form.anchor'} ne '') {
             $anchor = '#'.$env{'form.anchor'};              $anchor = '#'.$env{'form.anchor'};
         }          }
         unless (($is_pdf) && ($clientmobile)) {          if (($is_ext eq 'tab') || ($is_ext eq 'window')) {
               $uselink = 1;
           }
           unless (($is_pdf && $clientmobile) || $uselink) {
             my $hostname = $r->hostname();              my $hostname = $r->hostname();
             my $lonhost = $r->dir_config('lonHostID');              my $lonhost = $r->dir_config('lonHostID');
             my $ip = &Apache::lonnet::get_host_ip($lonhost);              my $ip = &Apache::lonnet::get_host_ip($lonhost);
Line 168  var LCresizedef = 0; Line 173  var LCresizedef = 0;
             }              }
         }          }
     }      }
     if ($clientmobile || ($exttool eq 'window') || ($exttool eq 'tab')) {      if ($clientmobile || ($exttool eq 'window') || ($exttool eq 'tab') ||
           ($is_ext eq 'tab') || ($is_ext eq 'window')) {
         my $output = $startpage;          my $output = $startpage;
         if ($is_pdf) {          if ($is_pdf) {
             $linktext = &mt('Link to PDF (for mobile devices)');              $linktext = &mt('Link to PDF (for mobile devices)');
             $output .= &create_link($url,$anchor,$title,$linktext);              $output .= &create_link($url,$anchor,$title,$linktext);
         } elsif (($exttool eq 'window') || ($exttool eq 'tab')) {          } elsif (($exttool eq 'window') || ($exttool eq 'tab') ||
                    ($is_ext eq 'tab') || ($is_ext eq 'window')) {
               my $preamble;
             if ($linktext eq '') {              if ($linktext eq '') {
                 $linktext = &mt('Launch External Tool');                  if ($exttool) {
                       $linktext = &mt('Launch External Tool');
                   } else {
                       $linktext = &mt('Link to External Resource');
                   }
               }
               if ($exttool) {
                   $url = &HTML::Entities::encode($url,'"<>&');
               } else {
                   $url = &HTML::Entities::encode($url.$anchor,'&<>"');
             }              }
             $url = &HTML::Entities::encode($url,'"<>&');              if (($exttool eq 'tab') || ($is_ext eq 'tab')) {
             if ($exttool eq 'tab') {                  my $target;
                 $output .= '<div>'.                  if ($exttool) {
                            '<a href="'.$url.'" target="LCExternalToolTab" style="padding:0;clear:both;margin:0;border:0">'.                      $target = 'LCExternalToolTab';
                   } else {
                       if ($reuse) {
                           $target = 'LCExternalResTab';
                       } else {
                           $target = '_blank';
                       }
                       if ($title ne '') {
                           $preamble = '<span style="font-weight:bold;">'.$title.'</span><br />';
                       }
                   }
                   $output .= '<div>'.$preamble.
                              '<a href="'.$url.'" target="'.$target.'" style="padding:0;clear:both;margin:0;border:0">'.
                            $linktext.'</a>'.                             $linktext.'</a>'.
                            '</div>';                             '</div>';
             } else {              } else {
                   my ($target,$extlinkimg);
                   if ($exttool) {
                       $target = 'LCExternalToolPopUp';
                   } else {
                       $target = 'LCExternalResPopUp';
                       if ($title ne '') {
                           $preamble = '<span style="font-weight:bold;">'.$title.'</span><br />';
                       }
                       $extlinkimg = '<img src="'.&Apache::loncommon::lonhttpdurl($r->dir_config('lonIconsURL').'/externallink.gif').'" width="19" height="18" border="0" />';
                       unless ($reuse) {
                           my $resid;
                           if ($env{'request.course.id'}) {
                               unless ($env{'form.folderpath'} =~ /^supplemental/) {
                                   my $symb=&Apache::lonnet::symbread($r->uri);
                                   if ($symb) {
                                       my $navmap = Apache::lonnavmaps::navmap->new();
                                       if (ref($navmap)) {
                                           my $res = $navmap->getBySymb($symb);
                                           if (ref($res)) {
                                               $resid = $res->id;
                                               $resid =~ s/\./_/g;
                                           }
                                       }
                                   }
                               }
                           }
                           if ($resid eq '') {
                               $resid = substr(Digest::MD5::md5_hex(Digest::MD5::md5_hex(time(). {}. rand(). $$)), 0, 8);
                           }
                           &js_escape(\$resid);
                           $target .= $resid;
                       }
                   }
                 $output .= <<"ENDLINK";                  $output .= <<"ENDLINK";
 <script type="text/javascript">  <script type="text/javascript">
 // <![CDATA[  // <![CDATA[
Line 192  var PreviousUrl; Line 254  var PreviousUrl;
   
 function openSinglePopup(strUrl) {  function openSinglePopup(strUrl) {
     if (windowObjectReference == null || windowObjectReference.closed) {      if (windowObjectReference == null || windowObjectReference.closed) {
         windowObjectReference = window.open(strUrl, "LCExternalToolPopUp",          windowObjectReference = window.open(strUrl, "$target",
                                             "height=$height,width=$width,scrollbars=yes,resizable=yes,status=yes,menubar=no,location=no'");                                              "height=$height,width=$width,scrollbars=yes,resizable=yes,status=yes,menubar=no,location=no'");
     } else if(PreviousUrl != strUrl) {      } else if(PreviousUrl != strUrl) {
         windowObjectReference = window.open(strUrl, "LCExternalToolPopUp",          windowObjectReference = window.open(strUrl, "$target",
                                             "height=$height,width=$width,scrollbars=yes,resizable=yes,status=yes,menubar=no,location=no'");                                              "height=$height,width=$width,scrollbars=yes,resizable=yes,status=yes,menubar=no,location=no'");
         windowObjectReference.focus();          windowObjectReference.focus();
     } else {      } else {
Line 205  function openSinglePopup(strUrl) { Line 267  function openSinglePopup(strUrl) {
 }  }
 // ]]>  // ]]>
 </script>  </script>
 <div>  <div>$preamble
 <a href="$url" target="LCExternalToolPopUp" onclick="openSinglePopup(this.href); return false;">  <a href="$url" target="$target" onclick="openSinglePopup(this.href); return false;">
 $linktext</a>  $linktext$extlinkimg</a>
 </div>  </div>
 ENDLINK  ENDLINK
             }              }
             if ($explanation ne '') {              if ($exttool) {
                 $output .= '<div>'.$explanation.'</div>';                  if ($explanation ne '') {
             }                      $output .= '<div>'.$explanation.'</div>';
             if (&Apache::lonnet::EXT('resource.0.gradable')) {                  }
                 $output .= &Apache::lonfeedback::list_discussion('tool','OPEN');                  if (&Apache::lonnet::EXT('resource.0.gradable')) {
                       $output .= &Apache::lonfeedback::list_discussion('tool','OPEN');
                   }
             }              }
         } else {          } else {
             if ($uselink) {              if ($uselink) {
Line 320  sub handler { Line 384  sub handler {
   
     my $url = $r->uri;      my $url = $r->uri;
     my ($is_ext,$brcrum,$absolute,$is_pdf,$exttool,$cdom,$cnum,$hostname,      my ($is_ext,$brcrum,$absolute,$is_pdf,$exttool,$cdom,$cnum,$hostname,
         $linktext,$explanation,$width,$height);          $linktext,$explanation,$width,$height,$reuse);
   
     for ($url){      for ($url){
         s|^/adm/wrapper||;          s|^/adm/wrapper||;
Line 331  sub handler { Line 395  sub handler {
   
     if ($url =~ /\.pdf$/i) {      if ($url =~ /\.pdf$/i) {
         $is_pdf = 1;          $is_pdf = 1;
       } elsif (($is_ext) && ($env{'request.course.id'})) {
           if ($env{'course.'.$env{'request.course.id'}.'.extresource'}) {
               (my $selected,$reuse,$width,$height) = split(/:/,$env{'course.'.$env{'request.course.id'}.'.extresource'});
               if ($selected eq 'tab') {
                   $is_ext = 'tab';
                   $width = '';
                   $height = '';
               } elsif ($selected eq 'window') {
                   $is_ext = 'window';
                   unless ($width =~ /^\d+$/) {
                       $width = '';
                   }
                   unless ($height =~ /^\d+$/) {
                       $height = '';
                   } 
               } else {
                   $width = '';
                   $height = '';
                   $reuse = '';
               }
           }
     } elsif ($url =~ m{^/adm/($match_domain)/($match_courseid)/(\d+)/ext\.tool$}) {      } elsif ($url =~ m{^/adm/($match_domain)/($match_courseid)/(\d+)/ext\.tool$}) {
         $cdom = $1;          $cdom = $1;
         $cnum = $2;          $cnum = $2;
Line 432  sub handler { Line 517  sub handler {
         }          }
   
         $r->print( wrapper($r,$url,$brcrum,$absolute,$is_ext,$is_pdf,$exttool,          $r->print( wrapper($r,$url,$brcrum,$absolute,$is_ext,$is_pdf,$exttool,
                            $linktext,$explanation,undef,$width,$height) );                             $linktext,$explanation,undef,$width,$height,$reuse) );
   
     } # not just the menu      } # not just the menu
           
Line 459  described at http://www.lon-capa.org. Line 544  described at http://www.lon-capa.org.
   
 =over  =over
   
 =item wrapper($r,$url,$brcrum,$absolute,$is_ext,$is_pdf,$exttool,$linktext,$explanation,$title,$width,$height)  =item wrapper($r,$url,$brcrum,$absolute,$is_ext,$is_pdf,$exttool,$linktext,$explanation,$title,$width,$height,$reuse)
   
 =over  =over
   
Line 502  in Firefox 23 and later, when serving fr Line 587  in Firefox 23 and later, when serving fr
   
 =item $is_ext  =item $is_ext
   
 true if URL is for an external resource.  true if URL is for an external resource. Default true value
   is 1 (display in iframe, unless $uselink is true). 
   If external resource is to be displayed in a tab,
   value of $is_ext will be tab, if to be displayed in a pop-up window,
   value of $is_ext will be window.  
   
 =item $is_pdf  =item $is_pdf
   
Line 537  hidden URL set for the resource). Line 626  hidden URL set for the resource).
 optional. If URL is for an External Tool, and target type is window,  optional. If URL is for an External Tool, and target type is window,
 then a default width may have been defined in the domain for all instances of   then a default width may have been defined in the domain for all instances of 
 the tool.  If so, that width will be used for the window opened (via a link)  the tool.  If so, that width will be used for the window opened (via a link)
 to launch the external tool.  to launch the external tool. If the URL is for an External Resource, and 
   $is_ext is window, then a default width (px) may have been defined in the current
   course for all external resource instances.
   
 =item $height  =item $height
   
 optional. If URL is for an External Tool, and target type is window,  optional. If URL is for an External Tool, and target type is window,
 then a default height may have been defined in the domain for all instances of   then a default height may have been defined in the domain for all instances of 
 the tool.  If so, that height will be used for the window opened (via a link)  the tool.  If so, that height will be used for the window opened (via a link)
 to launch the external tool.  to launch the external tool.  If the URL is for an External Resource, and 
   $is_ext is window, then a default height (px) may have been defined in the current
   course for all external resource instances.
   
   =item $reuse
   
   optional. If the URL is for an External Resource, and $is_ext is tab or window,
   then $reuse will be true if the same tab or window is to be reused for display
   of all external resource instances in a a course.
   
 =back  =back
   

Removed from v.1.77  
changed lines
  Added in v.1.78


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