--- loncom/interface/lonsyllabus.pm 2017/02/18 19:05:51 1.141 +++ loncom/interface/lonsyllabus.pm 2017/02/18 23:39:16 1.142 @@ -1,7 +1,7 @@ # The LearningOnline Network # Syllabus # -# $Id: lonsyllabus.pm,v 1.141 2017/02/18 19:05:51 raeburn Exp $ +# $Id: lonsyllabus.pm,v 1.142 2017/02/18 23:39:16 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -309,6 +309,9 @@ sub handler { my $protocol = $Apache::lonnet::protocol{$homeserver}; $protocol = 'http' if ($protocol ne 'https'); my $link = $protocol.'://'.&Apache::lonnet::hostname($homeserver).$r->uri; + if (($protocol eq 'https') && ($external =~ m{^http://})) { + $link .= '?usehttp=1'; + } $r->print('
' .'' .'' @@ -627,11 +630,16 @@ function toggleEditor(pick) { var regexp = $urlregexp; -function extUrlPreview(caller) { +function extUrlPreview(caller,protocol) { if (document.getElementById(caller)) { var url = document.getElementById(caller).value; if (regexp.test(url)) { - openMyModal(url,500,400,'yes'); + var http_regex = /^http\:\/\//gi; + if ((protocol == 'https') && (http_regex.test(url))) { + window.open(url,"syllabuspreview","height=400,width=500,scrollbars=1,resizable=1,menubar=0,location=1"); + } else { + openMyModal(url,500,400,'yes'); + } } else { alert("$invurl"); } @@ -819,6 +827,7 @@ sub chooser { $checked{'templatebox'} = $check; $display{'templatebox'} = 'block'; } + my $protocol = ($ENV{'SERVER_PORT'} == 443?'https':'http'); my $output = '
'."\n". @@ -831,7 +840,7 @@ sub chooser { $output .= '
'."\n". '
'."\n". '
'.$lt{'chourl'}.''."\n". - ''.$lt{'pr'}.' '."\n". + ''.$lt{'pr'}.' '."\n". ''."\n". ' '."\n". '
'."\n". @@ -1132,6 +1141,10 @@ sub save_changes { (ref($courseenv) eq 'HASH')) { return ($earlyout,$uploaded,$external,$minimal,$output); } + my ($was_ext,$is_ext,$putres); + if ($external) { + $was_ext = $external; + } if (($env{'form.deleteuploaded_file'}) || ($env{'form.deleteuploaded_minimal'})) { my %storehash; if (($env{'form.choice'} eq 'file') && @@ -1144,7 +1157,7 @@ sub save_changes { &Apache::lonnet::delenv('course.'.$env{'request.course.id'}.'.externalsyllabus'); $storehash{'uploadedsyllabus'} = ''; $storehash{'externalsyllabus'} = ''; - my $putres = &Apache::lonnet::put('environment',\%storehash,$cdom,$cnum); + $putres = &Apache::lonnet::put('environment',\%storehash,$cdom,$cnum); undef($uploaded); undef($external); } elsif (($env{'form.choice'} eq 'minimal') && @@ -1164,7 +1177,7 @@ sub save_changes { &Apache::lonnet::delenv('course.'.$env{'request.course.id'}.'.minimalsyllabus'); $storehash{'externalsyllabus'} = ''; $storehash{'minimalsyllabus'} = ''; - my $putres = &Apache::lonnet::put('environment',\%storehash,$cdom,$cnum); + $putres = &Apache::lonnet::put('environment',\%storehash,$cdom,$cnum); undef($external); undef($minimal); } @@ -1254,7 +1267,7 @@ sub save_changes { $syllabus->{'uploaded.domain'}=$env{'user.domain'}; $syllabus->{'uploaded.name'}=$env{'user.name'}; $syllabus->{'uploaded.lastmodified'} = $now; - my $putres = &Apache::lonnet::put('syllabus',$syllabus,$cdom,$cnum); + $putres = &Apache::lonnet::put('syllabus',$syllabus,$cdom,$cnum); if ($putres eq 'ok') { ($uploaded,$minimal,$external) = &update_syllabus_env($cdom,$cnum,$courseenv,$env{'form.choice'},$uploaded, @@ -1279,7 +1292,7 @@ sub save_changes { } else { $external=$env{'form.externalsyllabus'}; $external =~ s/(`)//g; - my $putres = + $putres = &Apache::lonnet::put('environment',{externalsyllabus=>$external}, $cdom,$cnum); if ($putres eq 'ok') { @@ -1296,6 +1309,7 @@ sub save_changes { ''; } } + $is_ext = $external; } else { $output = '
'. &mt('External URL not saved -- invalid URL.'). @@ -1341,7 +1355,7 @@ sub save_changes { } else { $storehash{'externalsyllabus'} = '', } - my $putres = + $putres = &Apache::lonnet::put('environment',\%storehash,$cdom,$cnum); if ($putres eq 'ok') { &Apache::lonnet::make_public_indefinitely($url); @@ -1406,6 +1420,22 @@ sub save_changes { $output = $result.&return_to_editor($cdom,$cnum); $earlyout = 1; } + if ($putres eq 'ok') { + if ((($is_ext) && ($is_ext ne $was_ext)) || ($was_ext)) { + my $chome = &Apache::lonnet::homeserver($cnum,$cdom); + unless ($chome eq 'no_host') { + my %crsinfo = &Apache::lonnet::courseiddump($cdom,'.',1,'.','.',$cnum,undef,undef,'.'); + if (ref($crsinfo{$cdom.'_'.$cnum}) eq 'HASH') { + if ($external =~ m{^http://}) { + $crsinfo{$cdom.'_'.$cnum}{'extsyllplain'} = 1; + } elsif ($crsinfo{$cdom.'_'.$cnum}{'extsyllplain'}) { + delete($crsinfo{$cdom.'_'.$cnum}{'extsyllplain'}); + } + &Apache::lonnet::courseidput($cdom,\%crsinfo,$chome,'notime'); + } + } + } + } return ($earlyout,$uploaded,$external,$minimal,$output); }