version 1.49.2.4.4.1, 2020/04/07 20:39:03
|
version 1.68, 2017/12/30 00:16:36
|
Line 37 use Apache::lonlocal;
|
Line 37 use Apache::lonlocal;
|
use Apache::loncommon(); |
use Apache::loncommon(); |
use Apache::lonhtmlcommon(); |
use Apache::lonhtmlcommon(); |
use Apache::lonextresedit(); |
use Apache::lonextresedit(); |
|
use Apache::lonexttool(); |
|
use Apache::lonhomework(); |
use LONCAPA qw(:DEFAULT :match); |
use LONCAPA qw(:DEFAULT :match); |
|
use HTML::Entities(); |
|
|
# ================================================================ Main Handler |
# ================================================================ Main Handler |
sub wrapper { |
sub wrapper { |
Line 48 sub wrapper {
|
Line 51 sub wrapper {
|
unless ($env{'form.folderpath'}) { |
unless ($env{'form.folderpath'}) { |
$forcereg = 1; |
$forcereg = 1; |
} |
} |
|
|
my %lt = &Apache::lonlocal::texthash( |
my %lt = &Apache::lonlocal::texthash( |
'noif' => 'No iframe support.', |
'noif' => 'No iframe support.', |
'show' => 'Show content in pop-up window', |
'show' => 'Show content in pop-up window', |
Line 81 sub wrapper {
|
Line 83 sub wrapper {
|
$args->{'only_body'} = $env{'form.only_body'}; |
$args->{'only_body'} = $env{'form.only_body'}; |
} |
} |
|
|
my $startpage = &Apache::loncommon::start_page('Menu',undef,$args); |
my ($countdown,$donemsg); |
|
if (($exttool) && (&Apache::lonnet::EXT('resource.0.gradable') =~ /^yes$/i)) { |
|
$Apache::lonhomework::browse = &Apache::lonnet::allowed('bre',$url); |
|
if ($env{'form.markaccess'}) { |
|
my $symb=&Apache::lonnet::symbread($url); |
|
my @interval=&Apache::lonnet::EXT('resource.0.interval',$symb); |
|
my ($timelimit) = split(/_/,$interval[0]); |
|
my $setres = &Apache::lonnet::set_first_access($interval[1],$timelimit); |
|
if ($setres eq 'ok') { |
|
delete($env{'form.markaccess'}); |
|
} |
|
} elsif ($env{'form.LC_interval_done'} eq 'true') { |
|
my $symb=&Apache::lonnet::symbread($url); |
|
if ($symb) { |
|
(my $donebuttonresult,$donemsg) = &Apache::lonhomework::zero_timer($symb); |
|
undef($env{'form.LC_interval_done'}); |
|
undef($env{'form.LC_interval_done_proctorpass'}); |
|
} |
|
} |
|
my ($status,$result,$resource_due) = |
|
&Apache::lonexttool::gradabletool_access_check(); |
|
undef($Apache::lonhomework::browse); |
|
if ($status eq 'CAN_ANSWER') { |
|
if ($resource_due) { |
|
my $time_left = $resource_due - time(); |
|
if ($resource_due && ($time_left > 0)) { |
|
$countdown =' |
|
<script type="text/javascript"> |
|
// <![CDATA['."\n". |
|
&Apache::lonhtmlcommon::countdown().' |
|
// ]]> |
|
</script>'."\n". |
|
&Apache::lonhtmlcommon::set_due_date($resource_due); |
|
} |
|
} |
|
} else { |
|
if ($status eq 'SHOW_ANSWER') { |
|
$result = &Apache::lonexttool::display_score(). |
|
&Apache::lonfeedback::list_discussion('tool','OPEN'); |
|
} |
|
return &Apache::loncommon::start_page('Menu',undef,$args). |
|
$result. |
|
&Apache::loncommon::end_page(); |
|
} |
|
} |
|
|
|
my $startpage = &Apache::loncommon::start_page('Menu',undef,$args).$countdown.$donemsg; |
my $endpage = &Apache::loncommon::end_page(); |
my $endpage = &Apache::loncommon::end_page(); |
|
|
if (($env{'browser.mobile'}) || ($exttool eq 'window') || ($exttool eq 'tab')) { |
if (($env{'browser.mobile'}) || ($exttool eq 'window') || ($exttool eq 'tab')) { |
Line 104 sub wrapper {
|
Line 152 sub wrapper {
|
if ($linktext eq '') { |
if ($linktext eq '') { |
$linktext = &mt('Launch External Tool'); |
$linktext = &mt('Launch External Tool'); |
} |
} |
|
$url = &HTML::Entities::encode($url,'"<>&'); |
if ($exttool eq 'tab') { |
if ($exttool eq 'tab') { |
$output .= '<div>'. |
$output .= '<div>'. |
'<a href="'.$url.'" target="LCExternalToolTab" style="padding:0;clear:both;margin:0;border:0">'. |
'<a href="'.$url.'" target="LCExternalToolTab" style="padding:0;clear:both;margin:0;border:0">'. |
Line 113 sub wrapper {
|
Line 162 sub wrapper {
|
$output .= <<"ENDLINK"; |
$output .= <<"ENDLINK"; |
<script type="text/javascript"> |
<script type="text/javascript"> |
// <![CDATA[ |
// <![CDATA[ |
var windowObjectReference = null; |
var windowObjectReference = null; |
var PreviousUrl; |
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, "LCExternalToolPopUp", |
Line 140 ENDLINK
|
Line 189 ENDLINK
|
if ($explanation ne '') { |
if ($explanation ne '') { |
$output .= '<div>'.$explanation.'</div>'; |
$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 181 ENDLINK
|
Line 234 ENDLINK
|
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 200 sub handler {
|
Line 254 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); |
$linktext,$explanation,$width,$height); |
|
|
for ($url){ |
for ($url){ |
Line 210 sub handler {
|
Line 264 sub handler {
|
s|:|:|g; |
s|:|:|g; |
} |
} |
|
|
|
|
if ($url =~ /\.pdf$/i) { |
if ($url =~ /\.pdf$/i) { |
$is_pdf = 1; |
$is_pdf = 1; |
} elsif ($url =~ m{^/adm/($match_domain)/($match_courseid)/(\d+)/ext\.tool$}) { |
} elsif ($url =~ m{^/adm/($match_domain)/($match_courseid)/(\d+)/ext\.tool$}) { |
Line 221 sub handler {
|
Line 276 sub handler {
|
my %toolhash = &Apache::lonnet::get('exttool_'.$marker,['target','linktext','explanation','id','width','height'], |
my %toolhash = &Apache::lonnet::get('exttool_'.$marker,['target','linktext','explanation','id','width','height'], |
$cdom,$cnum); |
$cdom,$cnum); |
if ($toolhash{'id'}) { |
if ($toolhash{'id'}) { |
my %ltitools = &Apache::lonnet::get_domain_ltitools($cdom); |
my %ltitools = &Apache::lonnet::get_domain_lti($cdom,'consumer'); |
if (ref($ltitools{$toolhash{'id'}}) eq 'HASH') { |
if (ref($ltitools{$toolhash{'id'}}) eq 'HASH') { |
$exttoolremote = $ltitools{$toolhash{'id'}}{'url'}; |
$exttoolremote = $ltitools{$toolhash{'id'}}{'url'}; |
} |
} |
Line 231 sub handler {
|
Line 286 sub handler {
|
$width = $toolhash{'width'}; |
$width = $toolhash{'width'}; |
$height = $toolhash{'height'}; |
$height = $toolhash{'height'}; |
} elsif ($toolhash{'target'} eq 'tab') { |
} elsif ($toolhash{'target'} eq 'tab') { |
$exttool = 'tab'; |
$exttool = 'tab'; |
} |
} |
if (($exttool eq 'window') || ($exttool eq 'tab')) { |
if (($exttool eq 'window') || ($exttool eq 'tab')) { |
$linktext = $toolhash{'linktext'}; |
$linktext = $toolhash{'linktext'}; |
$explanation = $toolhash{'explanation'}; |
$explanation = $toolhash{'explanation'}; |
} elsif (($exttoolremote =~ /^http:/) && ($ENV{'SERVER_PORT'} == 443)) { |
} elsif (($exttoolremote =~ /^http:/) && ($ENV{'SERVER_PORT'} == 443)) { |
$exttool = 'tab'; |
$exttool = 'tab'; |
Line 260 sub handler {
|
Line 315 sub handler {
|
my $type = 'ext'; |
my $type = 'ext'; |
if ($exttool) { |
if ($exttool) { |
$type = 'tool'; |
$type = 'tool'; |
|
} 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)); |
$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(); |
my $title = $env{'form.title'}; |
my $title = $env{'form.title'}; |
if ($title eq '') { |
if ($title eq '') { |
$title = &mt('External Resource'); |
if ($is_ext) { |
|
$title = &mt('External Resource'); |
|
} else { |
|
$title = &mt('External Tool'); |
|
} |
} |
} |
$brcrum = |
$brcrum = |
&Apache::lonhtmlcommon::docs_breadcrumbs(undef,$crstype,undef,$title,1); |
&Apache::lonhtmlcommon::docs_breadcrumbs(undef,$crstype,undef,$title,1); |
Line 334 described at http://www.lon-capa.org.
|
Line 395 described at http://www.lon-capa.org.
|
|
|
=over |
=over |
|
|
=item wrapper($url,$brcrum,$absolute,$is_ext,$is_pdf,$exttool,$linktext,$explanation,$title,$width,$height) |
=item wrapper($url,$brcrum,$absolute,$is_ext,$is_pdf,$linktext,$explanation,$title,$width,$height) |
|
|
=over |
=over |
|
|
Line 376 true if URL is for an external resource.
|
Line 437 true if URL is for an external resource.
|
|
|
true if URL is for a PDF (based on file extension). |
true if URL is for a PDF (based on file extension). |
|
|
=item $exttool |
|
|
|
If URL is for an External Tool, will contain the target type: iframe, window or tab. |
|
|
|
=item $linktext |
|
|
|
optional. If URL is for an External Tool, and target type is window or tab, |
|
then the link text may be an option set in the course for each tool instance, |
|
or may be a default defined in the domain for all instances of the tool. |
|
|
|
=item $explanation |
|
|
|
optional. If URL is for an External Tool, and target type is window or tab, |
|
then the explanation is an option set in the course for each tool instance, |
|
or may be a default defined in the domain for all instances of the tool. |
|
|
|
=item $title |
=item $title |
|
|
optional. If wrapped item is a PDF, and $env{'browser.mobile'} |
optional. If wrapped item is a PDF, and $env{'browser.mobile'} |
Line 400 above the link, but if not provided as a
|
Line 445 above the link, but if not provided as a
|
will be used, otherwise, the filename will be displayed (unless |
will be used, otherwise, the filename will be displayed (unless |
hidden URL set for the resource). |
hidden URL set for the resource). |
|
|
=item $width |
|
|
|
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 |
|
the tool. If so, that width will be used for the window opened (via a link) |
|
to launch the external tool. |
|
|
|
=item $height |
|
|
|
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 |
|
the tool. If so, that height will be used for the window opened (via a link) |
|
to launch the external tool. |
|
|
|
=back |
=back |
|
|
Returns markup for the entire page. |
Returns markup for the entire page. |