--- loncom/interface/portfolio.pm 2006/07/03 04:25:08 1.121.2.5 +++ loncom/interface/portfolio.pm 2006/07/05 22:52:53 1.131 @@ -1,7 +1,7 @@ # The LearningOnline Network # portfolio browser # -# $Id: portfolio.pm,v 1.121.2.5 2006/07/03 04:25:08 albertel Exp $ +# $Id: portfolio.pm,v 1.131 2006/07/05 22:52:53 banghart Exp $ # # Copyright Michigan State University Board of Trustees # @@ -183,6 +183,7 @@ sub display_directory { my $href_location="/uploaded/$udom/$uname/$port_path".$current_path; my $href_edit_location="/editupload/$udom/$uname/$port_path".$current_path; my @dir_lines; + my @version_lines; my %versioned; foreach my $line (sort { @@ -196,14 +197,26 @@ sub display_directory { $filename =~ s/\s+$//; my ($fname,$version,$extension) = &Apache::grades::file_name_version_ext($filename); if ($version) { - $versioned{$fname} .= $version.","; + push(@version_lines, [$filename,$dom,$testdir,$size,$mtime,$obs]); + $versioned{$fname.'.'.$extension} .= $version.","; + } else { + push(@dir_lines, [$filename,$dom,$testdir,$size,$mtime,$obs]); } - push(@dir_lines, [$filename,$dom,$testdir,$size,$mtime,$obs]); } foreach my $line (@dir_lines) { my ($filename,$dom,$testdir,$size,$mtime,$obs) = @$line; my ($fname,$version,$extension) = &Apache::grades::file_name_version_ext($filename); if (($filename ne '.') && ($filename ne '..') && ($filename !~ /\.meta$/ ) && ($filename !~ /(.*)\.(\d+)\.([^\.]*)$/)) { + my %version_flag; + my $show_versions; + if ($env{'form.showversions'} eq $filename) { + $show_versions = 'true'; + } + if (exists($versioned{$filename})) { + $version_flag{$filename} = '<a href="portfolio?showversions='.$filename.'"><img alt="'.&mt('closed folder').'" src="'.$iconpath.'folder_pointer_closed.gif" /></a>'; + } else { + $version_flag{$filename} = ''; + } if ($dirptr&$testdir) { my $colspan='colspan="2"'; if ($select_mode eq 'true'){ @@ -211,18 +224,12 @@ sub display_directory { } $r->print('<tr class="LC_browser_folder"><td '.$colspan.'><img alt="'.&mt('closed folder').'" src="'.$iconpath.'folder_closed.gif" /></td>'); $r->print('<td>Go to ...</td>'); - $r->print('<td>'.&make_anchor($url,$filename.'/',$current_path.$filename.'/',$env{'form.mode'},$env{"form.fieldname"},$env{'form.continue'},$group).'</td>'); + $r->print('<td>'.$version_flag{$filename}.&make_anchor($url,$filename.'/',$current_path.$filename.'/',$env{'form.mode'},$env{"form.fieldname"},$env{'form.continue'},$group).'</td>'); $r->print('</tr>'); } else { my $css_class = 'LC_browser_file'; my $line; - my $version_flag; - if (exists($versioned{$fname})) { - $version_flag = "*"; - } else { - $version_flag = ""; - } - my $fullpath = $current_path.$filename; + my $fullpath = $current_path.$filename; $fullpath = &prepend_group($fullpath,$group); if ($select_mode eq 'true') { $line='<td><input type="checkbox" name="checkfile" value="'.$filename.'"'; @@ -247,7 +254,7 @@ sub display_directory { my $cat='<img alt="'.&mt('Catalog Information'). '" src="'.&Apache::loncommon::lonhttpdurl('/res/adm/pages/catalog.gif').'" />'; $line .= '<a href="'.$url.'?rename='.$filename.'&currentpath='.$current_path.$groupecho.'">Rename</a>'; - $line .= '</td><td><a href="'.$href_edit_location.$filename.'.meta">'.$cat.'</a>'; + $line .= '</td><td>'.$version_flag{$filename}.'<a href="'.$href_edit_location.$filename.'.meta">'.$cat.'</a>'; } $line .= '</td>'; } @@ -288,7 +295,7 @@ sub display_directory { } } $r->print('<td><img alt="" src="'.&Apache::loncommon::icon($filename).'" /></td>'); - $r->print('<td><a href="'.$href_location.$filename.'">'. + $r->print('<td>'.$version_flag{$filename}.'<a href="'.$href_location.$filename.'">'. $filename.'</a></td>'); $r->print('<td>'.$size.'</td>'); $r->print('<td>'.&Apache::lonlocal::locallocaltime($mtime).'</td>'); @@ -535,20 +542,7 @@ sub display_access { my %access_controls = &Apache::lonnet::get_access_controls($current_permissions,$group,$file_name); my $aclcount = keys(%access_controls); my $header = '<h3>'.&mt('Allowing others to retrieve portfolio file: [_1]',$env{'form.currentpath'}.$env{'form.access'}).'</h3>'; - my $info .= - &mt('Access to this file by others can be set to be one or more of the following types: public, passphrase-protected or conditional.'). - '<br /><ul><li>'. - &mt('Public files are available to anyone without the need for login.'). - '</li><li>'. - &mt('Passphrase-protected files do not require log-in, but will require the viewer to enter the passphrase you set.'). - '</li>'. - #'<li>'. - #&mt('Conditional files are accessible to logged-in users with accounts in the LON-CAPA network, who satisfy the conditions you set.'). - #'<br />'. - #&mt('The conditions can include affiliation with a particular course or group, or a user account in a specific domain.'). - #'<br />'. - #&mt('Alternatively access can be granted to people with specific LON-CAPA usernames and domains.'). - '</li></ul>'; + my $info .= &mt('Access to this file by others can be set to be one or more of the following types: public, passphrase-protected or conditional.').'<br /><ul><li>'.&mt('Public files are available to anyone without the need for login.').'</li><li>'.&mt('Passphrase-protected files do not require log-in, but will require the viewer to enter the passphrase you set.').'</li><li>'.&mt('Conditional files are accessible to logged-in users with accounts in the LON-CAPA network, who satisfy the conditions you set.').'<br />'.&mt('The conditions can include affiliation with a particular course or group, or a user account in a specific domain.').'<br />'.&mt('Alternatively access can be granted to people with specific LON-CAPA usernames and domains.').'</li></ul>'; if ($can_setacl) { &open_form($r,$url); $r->print($header.$info); @@ -995,25 +989,24 @@ sub access_setting_table { $passwd.'" /></td>'); $r->print(&Apache::loncommon::end_data_table_row()); $r->print(&Apache::loncommon::end_data_table()); - - #$r->print('</td></tr><tr><td colspan="3"> </td></tr><tr><td valign="top">'); - #&access_element($r,'domains',\%acl_count,\@domains,$access_controls,$now,$then); - #$r->print('</td><td> </td><td valign="top">'); - #&access_element($r,'users',\%acl_count,\@users,$access_controls,$now,$then); - #$r->print('</td></tr><tr><td colspan="3"></td></tr><tr>'); - #if (@courses > 0 || @groups > 0) { - # $r->print('<td colspan="3" valign="top">'); - #} else { - # $r->print('<td valign="top">'); - #} - #&access_element($r,'course',\%acl_count,\@courses,$access_controls,$now,$then); - #$r->print('</td>'); - #if (@courses > 0 || @groups > 0) { - # $r->print('</tr><tr><td colspan="3"> </td></tr><tr><td colspan="3" valign="top">'); - #} else { - # $r->print('<td> </td><td valign="top">'); - #} - #&access_element($r,'group',\%acl_count,\@groups,$access_controls,$now,$then); + $r->print('</td></tr><tr><td colspan="3"> </td></tr><tr><td valign="top">'); + &access_element($r,'domains',\%acl_count,\@domains,$access_controls,$now,$then); + $r->print('</td><td> </td><td valign="top">'); + &access_element($r,'users',\%acl_count,\@users,$access_controls,$now,$then); + $r->print('</td></tr><tr><td colspan="3"></td></tr><tr>'); + if (@courses > 0 || @groups > 0) { + $r->print('<td colspan="3" valign="top">'); + } else { + $r->print('<td valign="top">'); + } + &access_element($r,'course',\%acl_count,\@courses,$access_controls,$now,$then); + $r->print('</td>'); + if (@courses > 0 || @groups > 0) { + $r->print('</tr><tr><td colspan="3"> </td></tr><tr><td colspan="3" valign="top">'); + } else { + $r->print('<td> </td><td valign="top">'); + } + &access_element($r,'group',\%acl_count,\@groups,$access_controls,$now,$then); $r->print('</td></tr></table>'); } @@ -1688,7 +1681,7 @@ sub handler { &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, ['selectfile','currentpath','meta','lockinfo','currentfile','action', 'fieldname','mode','rename','continue','group','access','setnum', - 'cnum','cdom','type','setroles']); + 'cnum','cdom','type','setroles','showversions']); my ($uname,$udom,$portfolio_root,$url,$group,$caller,$title); if ($r->uri =~ m|^(/adm/)([^/]+)|) { $url = $1.$2;