--- loncom/interface/lonextresedit.pm 2025/06/14 20:48:54 1.8.2.4.4.5
+++ loncom/interface/lonextresedit.pm 2023/05/22 21:10:55 1.31
@@ -1,7 +1,7 @@
# The LearningOnline Network
# Documents
#
-# $Id: lonextresedit.pm,v 1.8.2.4.4.5 2025/06/14 20:48:54 raeburn Exp $
+# $Id: lonextresedit.pm,v 1.31 2023/05/22 21:10:55 raeburn Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -109,7 +109,7 @@ sub handler {
%ltitools = (
dom => \%domtools,
crs => \%crstools,
- );
+ );
}
my $js = &Apache::lonhtmlcommon::scripttag(&extedit_javascript());
my $pathitem = '';
}
$formname = 'edit'.$type.'_'.$residx;
- $fieldsetid = 'upload'.$type.$residx;
+ $fieldsetid = 'external'.$type.$residx;
$urlid = $type.'url_'.$residx;
map { $toolattr{$_} .= '_'.$residx; } (keys(%toolattr));
$srcclass = ' class="LC_nobreak"';
@@ -525,7 +472,7 @@ sub extedit_form {
if ($type eq 'tool') {
$link = $lt{'et'};
}
- $link = ''.$link.''.$helpitem;
+ $link = ''.$link.''.$helpitem;
if ($type eq 'tool') {
$legend = $lt{'te'};
} else {
@@ -552,7 +499,6 @@ sub extedit_form {
$urlelem = '';
} else {
my $class = 'LC_nobreak';
- my ($nocrsdest,$fixeddest,$fixeddelay,$showprovider,$provider,$scheme);
if ($residx) {
$class = 'LC_docs_ext_edit LC_nobreak';
if ($orig_url =~ m{^/adm/$cdom/$cnum/(\d+)/ext\.tool$}) {
@@ -562,14 +508,19 @@ sub extedit_form {
if ($toolhash{'id'} =~/^c(\d+)$/) {
$tool = $1;
$tooltype = 'crs';
+ if (ref($ltitools) eq 'HASH') {
+ if (ref($ltitools->{'crs'}) eq 'HASH') {
+ $ltihash = $ltitools->{'crs'}->{$tool};
+ }
+ }
} elsif ($toolhash{'id'} =~/^\d+$/) {
$tooltype = 'dom';
$tool = $toolhash{'id'};
- }
- if (($tool ne '') && ($tooltype ne '') && (ref($ltitools) eq 'HASH')) {
- if (ref($ltitools->{$tooltype}) eq 'HASH') {
- $ltihash = $ltitools->{$tooltype}->{$tool};
- }
+ if (ref($ltitools) eq 'HASH') {
+ if (ref($ltitools->{'dom'}) eq 'HASH') {
+ $ltihash = $ltitools->{'dom'}->{$tool};
+ }
+ }
}
if (($tool ne '') && (ref($ltihash) eq 'HASH')) {
my $tooltitle = $ltihash->{'title'};
@@ -578,10 +529,10 @@ sub extedit_form {
if ($icon) {
$image = '';
}
- if ($ltihash->{'url'} =~ m{^https?\://}) {
- ($scheme,$provider,$path) = ($ltihash->{'url'} =~ m{^(https?\://)([^/]+)(|/.+)$});
+ if ($ltihash->{'url'} =~ m{://}) {
+ (my $prot,my $host,$providerurl) = ($ltihash->{'url'} =~ m{^([^/]+)://([^/]+)(|/.+)$});
} else {
- $path = $ltihash->{'url'};
+ $providerurl = $ltihash->{'url'};
}
$tooltarget = $toolhash{'target'};
if ($tooltarget eq 'window') {
@@ -615,7 +566,6 @@ sub extedit_form {
if ($ltihash->{'crsconf'}->{'append'}) {
$crsappend = $toolhash{'crsappend'};
$appendstyle = 'display:inline';
- $showprovider = 1;
}
if ($ltihash->{'crsconf'}->{'target'}) {
$dispdivstyle = 'display:block';
@@ -626,52 +576,9 @@ sub extedit_form {
if ($ltihash->{'crsconf'}->{'explanation'}) {
$explanationstyle = 'padding:0;display:inline';
}
- if ($ltihash->{'crsconf'}->{'returnurl'}) {
- $returnurl = $toolhash{'returnurl'};
- $returnurlstyle = 'display:inline';
- $backtourl = $toolhash{'backtourl'};
- if ($returnurl eq 'none') {
- $chknoreturn = ' checked="checked"';
- $customreturn = 'hidden';
- } elsif (($returnurl eq 'custom') && ($backtourl ne '')) {
- $chkreturncust = ' checked="checked"';
- $customreturn = 'text';
- } else {
- $chkreturndef = ' checked="checked"';
- $customreturn = 'hidden';
- }
- }
- if ($ltihash->{'crsconf'}->{'desturl'}) {
- $desturl = $toolhash{'desturl'};
- $desturlstyle = 'display:inline';
- $delay = $toolhash{'delay'};
- $showprovider = 1;
- if ($desturl ne '') {
- $desturlinfostyle = 'display:inline';
- $chkdest = ' checked="checked"';
- $chknodest = '';
- } else {
- $desturlinfostyle = 'display:none';
- $chkdest = '';
- $chknodest = ' checked="checked"';
- }
- } else {
- $nocrsdest = 1;
- }
}
$toolelem = ''.$image.' '.$tooltitle.'
';
$gradablestyle = 'display:inline';
- if (($ltihash->{'desturl'}) && ($nocrsdest) && ($ltihash->{'defdest'} =~ m{^(https?\://|/)})) {
- $fixeddest = $ltihash->{'defdest'};
- if ($ltihash->{'defdelay'} =~ /^\d+\.?\d*$/) {
- $fixeddelay = $ltihash->{'defdelay'};
- }
- $desturlfixedstyle = 'display:inline-block';
- $showprovider = 1;
- }
- if (($showprovider) && ($provider ne '')) {
- $providerstyle = 'display:inline-block';
- }
}
}
} else {
@@ -724,7 +631,7 @@ sub extedit_form {
$exttypeofftext = &mt('No external tools defined in the domain are available for selection.');
} elsif (!$numcrstools && $numdomtools) {
$defcheck{'dom'} = ' checked="checked"';
- $subdivstyle = 'display:block';
+ $subdivstyle = 'display:none';
$exttypeonsty = 'display:block';
my $firstoption = '';
$seloptions = &ordered_tooloptions($ltitools->{'dom'});
@@ -751,49 +658,9 @@ sub extedit_form {
$crslabel = $env{'course.'.$cdom.'_'.$cnum.'.internal.coursecode'};
$crstitle = $env{'course.'.$cdom.'_'.$cnum.'.description'};
$crsappend = '';
- $returnurl = '';
- $backtourl = '';
- $customreturn = 'hidden';
$chknogrd = ' checked="checked"';
- $chknoreturn = '';
- $chkreturndef = ' checked="checked"';
- $chkreturncust = '';
- $chknodest = ' checked="checked"';
- $chkdest = '';
- }
- my $onclickreturl = ' onclick="updateReturnUrl('."this.form,'$toolattr{'customreturnurl'}','$toolattr{'returnurldiv'}','exttoolreturnurl'".');"';
- my $onclickdest = ' onclick="updateDestUrl('."this.form,'$toolattr{'desturlinfodiv'}','$toolattr{'desturldiv'}','exttooldest'".');"';
- $toolelem.= '