--- loncom/publisher/lonpubdir.pm 2001/07/12 21:23:12 1.10
+++ loncom/publisher/lonpubdir.pm 2002/02/05 12:54:46 1.21
@@ -1,16 +1,45 @@
# The LearningOnline Network with CAPA
-#
# (Publication Handler
+#
+# $Id: lonpubdir.pm,v 1.21 2002/02/05 12:54:46 foxr Exp $
+#
+# Copyright Michigan State University Board of Trustees
+#
+# This file is part of the LearningOnline Network with CAPA (LON-CAPA).
+#
+# LON-CAPA is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# LON-CAPA is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with LON-CAPA; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+#
+# /home/httpd/html/adm/gpl.txt
+#
+# http://www.lon-capa.org/
+#
#
# (TeX Content Handler
#
+# YEAR=2000
# 05/29/00,05/30,10/11 Gerd Kortemeyer)
#
# 11/28,11/29,11/30,12/01,12/02,12/04,12/23 Gerd Kortemeyer
+# YEAR=2001
# 03/23 Guy Albertelli
# 03/24,03/29 Gerd Kortemeyer)
+# 03/31,04/03,05/09,06/23,08/18,08/20 Gerd Kortemeyer
+# 12/15 Scott Harrison
+# 12/28 Gerd Kortemeyer
#
-# 03/31,04/03,05/09,06/23 Gerd Kortemeyer
+###
package Apache::lonpubdir;
@@ -19,8 +48,7 @@ use Apache::File;
use File::Copy;
use Apache::Constants qw(:common :http :methods);
use Apache::loncacc;
-use Apache::lonnet;
-
+use Apache::loncommon();
sub handler {
@@ -75,34 +103,39 @@ 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.
+ '
');
}
my $docroot=$r->dir_config('lonDocRoot');
my $resdir=$docroot.'/res/'.$udom.'/'.$uname.$thisdisfn;
+ my $targetdir=$udom.'/'.$uname.$thisdisfn;
my $linkdir='/~'.$uname.$thisdisfn;
$r->print(''.
- 'Filename | Modified | Status |
');
+ 'Actions | Name | Title | '.
+ 'Status | Last Modified |
');
my $filename;
my $dirptr=16384;
opendir(DIR,$fn);
my @files=sort(readdir(DIR));
- foreach my$filename (@files) {
+ foreach my $filename (@files) {
my ($cdev,$cino,$cmode,$cnlink,
$cuid,$cgid,$crdev,$csize,
$catime,$cmtime,$cctime,
$cblksize,$cblocks)=stat($fn.'/'.$filename);
+
my $extension='';
if ($filename=~/\.(\w+)$/) { $extension=$1; }
- if (($extension ne 'meta') && (&Apache::lonnet::fileembstyle($extension))) {
+ if ($cmode&$dirptr) {
+ 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,
@@ -110,35 +143,37 @@ sub handler {
$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::lonnet::fileembstyle(($filename=~/\.(\w+)$/)) eq 'ssi') {
+ (&Apache::loncommon::fileembstyle(($filename=~/\.(\w+)$/)) eq 'ssi') {
$status.='
Diffs';
}
}
+ $status.='
Retrieve';
}
- $r->print(''.$filename.
- ' | '.localtime($cmtime).' | '.$status.' |
');
- } elsif ($cmode&$dirptr) {
- my $disfilename=$filename;
- if ($filename eq '..') {
- $disfilename='Parent Directory';
- }
- unless ((($filename eq '..') && ($thisdisfn eq '')) ||
- ($filename eq '.')) {
- $r->print(''.$disfilename.
- ' | '.localtime($cmtime).' | |
');
- }
+ $r->print(''.
+ ''.'Publish'.
+ ' | '.
+ ''.
+ ''.$filename.''.
+ ' | '.
+ ''.$title.' | '.
+ ''.$status.' | '.
+ ''.localtime($cmtime).' | '.
+ '
');
} else {
- #no extension that we know of and not a directory
- #just hide it away
+ # "hidden" extension and not a directory, so hide it away.
}
}
closedir(DIR);
@@ -146,6 +181,93 @@ sub handler {
$r->print('