--- loncom/interface/lonsyllabus.pm 2002/08/27 16:49:20 1.4 +++ loncom/interface/lonsyllabus.pm 2002/08/27 19:59:08 1.5 @@ -1,7 +1,7 @@ # The LearningOnline Network # Syllabus # -# $Id: lonsyllabus.pm,v 1.4 2002/08/27 16:49:20 www Exp $ +# $Id: lonsyllabus.pm,v 1.5 2002/08/27 19:59:08 www Exp $ # # Copyright Michigan State University Board of Trustees # @@ -32,6 +32,7 @@ use strict; use Apache::Constants qw(:common); use Apache::loncommon; use Apache::lonnet; +use Apache::lontexconvert; sub handler { my $r = shift; @@ -39,7 +40,6 @@ sub handler { $r->send_http_header; return OK if $r->header_only; - # ------------------------------------------------------------ Print the screen $r->print(< @@ -53,31 +53,82 @@ ENDDOCUMENT $r->print('No syllabus available'); return OK; } +# --------------------------------------------------------- The syllabus fields + my %syllabusfields=( + 'aaa_instructorinfo' => 'Instructor Information', + 'bbb_description' => 'Course Description', + 'ccc_prereq' => 'Prerequisites', + 'ddd_officehours' => 'Office Hours', + 'eee_helproom' => 'Helproom Hours', + 'fff_examinfo' => 'Exam Information', + 'ggg_grading' => 'Grading Information', + 'hhh_readings' => 'Readings'); + + # ------------------------------------- There is such a course, get environment my %courseenv=&Apache::lonnet::dump('environment',$cdom,$cnum); $r->print(&Apache::loncommon::bodytag("Syllabus",'','','',$cdom)); $r->print('

'.$courseenv{'description'}.'

'. $Apache::lonnet::domaindescription{$cdom}.'

'); my %syllabus=&Apache::lonnet::dump('syllabus',$cdom,$cnum); + my $allowed=0; # This handler might be called anonymously ... # ----------------------------------------------------- Only if not public call if ($ENV{'user.environment'}) { # does this user have privileges to post, etc? - my $allowed=0; if ($ENV{'request.course.id'}) { $allowed=&Apache::lonnet::allowed('srm',$ENV{'request.course.id'}); } + if (($allowed) && ($ENV{'form.storesyl'})) { + foreach (keys %syllabusfields) { + my $field=$ENV{'form.'.$_}; + $field=~s/\s+$//s; + $field=~s/\/\>\;/g; + if ($field) { + $syllabus{$_}=$field; + } else { + delete $syllabus{$_}; + } + } + $syllabus{'uploaded.domain'}=$ENV{'user.domain'}; + $syllabus{'uploaded.name'}=$ENV{'user.name'}; + $syllabus{'uploaded.lastmodified'}=time; + &Apache::lonnet::put('syllabus',\%syllabus,$cdom,$cnum); + } } # ---------------------------------------------------------------- Get syllabus - if ($ENV{'uploaded.lastmodified'}) { + if (($syllabus{'uploaded.lastmodified'}) || ($allowed)) { $r->print('
Uploaded:'. &Apache::loncommon::plainname($syllabus{'uploaded.name'}, $syllabus{'uploaded.domain'}). '
Last updated'. localtime($syllabus{'uploaded.lastmodified'}). - '
'); - $r->print('
'.$syllabus{'description'}.'
'); + '

'); + if ($allowed) { + $r->print('

'); + } + foreach (sort keys %syllabusfields) { + if (($syllabus{$_}) || ($allowed)) { + my $message=$syllabus{$_}; + $message=~s/\n/\
/g; + $message + =~s/(http\:\/\/[^\s]+)/\\$1\<\/tt\>\<\/a\>/g; + $message=&Apache::lontexconvert::msgtexconverted($message); + $r->print('

'.$syllabusfields{$_}.'

'. + $message.'
'); + if ($allowed) { + $r->print('
'); + } + } + } + if ($allowed) { + $r->print(''); + } + $r->print('

'); } else { $r->print('

No syllabus information provided.

'); }