version 1.51, 2016/02/22 03:36:52
|
version 1.66, 2017/12/18 23:23:14
|
Line 38 use Apache::loncommon();
|
Line 38 use Apache::loncommon();
|
use Apache::lonhtmlcommon(); |
use Apache::lonhtmlcommon(); |
use Apache::lonextresedit(); |
use Apache::lonextresedit(); |
use Apache::lonexttool(); |
use Apache::lonexttool(); |
use LONCAPA qw(:DEFAULT :match);; |
use LONCAPA qw(:DEFAULT :match); |
|
use HTML::Entities(); |
|
|
# ================================================================ Main Handler |
# ================================================================ Main Handler |
sub wrapper { |
sub wrapper { |
my ($url,$brcrum,$absolute,$is_ext,$is_pdf,$exttool,$title) = @_; |
my ($url,$brcrum,$absolute,$is_ext,$is_pdf,$exttool,$linktext,$explanation, |
|
$title,$width,$height) = @_; |
|
|
my $forcereg; |
my $forcereg; |
unless ($env{'form.folderpath'}) { |
unless ($env{'form.folderpath'}) { |
Line 54 sub wrapper {
|
Line 56 sub wrapper {
|
); |
); |
|
|
my $anchor; |
my $anchor; |
if (($is_ext) && ($env{'form.symb'})) { |
if ($is_ext) { |
(undef,undef,my $res) = &Apache::lonnet::decode_symb($env{'form.symb'}); |
if ($env{'form.symb'}) { |
if ($res =~ /(\#.+)$/) { |
(undef,undef,my $res) = &Apache::lonnet::decode_symb($env{'form.symb'}); |
$anchor = $1; |
if ($res =~ /(#[^#]+)$/) { |
|
$anchor = $1; |
|
} |
|
} elsif ($env{'form.anchor'} ne '') { |
|
$anchor = '#'.$env{'form.anchor'}; |
} |
} |
} |
} |
|
|
Line 70 sub wrapper {
|
Line 76 sub wrapper {
|
$args->{'bread_crumbs'} = $brcrum; |
$args->{'bread_crumbs'} = $brcrum; |
} |
} |
if ($absolute) { |
if ($absolute) { |
$args->{'use_absolute'} = $absolute; |
$args->{'use_absolute'} = $absolute; |
|
} |
|
if ($env{'form.only_body'}) { |
|
$args->{'only_body'} = $env{'form.only_body'}; |
} |
} |
|
|
my $startpage = &Apache::loncommon::start_page('Menu',undef,$args); |
my $startpage = &Apache::loncommon::start_page('Menu',undef,$args); |
my $endpage = &Apache::loncommon::end_page(); |
my $endpage = &Apache::loncommon::end_page(); |
|
|
if (($env{'browser.mobile'}) || ($exttool eq 'window')) { |
if (($exttool) && (&Apache::lonnet::EXT('resource.0.gradable'))) { |
|
my $resource_due = &Apache::lonhomework::due_date(0, $env{'request.symb'}); |
|
if ($resource_due) { |
|
my $time_left = $resource_due - time(); |
|
if ($resource_due && ($time_left > 0)) { |
|
$startpage .=' |
|
<script type="text/javascript"> |
|
// <![CDATA['."\n". |
|
&Apache::lonhtmlcommon::countdown().' |
|
// ]]> |
|
</script>'."\n". |
|
&Apache::lonhtmlcommon::set_due_date($resource_due); |
|
} |
|
} |
|
} |
|
|
|
if (($env{'browser.mobile'}) || ($exttool eq 'window') || ($exttool eq 'tab')) { |
my $output = $startpage; |
my $output = $startpage; |
if ($is_pdf) { |
if ($is_pdf) { |
if ($title eq '') { |
if ($title eq '') { |
Line 92 sub wrapper {
|
Line 117 sub wrapper {
|
$output .= $title.'<br />'; |
$output .= $title.'<br />'; |
} |
} |
$output .= '<a href="'.$url.'">'.&mt('Link to PDF (for mobile devices)').'</a>'; |
$output .= '<a href="'.$url.'">'.&mt('Link to PDF (for mobile devices)').'</a>'; |
} elsif ($exttool eq 'window') { |
} elsif (($exttool eq 'window') || ($exttool eq 'tab')) { |
$output .= '<div>'. |
if ($linktext eq '') { |
'<a href="'.$url.'" target="LC_LTI" style="padding:0;clear:both;margin:0;border:0">'. |
$linktext = &mt('Launch External Tool'); |
&mt('Launch External Tool').'</a>'. |
} |
'</div>'; |
$url = &HTML::Entities::encode($url,'"<>&'); |
|
if ($exttool eq 'tab') { |
|
$output .= '<div>'. |
|
'<a href="'.$url.'" target="LCExternalToolTab" style="padding:0;clear:both;margin:0;border:0">'. |
|
$linktext.'</a>'. |
|
'</div>'; |
|
} else { |
|
$output .= <<"ENDLINK"; |
|
<script type="text/javascript"> |
|
// <![CDATA[ |
|
var windowObjectReference = null; |
|
var PreviousUrl; |
|
|
|
function openSinglePopup(strUrl) { |
|
if (windowObjectReference == null || windowObjectReference.closed) { |
|
windowObjectReference = window.open(strUrl, "LCExternalToolPopUp", |
|
"height=$height,width=$width,scrollbars=yes,resizable=yes,status=yes,menubar=no,location=no'"); |
|
} else if(PreviousUrl != strUrl) { |
|
windowObjectReference = window.open(strUrl, "LCExternalToolPopUp", |
|
"height=$height,width=$width,scrollbars=yes,resizable=yes,status=yes,menubar=no,location=no'"); |
|
windowObjectReference.focus(); |
|
} else { |
|
windowObjectReference.focus(); |
|
}; |
|
PreviousUrl = strUrl; |
|
} |
|
// ]]> |
|
</script> |
|
<div> |
|
<a href="$url" target="LCExternalToolPopUp" onclick="openSinglePopup(this.href); return false;"> |
|
$linktext</a> |
|
</div> |
|
ENDLINK |
|
} |
|
if ($explanation ne '') { |
|
$output .= '<div>'.$explanation.'</div>'; |
|
} |
|
if (&Apache::lonnet::EXT('resource.0.gradable')) { |
|
$output .= &Apache::lonfeedback::list_discussion('tool','OPEN'); |
|
} |
} else { |
} else { |
|
my $dest = &HTML::Entities::encode($url.$anchor,'&<>"'); |
$output .= '<div style="overflow:scroll; -webkit-overflow-scrolling:touch;">'."\n". |
$output .= '<div style="overflow:scroll; -webkit-overflow-scrolling:touch;">'."\n". |
'<iframe src="'.$url.$anchor.'" height="100%" width="100%" frameborder="0">'."\n". |
'<iframe src="'.$dest.'" height="100%" width="100%" frameborder="0">'."\n". |
"$lt{'noif'} $noiframe\n". |
"$lt{'noif'} $noiframe\n". |
"</iframe>\n". |
"</iframe>\n". |
"</div>\n"; |
"</div>\n"; |
Line 107 sub wrapper {
|
Line 172 sub wrapper {
|
$output .= $endpage; |
$output .= $endpage; |
return $output; |
return $output; |
} else { |
} else { |
|
my $offset = 5; |
|
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['inhibitmenu']); |
|
if ($env{'form.inhibitmenu'} eq 'yes') { |
|
$offset = 0; |
|
} |
my $script = &Apache::lonhtmlcommon::scripttag(<<SCRIPT); |
my $script = &Apache::lonhtmlcommon::scripttag(<<SCRIPT); |
\$(document).ready( function() { |
\$(document).ready( function() { |
\$(window).unbind('resize').resize(function(){ |
\$(window).unbind('resize').resize(function(){ |
var header; |
var header = null; |
var offset = 5; |
var offset = $offset; |
var height = 0; |
var height = 0; |
var hdrtop = 0; |
var hdrtop = 0; |
if (\$('div.LC_head_subbox:first').length) { |
if (\$('div.LC_head_subbox:first').length) { |
Line 122 sub wrapper {
|
Line 192 sub wrapper {
|
header = \$('#LC_breadcrumbs'); |
header = \$('#LC_breadcrumbs'); |
} |
} |
} |
} |
if (header.length) { |
if (header != null && header.length) { |
height = header.height(); |
height = header.height(); |
hdrtop = header.position().top; |
hdrtop = header.position().top; |
} |
} |
Line 133 sub wrapper {
|
Line 203 sub wrapper {
|
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) |
# javascript will position the iframe if window was resized (or zoomed) |
|
my $dest = &HTML::Entities::encode($url.$anchor,'&<>"'); |
return <<ENDFRAME; |
return <<ENDFRAME; |
$startpage |
$startpage |
$script |
$script |
<div class="LC_iframecontainer"> |
<div class="LC_iframecontainer"> |
<iframe src="$url$anchor">$lt{'noif'} $noiframe</iframe> |
<iframe src="$dest">$lt{'noif'} $noiframe</iframe> |
</div> |
</div> |
$endpage |
$endpage |
ENDFRAME |
ENDFRAME |
Line 152 sub handler {
|
Line 223 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,$brcrum,$absolute,$is_pdf,$exttool,$cdom,$cnum); |
my ($is_ext,$brcrum,$absolute,$is_pdf,$exttool,$cdom,$cnum,$hostname, |
|
$linktext,$explanation,$width,$height); |
|
|
for ($url){ |
for ($url){ |
s|^/adm/wrapper||; |
s|^/adm/wrapper||; |
Line 164 sub handler {
|
Line 236 sub handler {
|
|
|
if ($url =~ /\.pdf$/i) { |
if ($url =~ /\.pdf$/i) { |
$is_pdf = 1; |
$is_pdf = 1; |
} elsif ($url =~ m{^/adm/($match_domain)/($match_courseid)/(\d+)/exttools?$}) { |
} elsif ($url =~ m{^/adm/($match_domain)/($match_courseid)/(\d+)/ext\.tool$}) { |
$cdom = $1; |
$cdom = $1; |
$cnum = $2; |
$cnum = $2; |
my $marker = $3; |
my $marker = $3; |
$exttool = 'iframe'; |
$exttool = 'iframe'; |
my %toolhash = &Apache::lonnet::get('exttool_'.$marker,['target'],$cdom,$cnum); |
my $exttoolremote; |
|
my %toolhash = &Apache::lonnet::get('exttool_'.$marker,['target','linktext','explanation','id','width','height'], |
|
$cdom,$cnum); |
|
if ($toolhash{'id'}) { |
|
my %ltitools = &Apache::lonnet::get_domain_lti($cdom,'consumer'); |
|
if (ref($ltitools{$toolhash{'id'}}) eq 'HASH') { |
|
$exttoolremote = $ltitools{$toolhash{'id'}}{'url'}; |
|
} |
|
} |
if ($toolhash{'target'} eq 'window') { |
if ($toolhash{'target'} eq 'window') { |
$exttool = 'window'; |
$exttool = 'window'; |
|
$width = $toolhash{'width'}; |
|
$height = $toolhash{'height'}; |
|
} elsif ($toolhash{'target'} eq 'tab') { |
|
$exttool = 'tab'; |
|
} |
|
if (($exttool eq 'window') || ($exttool eq 'tab')) { |
|
$linktext = $toolhash{'linktext'}; |
|
$explanation = $toolhash{'explanation'}; |
|
} elsif (($exttoolremote =~ /^http:/) && ($ENV{'SERVER_PORT'} == 443)) { |
|
$exttool = 'tab'; |
} |
} |
} |
} |
if (($is_ext) || ($exttool)) { |
if (($is_ext) || ($exttool)) { |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, |
['forceedit','register','folderpath','symb','idx','title']); |
['forceedit','register','folderpath','symb','idx','title','anchor']); |
if (($env{'form.forceedit'}) && |
if (($env{'form.forceedit'}) && |
(&Apache::lonnet::allowed('mdc',$env{'request.course.id'})) && |
(&Apache::lonnet::allowed('mdc',$env{'request.course.id'})) && |
(($env{'form.folderpath'} =~ /^supplemental/) || |
(($env{'form.folderpath'} =~ /^supplemental/) || |
($env{'form.symb'} =~ /^uploaded/))) { |
($env{'form.symb'} =~ /^uploaded/))) { |
|
if ($env{'form.symb'}) { |
|
(undef,undef,my $res) = &Apache::lonnet::decode_symb($env{'form.symb'}); |
|
if ($res =~ /(#[^#]+)$/) { |
|
$url .= $1; |
|
} |
|
} elsif ($env{'form.folderpath'} =~ /^supplemental/) { |
|
if ($env{'form.anchor'} ne '') { |
|
$url .= '#'.$env{'form.anchor'}; |
|
} |
|
} |
my $type = 'ext'; |
my $type = 'ext'; |
my %ltitools; |
|
if ($exttool) { |
if ($exttool) { |
$type = 'tool'; |
$type = 'tool'; |
%ltitools = &Apache::lonnet::get_domain_ltitools($cdom); |
} elsif (($url =~ /^http:/) && ($ENV{'SERVER_PORT'} == 443)) { |
|
$hostname = $r->hostname(); |
} |
} |
$r->print( |
$r->print( |
&Apache::lonextresedit::display_editor($url,$env{'form.folderpath'}, |
&Apache::lonextresedit::display_editor($url,$env{'form.folderpath'}, |
$env{'form.symb'}, |
$env{'form.symb'}, |
$env{'form.idx'},$type,$cdom, |
$env{'form.idx'},$type,$cdom, |
$cnum,\%ltitools)); |
$cnum,$hostname)); |
return OK; |
return OK; |
} elsif ($env{'form.folderpath'} =~ /^supplemental/) { |
} elsif ($env{'form.folderpath'} =~ /^supplemental/) { |
my $crstype = &Apache::loncommon::course_type(); |
my $crstype = &Apache::loncommon::course_type(); |
Line 211 sub handler {
|
Line 311 sub handler {
|
# |
# |
# Actual URL |
# Actual URL |
# |
# |
if ($url=~/$LONCAPA::assess_re/) { |
if (($url=~/$LONCAPA::assess_re/) && (!$exttool)) { |
# |
# |
# This is uploaded homework |
# This is uploaded homework |
# |
# |
Line 232 sub handler {
|
Line 332 sub handler {
|
} |
} |
|
|
# encrypt url if not external |
# encrypt url if not external |
unless ($is_ext || $exttool) { |
unless ($is_ext) { |
&Apache::lonenc::check_encrypt(\$url); |
&Apache::lonenc::check_encrypt(\$url); |
} |
} |
|
|
$r->print( wrapper($url,$brcrum,$absolute,$is_ext,$is_pdf,$exttool) ); |
$r->print( wrapper($url,$brcrum,$absolute,$is_ext,$is_pdf,$exttool, |
|
$linktext,$explanation,undef,$width,$height) ); |
|
|
} # not just the menu |
} # not just the menu |
|
|
Line 263 described at http://www.lon-capa.org.
|
Line 364 described at http://www.lon-capa.org.
|
|
|
=over |
=over |
|
|
=item wrapper($url,$brcrum,$absolute,$is_ext,$is_pdf,$title)) |
=item wrapper($url,$brcrum,$absolute,$is_ext,$is_pdf,$linktext,$explanation,$title,$width,$height) |
|
|
=over |
=over |
|
|