--- loncom/interface/portfolio.pm 2004/07/09 16:40:31 1.13
+++ 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,14 +173,16 @@ 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; - # send header - # FIXME need to start using &Apache::loncommon::no_cache($r); - &Apache::loncommon::content_type($r, 'text/html'); - &Apache::loncommon::bodytag('Portfolio Managment', 'bgcolor="dogfood"'); + &Apache::loncommon::content_type($r,'text/html'); $r->send_http_header; + # Give the LON-CAPA page header + $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(' | >