[LON-CAPA-cvs] cvs: loncom /interface lonsyllabus.pm
www
lon-capa-cvs@mail.lon-capa.org
Mon, 10 Feb 2003 14:44:36 -0000
www Mon Feb 10 09:44:36 2003 EDT
Modified files:
/loncom/interface lonsyllabus.pm
Log:
Bug #1019 - can now incorporate internal and external URLs.
Index: loncom/interface/lonsyllabus.pm
diff -u loncom/interface/lonsyllabus.pm:1.8 loncom/interface/lonsyllabus.pm:1.9
--- loncom/interface/lonsyllabus.pm:1.8 Fri Sep 13 15:40:48 2002
+++ loncom/interface/lonsyllabus.pm Mon Feb 10 09:44:36 2003
@@ -1,7 +1,7 @@
# The LearningOnline Network
# Syllabus
#
-# $Id: lonsyllabus.pm,v 1.8 2002/09/13 19:40:48 www Exp $
+# $Id: lonsyllabus.pm,v 1.9 2003/02/10 14:44:36 www Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -69,7 +69,8 @@
'hhh_readings' => 'Readings',
'iii_coursepack' => 'Coursepack',
'jjj_weblinks' => 'Web Links',
- 'kkk_textbook' => 'Textbook');
+ 'kkk_textbook' => 'Textbook',
+ 'lll_includeurl' => 'URLs To Include in Syllabus');
# --------------------------------------------------------------- Force Student
&Apache::loncommon::get_unprocessed_cgi
@@ -106,6 +107,33 @@
$field=~s/\</\<\;/g;
$field=~s/\>/\>\;/g;
$syllabus{$_}=$field;
+ if ($_ eq 'lll_includeurl') { # clean up included URLs
+ my $field='';
+ foreach (split(/\n/,$syllabus{$_})) {
+ my $url=$_;
+# get rid of leading and trailing spaces
+ $url=~s/^\s+//;
+ $url=~s/\s+$//;
+ if ($url=~/^http\:\/\/([^\/]+)\/(.+)$/) {
+ my $remainder=$2;
+# remove the hostname from internal URLs
+ foreach (keys %Apache::lonnet::hostname) {
+ if ($1=~/$Apache::lonnet::hostname{$_}/i) {
+ $url=$remainder;
+ }
+ }
+ }
+# norm internal URLs
+ unless ($url=~/^http\:/) {
+ $url=&Apache::lonnet::clutter($url);
+ }
+# re-assemble field
+ if ($url) {
+ $field.=$url."\n";
+ }
+ }
+ $syllabus{$_}=$field;
+ }
}
$syllabus{'uploaded.domain'}=$ENV{'user.domain'};
$syllabus{'uploaded.name'}=$ENV{'user.name'};
@@ -132,12 +160,42 @@
foreach (sort keys %syllabusfields) {
if (($syllabus{$_}) || ($allowed)) {
my $message=$syllabus{$_};
- $message=~s/\n/\<br \/\>/g;
- $message
+ if ($_ eq 'lll_includeurl') { # this is the "included" field
+ my $urls=$message;
+ $message='';
+ foreach my $filelink (split(/\n/,$urls)) {
+ my $output='';
+# embed style?
+ my ($curfext)=($filelink=~/\.([^\.]+)$/);
+ my $embstyle=&Apache::loncommon::fileembstyle($curfext);
+ if ($embstyle eq 'ssi') {
+# make ssi call and remove everything but the body contents
+ $output=&Apache::lonnet::ssi($filelink);
+ $output=~s/^.*\<body[^\>]*\>//si;
+ $output=~s/\<\/body\s*\>.*$//si;
+ } elsif ($embstyle eq 'img') {
+# embed as an image
+ $output='<img src="'.$filelink.'" />';
+ }
+ $message.='<p>'.$output.'</p>';
+ }
+ if ($allowed) {
+ $r->print('<h3>'.$syllabusfields{$_}.
+ '</h3>URLs provided will be included into the page output.'.
+ '<br />Format:<br /><pre>'.
+ "http://www.foo.org/foo.html\n/res/foo/author/foo.html\n</pre>".
+ '<p><a href="'.$r->uri.'?forcestudent=1">Show Student View</a></p>');
+ } else {
+ $r->print($message);
+ }
+ } else {
+ $message=~s/\n/\<br \/\>/g;
+ $message
=~s/(http\:\/\/[^\s]+)/\<a href=\"$1\"\>\<tt\>$1\<\/tt\>\<\/a\>/g;
- $message=&Apache::lontexconvert::msgtexconverted($message);
- $r->print('<h3>'.$syllabusfields{$_}.'</h3><blockquote>'.
+ $message=&Apache::lontexconvert::msgtexconverted($message);
+ $r->print('<h3>'.$syllabusfields{$_}.'</h3><blockquote>'.
$message.'</blockquote>');
+ }
if ($allowed) {
$r->print('<br /><textarea cols="80" rows="6" name="'.$_.'">'.
$syllabus{$_}.