--- loncom/publisher/lonpubdir.pm 2001/12/28 22:14:10 1.19 +++ loncom/publisher/lonpubdir.pm 2002/02/05 22:25:00 1.22 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # (Publication Handler # -# $Id: lonpubdir.pm,v 1.19 2001/12/28 22:14:10 www Exp $ +# $Id: lonpubdir.pm,v 1.22 2002/02/05 22:25:00 foxr Exp $ # # Copyright Michigan State University Board of Trustees # @@ -103,8 +103,8 @@ sub handler { $r->print('

Construction Space Directory '.$thisdisfn.'/

'); if (($uname ne $ENV{'user.name'}) || ($udom ne $ENV{'user.domain'})) { - $r->print('

Co-Author: '.$uname.' at '.$udom. - '

'); + $r->print('

Co-Author: '.$uname.' at '.$udom. + '

'); } @@ -115,8 +115,8 @@ sub handler { my $linkdir='/~'.$uname.$thisdisfn; $r->print(''. - ''. - ''); + ''. + ''); my $filename; my $dirptr=16384; @@ -132,56 +132,10 @@ sub handler { my $extension=''; if ($filename=~/\.(\w+)$/) { $extension=$1; } if ($cmode&$dirptr) { - my $disfilename=$filename; - if ($filename eq '..') { - $disfilename='Parent Directory'; - } - unless ((($filename eq '..') && ($thisdisfn eq '')) || - ($filename eq '.')) { - $r->print('' - ); - } + putdirectory($r, $thisdisfn, $linkdir, $filename, $cmtime); } elsif (&Apache::loncommon::fileembstyle($extension) ne 'hdn') { - my $status='Unpublished'; - my $bgcol='#FFBBBB'; - my $title=' '; - if (-e $resdir.'/'.$filename) { - my ($rdev,$rino,$rmode,$rnlink, - $ruid,$rgid,$rrdev,$rsize, - $ratime,$rmtime,$rctime, - $rblksize,$rblocks)=stat($resdir.'/'.$filename); - if ($rmtime>=$cmtime) { - $status='Published'; - $bgcol='#BBFFBB'; - $title= - ''. - &Apache::lonnet::metadata($targetdir.'/'.$filename,'title').''; - } else { - $status='Modified'; - $bgcol='#FFFFBB'; - $title= - ''. - &Apache::lonnet::metadata($targetdir.'/'.$filename,'title').''; - if - (&Apache::loncommon::fileembstyle(($filename=~/\.(\w+)$/)) eq 'ssi') { - $status.='
Diffs'; - } - } - $status.='
Retrieve'; - } - $r->print(''. - ''); + putresource($r, $uname, $filename, $thisdisfn, $resdir, + $targetdir, $linkdir, $cmtime); } else { # "hidden" extension and not a directory, so hide it away. } @@ -191,6 +145,82 @@ sub handler { $r->print('
FilenameMetadataModifiedStatus 
ActionsNameTitleStatusLast Modified
'.$disfilename. - ' '.localtime($cmtime). - '  
'.$filename. - ''.$title. - ''.localtime($cmtime).''.$status.''. - 'Publish
'); return OK; } +# +# Put out a directory table row: +# putdirectory(r, base, here, dirname, modtime) +# r - Apache request object. +# reqfile - File in request. +# here - Where we are in directory tree. +# dirname - Name of directory special file. +# modtime - Encoded modification time. +# +sub putdirectory { + my ($r, $reqfile, $here, $dirname, $modtime) = @_; + + # construct the display filename: the directory name unless ..: + + my $disfilename = $dirname; + if ($dirname eq '..') { + $disfilename = 'Parent Directory'; + } + unless (( ($dirname eq '..') && ($reqfile eq '')) || + ($dirname eq '.')) { + $r->print(''. + 'Click to cwd'. + ''. + $disfilename.''. + ' '. + ' '. + ''.localtime($modtime).''. + ''); + } + return OK; +} +# +# Put a table row for a file resource. +# +sub putresource { + my ($r, $uname, $filename, $thisdisfn, + $resdir, $targetdir, $linkdir, + $cmtime) = @_; + + my $status='Unpublished'; + my $title=' '; + if (-e $resdir.'/'.$filename) { + my ($rdev,$rino,$rmode,$rnlink, + $ruid,$rgid,$rrdev,$rsize, + $ratime,$rmtime,$rctime, + $rblksize,$rblocks)=stat($resdir.'/'.$filename); + if ($rmtime>=$cmtime) { + $status='Published'; + $title=''. + &Apache::lonnet::metadata($targetdir.'/'.$filename,'title').''; + } else { + $status='Modified'; + $title=''. + &Apache::lonnet::metadata($targetdir.'/'.$filename,'title').''; + if (&Apache::loncommon::fileembstyle(($filename=~/\.(\w+)$/)) eq 'ssi') { + $status.='
Diffs'; + } + } + $status.='
Retrieve'; + } + $r->print(''. + ''.'Publish'. + ''. + ''. + ''.$filename.''. + ''. + ''.$title.''. + ''.$status.''. + ''.localtime($cmtime).''. + ''); + return OK; +} 1; __END__