--- loncom/interface/portfolio.pm 2004/07/09 17:12:38 1.14
+++ loncom/interface/portfolio.pm 2004/07/23 01:25:56 1.16
@@ -18,12 +18,9 @@
#
# /home/httpd/html/adm/gpl.txt
#
-
-
# http://www.lon-capa.org/
#
-
package Apache::portfolio;
use strict;
use Apache::Constants qw(:common :http);
@@ -32,17 +29,19 @@ use Apache::lonnet;
use Apache::lontexconvert;
use Apache::lonfeedback;
use Apache::lonlocal;
+
+# receives a file name and path stub from username/userfiles/portfolio/
+# returns an anchor tag consisting encoding filename and currentpath
sub makeAnchor{
- # receives a file name and path stub from username/userfiles/portfolio/
- # returns an anchor tag consisting encoding filename and currentpath
my ($fileName, $currentPath) = @_;
my $anchor = ''.$fileName.'';
return $anchor;
}
+
+# returns html with
separated contents of the directory
+# returns a currentFile (bolds the selected file/dir)
sub displayDirectory {
- # returns html with
separated contents of the directory
- # returns a currentFile (bolds the selected file/dir)
- my ($currentPath, $currentFile, $isDir, @dirList,) = @_;
+ my ($currentPath, $currentFile, @dirList,) = @_;
my $displayOut='';
my $fileName;
my $upPath;
@@ -64,22 +63,31 @@ sub displayDirectory {
foreach my $line (@dirList) {
#$strip holds directory/file name
#$dom
- my ($fileName,$dom,undef,$testdir,undef,undef,undef,undef,undef,undef,undef,undef,undef,undef,$obs,undef)=split(/\&/,$line,16);
+ my ($fileName,$dom,undef,$testdir,undef,undef,undef,undef,undef,undef,undef,undef,undef,undef,$obs,undef,$path)=split(/\&/,$line,17);
+ $path =~ m:/:;
+ my $dirDepth = @-;
if (($fileName ne '.') && ($fileName ne '..')){
+ for (my $i = 0; $i <= $dirDepth; $i += 1){
+ $displayOut.='
'; + } if ($testdir =~ m:^1:){ # handle directories different from files if ($fileName eq $currentFile){ #checks to bold the selected file - $displayOut.= ''.(makeAnchor($fileName.'/', $currentPath.$fileName.'/').''; + } + } } @@ -88,7 +96,7 @@ sub displayDirectory { sub displayActions { # returns html to offer user appropriate actions depending on selected file/directory my $displayOut; - my ($currentPath, $currentFile, $isDir, $isEmpty) = @_; + my ($currentPath, $currentFile, $isEmpty) = @_; # $displayOut = 'here are actions for '.$currentFile; if ($currentFile =~ m:/$:){ # if the selected file is a directory, these are the options @@ -165,7 +173,6 @@ sub handler { my $action; # delete, rename, makedirectory, removedirectory, my $filenewname; # for rename action (guess what we do with it!) my $isFile; - my $isDir; my $isEmpty; &Apache::loncommon::no_cache($r); &Apache::loncommon::content_type($r,'text/html'); @@ -216,17 +223,60 @@ sub handler { # we always need $dirList, plus this will return information about the current file # as well as information about he home server directory structure, specifically # the path to the users userfiles directory. - my $portfolioRoot = '/home/httpd/lonUsers/'.$ENV{'user.domain'}.'/'; - $ENV{'user.name'} =~ /^(.?)(.?)(.?)/; - $portfolioRoot = $portfolioRoot.$1.'/'.$2.'/'.$3.'/'.$ENV{'user.name'}.'/userfiles/portfolio'; - my @list = &Apache::lonnet::dirlist($currentPath, $ENV{'user.domain'}, $ENV{'user.name'}, $portfolioRoot); - @dirList = @list; + # + my $portfolio_root = &Apache::loncommon::propath($ENV{'user.domain'}, + $ENV{'user.name'}). + '/userfiles/portfolio'; + my $done = 0; + my $subdir = ''; + my @workinglist; # intermediate array, holds directory listing lines (dirlist), and path information + my $readDirectory = 1; # flag for directory + my $loopCounter = 0; # needed only for development to prevent run away program (or maybe more?) + while (!$done){ + # Needed while developing. Later, too? + $loopCounter += 1; + if ($loopCounter > 50) { + $r->print('
'); + $displayOut.= ''.(makeAnchor($fileName.'/', $path.$fileName.'/').'
'."\n"); }else{ - $displayOut.= (makeAnchor($fileName.'/', $currentPath.$fileName.'/').'
'); + $displayOut.= (makeAnchor($fileName.'/', $path.$fileName.'/').'
'."\n"); } }else{ if ($fileName eq $currentFile){ #checks to bold the selected file - $displayOut.=''.(makeAnchor($fileName, $currentPath).'
'); + $displayOut.=''.(makeAnchor($fileName, $currentPath).'
'."\n"); }else{ - $displayOut.=(makeAnchor($fileName, $currentPath).'
'); + $displayOut.=(makeAnchor($fileName, $currentPath).'
'."\n"); } } + for (my $i = 0; $i <= $dirDepth; $i += 1){ + $displayOut.='
'); - $r->print(displayDirectory($currentPath, $currentFile, $isDir, @dirList)); + $r->print(displayDirectory($currentPath, $currentFile, @dirList)); $r->print(' | >'); - $r->print(displayActions($currentPath, $currentFile, $isDir, $isEmpty)); + $r->print(displayActions($currentPath, $currentFile, $isEmpty)); $r->print(' | >