--- loncom/interface/londocs.pm 2002/07/31 14:56:36 1.4 +++ loncom/interface/londocs.pm 2002/08/21 17:18:08 1.9 @@ -1,7 +1,7 @@ # The LearningOnline Network # Documents # -# $Id: londocs.pm,v 1.4 2002/07/31 14:56:36 www Exp $ +# $Id: londocs.pm,v 1.9 2002/08/21 17:18:08 www Exp $ # # Copyright Michigan State University Board of Trustees # @@ -32,82 +32,169 @@ use strict; use Apache::Constants qw(:common); use Apache::lonnet; use Apache::loncommon; +use Apache::lonratedt; +use Apache::lonratsrv; +my $iconpath; + +# Mapread read maps into lonratedt::global arrays +# @links and @resources, determines status +# sets @order - pointer to resources in right order +# sets @resources - array with the resources with correct idx +# + +sub mapread { + my ($coursenum,$coursedom,$map)=@_; + return + &Apache::lonratedt::mapread('/uploaded/'.$coursedom.'/'.$coursenum.'/'. + $map); +} + +sub storemap { + my ($coursenum,$coursedom,$map)=@_; + return + &Apache::lonratedt::storemap('/uploaded/'.$coursedom.'/'.$coursenum.'/'. + $map); +} + +sub editor { + my ($r,$coursenum,$coursedom,$folder,$allowed)=@_; + my ($errtext,$fatal)= + &mapread($coursenum,$coursedom,$folder.'.sequence'); + if ($fatal) { + $r->print('

'.$errtext.'

'); + } else { +# ------------------------------------------------------------ Process commands + if ($allowed) { + if ($ENV{'form.cmd'}) { + + } + } +# ---------------------------------------------------------------- Print screen + } +} + +# --------------------------------------------------------------- An entry line + +sub entryline { + my ($index,$title,$url,$folder,$allowed)=@_; + my $line=''; +# Edit commands + if ($allowed) { + $line.=(< + + +
+UP
+DOWN
+Remove +END + } +# URL + $line.='View'; +# Title + $title=&Apache::lonnet::unescape($title); + if ($title=~ + /^(\d+)\_\_\_\&\&\&\_\_\_(\w+)\_\_\_\&\&\&\_\_\_(\w+)\_\_\_\&\&\&\_\_\_(.*)$/ + ) { $title=''.localtime($1).' '.$2.' at '.$3.':
'. + &Apache::lontexconvert::msgtexconverted($4); + } + $line.='$title'; + $line.=''; + return $line; +} + +# ================================================================ Main Handler sub handler { my $r = shift; $r->content_type('text/html'); $r->send_http_header; return OK if $r->header_only; +# is this a standard course? + + &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['folder']); + my $standard=($ENV{'request.course.uri'}=~/^\/uploaded\//); + my $forcestandard=($ENV{'form.folder'}=~/^default_/); + my $forcesupplement=($ENV{'form.folder'}=~/^supplement_/); + # does this user have privileges to post, etc? my $allowed=&Apache::lonnet::allowed('srm',$ENV{'request.course.id'}); - + my $script=''; if ($allowed) { - &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, - ['remove']) + &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['cmd']); + $script=&Apache::lonratedt::editscript('docs'); } # get course data my $coursenum=$ENV{'course.'.$ENV{'request.course.id'}.'.num'}; my $coursedom=$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}; +# graphics settings -# upload a file + $iconpath = $r->dir_config('lonIconsURL') . "/"; + +# upload a file, if present if (($ENV{'form.uploaddoc.filename'}) && ($allowed)) { - my $id=time.'_'.$ENV{'user.name'}.'_'.$ENV{'user.domain'}; - my $url=&Apache::lonnet::userfileupload('uploaddoc'); - if ($url=~/^error\:/) { - } else { - my $comment=$ENV{'form.comment'}; - $comment=~s/\/\>\;/g; - &Apache::lonnet::put('coursedocs', - { $id.'.url' => $url, - $id.'.comment' => $comment }, - $coursedom,$coursenum); - } - } - -# delete a file - if ($ENV{'form.remove'}=~/$ENV{'user.name'}\_$ENV{'user.domain'}$/) { - my $id=$ENV{'form.remove'}; - &Apache::lonnet::del('coursedocs', - [$id.'.url',$id.'.comment'], - $coursedom,$coursenum); - } +# this is for a course, not a user, so set coursedoc flag +# probably the only place in the system where this should be "1" + my $url=&Apache::lonnet::userfileupload('uploaddoc',1); + my $comment=$ENV{'form.comment'}; + $comment=~s/\/\>\;/g; + } # print screen $r->print(< The LearningOnline Network with CAPA + - -

Course Documents

ENDDOCUMENT -# ------------------------------------------------------- Print headers to docs - my %currentdocs=&Apache::lonnet::dump('coursedocs',$coursedom,$coursenum); - foreach (sort keys (%currentdocs)) { - if ($_=~/(\d+)\_(\w+)\_(\w+)\.url/) { - $r->print('
'.localtime($1).' '.$2.' '.$3.'
'. - $currentdocs{$1.'_'.$2.'_'.$3.'.comment'}. - '
View'); - } - } -# ----------------------------------------------------------------- Upload form - if ($allowed) { +$r->print(&Apache::loncommon::bodytag('Course Documents')); +# --------------------------------------------------0------ Standard documents + if (($standard) && ($allowed) && (!$forcesupplement)) { + $r->print('

Main Course Documents

'); + my $folder=$ENV{'form.folder'}; + unless ($folder) { $folder='default'; } + &editor($r,$coursenum,$coursedom,$folder,$allowed); $r->print(< -

Post a new course document

+

Post a new main course document

+
+ +
+Title: + + + +
+ENDFORM + $r->print('
'); + } +# ----------------------------------------------------- Supplemental documents + if (!$forcestandard) { + $r->print('

Supplemental Course Documents

'); + my $folder=$ENV{'form.folder'}; + unless ($folder) { $folder='supplemental'; } + &editor($r,$coursenum,$coursedom,$folder,$allowed); + if ($allowed) { + $r->print(<Post a new supplemental course document

Comment:
+ +
-ENDFORM +ENDSUPFORM + } } + $r->print(''); return OK; }