--- loncom/interface/londocs.pm 2004/12/10 19:22:29 1.151 +++ loncom/interface/londocs.pm 2004/12/10 20:46:38 1.152 @@ -1,7 +1,7 @@ # The LearningOnline Network # Documents # -# $Id: londocs.pm,v 1.151 2004/12/10 19:22:29 albertel Exp $ +# $Id: londocs.pm,v 1.152 2004/12/10 20:46:38 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -1152,9 +1152,13 @@ END } elsif ($url=~m|^/ext/|) { $url='/adm/wrapper'.$url; } - unless ($container eq 'page') { + $url.=(($url=~/\?/)?'&':'?').'symb='.&Apache::lonnet::escape($symb); + if ($container eq 'page') { + my $symb=$ENV{'form.pagesymb'}; + + $url=&Apache::lonnet::clutter((&Apache::lonnet::decode_symb($symb))[2]); $url.=(($url=~/\?/)?'&':'?').'symb='.&Apache::lonnet::escape($symb); - } + } } my $parameterset=' '; if ($isfolder) { @@ -1171,13 +1175,26 @@ END } if ($ispage) { + &Apache::lonnet::logthis(" in ispage "); my $pagename=&Apache::lonnet::escape($pagetitle); my $pagepath; my $folderpath=$ENV{'form.folderpath'}; if ($folderpath) { $pagepath = $folderpath.'&' }; $pagepath.=$pagearg.'&'.$pagename; - $url.='pagepath='.&Apache::lonnet::escape($pagepath); + my $symb=$ENV{'form.pagesymb'}; + if (!$symb) { + my $path='uploaded/'. + $ENV{'course.'.$ENV{'request.course.id'}.'.domain'}.'/'. + $ENV{'course.'.$ENV{'request.course.id'}.'.num'}.'/'; + $symb=&Apache::lonnet::encode_symb($path.$folder.'.sequence', + $residx, + $path.$pagearg.'.page'); + } + #(undef,undef,$url)=&Apache::lonnet::decode_symb($symb); + $url.='pagepath='.&Apache::lonnet::escape($pagepath). + '&pagesymb='.&Apache::lonnet::escape($symb); } + &Apache::lonnet::logthis(" link \n$url"); $line.=''. "$title"; @@ -1676,7 +1693,7 @@ sub handler { my $containertag; my $uploadtag; &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, - ['folderpath','pagepath']); + ['folderpath','pagepath','pagesymb']); if ($ENV{'form.folderpath'}) { my (@folderpath)=split('&',$ENV{'form.folderpath'}); $ENV{'form.foldername'}=&Apache::lonnet::unescape(pop(@folderpath));