--- loncom/interface/lonmeta.pm 2006/05/31 17:44:14 1.158 +++ loncom/interface/lonmeta.pm 2006/08/21 18:04:20 1.171 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # Metadata display handler # -# $Id: lonmeta.pm,v 1.158 2006/05/31 17:44:14 www Exp $ +# $Id: lonmeta.pm,v 1.171 2006/08/21 18:04:20 banghart Exp $ # # Copyright Michigan State University Board of Trustees # @@ -170,7 +170,7 @@ sub authordisplay { my ($aname,$adom)=@_; return &Apache::loncommon::aboutmewrapper (&Apache::loncommon::plainname($aname,$adom), - $aname,$adom,'preview').' <tt>['.$aname.'@'.$adom.']</tt>'; + $aname,$adom,'preview').' <tt>['.$aname.':'.$adom.']</tt>'; } # Pretty display @@ -287,17 +287,22 @@ sub portfolio_linked_path { if ($group) { $start = "groups/$group/".$start; } - my $result = &Apache::portfolio::make_anchor($port_path,$start,'/', - undef,undef,undef,$group); - + my %anchor_fields = ( + 'selectfile' => $start, + 'currentpath' => '/' + ); + my $result = &Apache::portfolio::make_anchor($port_path,\%anchor_fields,$start); my $fullpath = '/'; my (undef,@tree) = split('/',$path); my $filename = pop(@tree); foreach my $dir (@tree) { $fullpath .= $dir.'/'; $result .= '/'; - $result .= &Apache::portfolio::make_anchor($port_path,$dir,$fullpath, - undef,undef,undef,$group); + my %anchor_fields = ( + 'selectfile' => $dir, + 'currentpath' => $fullpath + ); + $result .= &Apache::portfolio::make_anchor($port_path,\%anchor_fields,$dir); } $result .= "/$filename"; return $result; @@ -316,6 +321,9 @@ sub get_port_path_and_group { } else { $port_path = '/adm/portfolio'; } + if ($env{'form.group'} ne $group) { + $env{'form.group'} = $group; + } return ($port_path,$group); } @@ -357,14 +365,20 @@ sub pre_select_course { $r->print('<p>'.&mt('If you would like to associate this resource ([_1]) with a current or previous course, please select one from the list below, otherwise select, \'None\'','<tt>'.$res_uri.'</tt>').'</p>'); $output = &select_course(); $r->print($output.'<br /><input type="submit" name="store" value="'. - &mt('Associate Resource With Selected Course').'">'); + &mt('Associate Resource With Selected Course').'" />'); + $r->print('<input type="hidden" name="currentpath" value="'.$env{'form.currentpath'}.'" />'); + $r->print('<input type="hidden" name="associate" value="true" />'); $r->print('</form>'); my ($port_path,$group) = &get_port_path_and_group($uri); - $r->print('<br /><br /><form method="POST" action="'.$port_path.'">'. + my $group_input; + if ($group) { + $group_input = '<input type="hidden" name="group" value="'.$group.'" />'; + } + $r->print('<br /><br /><form method="post" action="'.$port_path.'">'. '<input type="hidden" name="currentpath" value="'.$path.'" />'. - '<input type="hidden" name="group" value="'.$group.'" />'. - '<input type="submit" name="cancel" value="'.&mt('Cancel').'">'. + $group_input. + '<input type="submit" name="cancel" value="'.&mt('Cancel').'" />'. '</form>'); return; @@ -705,24 +719,23 @@ sub prettyinput { # Main Handler sub handler { my $r=shift; - # + &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, + ['currentpath']); my $uri=$r->uri; # # Set document type &Apache::loncommon::content_type($r,'text/html'); $r->send_http_header; return OK if $r->header_only; - # my ($resdomain,$resuser)= (&Apache::lonnet::declutter($uri)=~/^(\w+)\/(\w+)\//); - if ($uri=~m:/adm/bombs/(.*)$:) { $r->print(&Apache::loncommon::start_page('Error Messages')); # Looking for all bombs? &report_bombs($r,$uri); - } elsif ($uri=~/\/portfolio\//) { + } elsif ($uri=~m|^/editupload/[^/]+/[^/]+/portfolio/|) { ($resdomain,$resuser)= - (&Apache::lonnet::declutter($uri)=~m|^(\w+)/(\w+)/portfolio|); + (&Apache::lonnet::declutter($uri)=~m|^(\w+)/(\w+)/portfolio|); $r->print(&Apache::loncommon::start_page('Edit Portfolio File Catalog Information', undef, {'domain' => $resdomain,})); @@ -731,7 +744,12 @@ sub handler { } else { &pre_select_course($r,$uri); } - } elsif ($uri=~/^\/\~/) { + } elsif ($uri=~m|^/editupload/[^/]+/[^/]+/groups/|) { + $r->print(&Apache::loncommon::start_page('Edit Group Portfolio File Catalog Information', + undef, + {'domain' => $resdomain,})); + &present_editable_metadata($r,$uri,'portfolio'); + } elsif ($uri=~m|^/~|) { # Construction space $r->print(&Apache::loncommon::start_page('Edit Catalog nformation', undef, @@ -797,6 +815,7 @@ ENDCLEAR sub present_uneditable_metadata { my ($r,$uri) = @_; # + my $uploaded = ($uri =~ m|/uploaded/|); my %content=(); # Read file foreach (split(/\,/,&Apache::lonnet::metadata($uri,'keys'))) { @@ -809,16 +828,18 @@ sub present_uneditable_metadata { my $disuri=&Apache::lonnet::clutter($uri); $disuri=~s/^\/adm\/wrapper//; # version - my $currentversion=&Apache::lonnet::getversion($disuri); my $versiondisplay=''; - if ($thisversion) { - $versiondisplay=&mt('Version').': '.$thisversion. - ' ('.&mt('most recent version').': '. - ($currentversion>0 ? - $currentversion : - &mt('information not available')).')'; - } else { - $versiondisplay='Version: '.$currentversion; + if (!$uploaded) { + my $currentversion=&Apache::lonnet::getversion($disuri); + if ($thisversion) { + $versiondisplay=&mt('Version').': '.$thisversion. + ' ('.&mt('most recent version').': '. + ($currentversion>0 ? + $currentversion : + &mt('information not available')).')'; + } else { + $versiondisplay='Version: '.$currentversion; + } } # crumbify displayed URL uri target prefix form size $disuri=&Apache::lonhtmlcommon::crumbs($disuri,undef, undef, undef,'+1'); @@ -838,30 +859,38 @@ sub present_uneditable_metadata { if (! defined($title)) { $title = 'Untitled Resource'; } - foreach ('title', - 'author', - 'subject', - 'keywords', - 'notes', - 'abstract', - 'lowestgradelevel', - 'highestgradelevel', - 'standards', - 'mime', - 'language', - 'creationdate', - 'lastrevisiondate', - 'owner', - 'copyright', - 'customdistributionfile', - 'sourceavail', - 'sourcerights', - 'obsolete', - 'obsoletereplacement') { - $table.='<tr><td bgcolor="#AAAAAA">'.$lt{$_}. + my @fields; + if ($uploaded) { + @fields = ('title','author','subject','keywords','notes','abstract', + 'lowestgradelevel','highestgradelevel','standards','mime', + 'owner'); + } else { + @fields = ('title', + 'author', + 'subject', + 'keywords', + 'notes', + 'abstract', + 'lowestgradelevel', + 'highestgradelevel', + 'standards', + 'mime', + 'language', + 'creationdate', + 'lastrevisiondate', + 'owner', + 'copyright', + 'customdistributionfile', + 'sourceavail', + 'sourcerights', + 'obsolete', + 'obsoletereplacement'); + } + foreach my $field (@fields) { + $table.='<tr><td bgcolor="#AAAAAA">'.$lt{$field}. '</td><td bgcolor="#CCCCCC">'. - &prettyprint($_,$content{$_}).'</td></tr>'; - delete $content{$_}; + &prettyprint($field,$content{$field}).'</td></tr>'; + delete($content{$field}); } # $r->print(<<ENDHEAD); @@ -875,7 +904,7 @@ $versiondisplay $table </table> ENDHEAD - if ($env{'user.adv'}) { + if (!$uploaded && $env{'user.adv'}) { &print_dynamic_metadata($r,$uri,\%content); } return; @@ -1121,7 +1150,7 @@ sub present_editable_metadata { my $goback=&mt('Back to Source File'); $r->print(<<ENDBOMBS); <h1>$disuri</h1> -<form method="post" name="defaultmeta"> +<form method="post" action="" name="defaultmeta"> ENDBOMBS if ($showdel) { $r->print(<<ENDDEL); @@ -1151,16 +1180,17 @@ ENDDEL } $r->print(<<ENDEDIT); <h1>$displayfile</h1> -<form method="post" name="defaultmeta"> +<form method="post" action="" name="defaultmeta"> ENDEDIT - $r->print('<script language="JavaScript">'. + $r->print('<script type="JavaScript">'. &Apache::loncommon::browser_and_searcher_javascript(). '</script>'); my %lt=&fieldnames($file_type); my $output; my @fields; if ($file_type eq 'portfolio') { - @fields = ('author','title','subject','keywords','abstract','notes','lowestgradelevel', + @fields = ('author','title','subject','keywords','abstract', + 'notes','lowestgradelevel', 'highestgradelevel','standards'); } else { @fields = ('author','title','subject','keywords','abstract','notes', @@ -1179,9 +1209,18 @@ ENDEDIT } if (! $Apache::lonpublisher::metadatafields{'copyright'}) { $Apache::lonpublisher::metadatafields{'copyright'}= - 'default'; + 'default'; } if ($file_type eq 'portfolio') { + if (! $Apache::lonpublisher::metadatafields{'mime'}) { + ($Apache::lonpublisher::metadatafields{'mime'}) = + ( $target=~/\.(\w+)$/ ); + } + if (! $Apache::lonpublisher::metadatafields{'owner'}) { + $Apache::lonpublisher::metadatafields{'owner'} = + $env{'user.name'}.':'.$env{'user.domain'}; + } + if ($Apache::lonpublisher::metadatafields{'courserestricted'} ne 'none') { $r->print(&mt('Associated with course [_1]','<strong>'.$env{$Apache::lonpublisher::metadatafields{'courserestricted'}.".description"}. '</strong>').'<br />'); @@ -1247,22 +1286,21 @@ ENDEDIT '<>&"'). '</'.$tag.'>'; } - if ($fn =~ m|/portfolio/|) { + if ($fn =~ m|^$Apache::lonnet::perlvar{'lonDocRoot'}/userfiles/portfolio/|) { my ($path, $new_fn) = ($fn =~ m|/(portfolio.*)/([^/]*)$|); - $env{'form.'.$formname}=$file_content."\n"; - $env{'form.'.$formname.'.filename'}=$new_fn; - my $result =&Apache::lonnet::userfileupload($formname,'', - $path); - - if ($result =~ /(error|notfound)/) { - $r->print('<p><font color="red">'. - &mt('Could not write metadata').', '. - &mt('FAIL').'</font></p>'); - } else { - $r->print('<p><font color="blue">'.&mt('Wrote Metadata'). - ' '.&Apache::lonlocal::locallocaltime(time). - '</font></p>'); - } + $r->print(&store_portfolio_metadata($formname,$file_content,$path, + $new_fn)); + unless ($env{'form.associate'}) { + $r->print(&Apache::portfolio::done("Return to Portfolio",'/adm/portfolio')); + return; + } + } elsif ($fn =~ m|^$Apache::lonnet::perlvar{'lonDocRoot'}/userfiles/groups/\w+/portfolio/|) { + my ($path, $new_fn) = ($fn =~ m|/(groups/\w+/portfolio.*)/([^/]*)$|); + $r->print(&store_portfolio_metadata($formname,$file_content,$path,$new_fn)); + unless ($env{'form.associate'}) { + $r->print(&Apache::portfolio::done("Return to Portfolio",'/adm/portfolio')); + return; + } } else { if (! ($mfh=Apache::File->new('>'.$fn))) { $r->print('<p><font color="red">'. @@ -1274,19 +1312,27 @@ ENDEDIT ' '.&Apache::lonlocal::locallocaltime(time). '</font></p>'); } + unless ($env{'form.associate'}) { + $r->print(&Apache::portfolio::done("Return to Portfolio",'/adm/portfolio')); + return; + } } } $r->print($output.'<br /><input type="submit" name="store" value="'. - &mt('Store Catalog Information').'">'); + &mt('Store Catalog Information').'" />'); if ($file_type eq 'portfolio') { my ($port_path,$group) = &get_port_path_and_group($uri); + if ($group) { + $r->print('<input type="hidden" name="group" value="'.$group.'" />'); + } + $r->print('<input type="hidden" name="currentpath" value="'.$env{'form.currentpath'}.'" />'); $r->print('</form> - <br /><br /><form method="POST" action="'.$port_path.'">'. + <br /><br /><form method="post" action="'.$port_path.'">'. '<input type="hidden" name="group" value="'.$group.'" />'. '<input type="hidden" name="currentpath" value="'.$path.'" />'. - '<input type="submit" name="cancel" value="'.&mt('Discard Edits and Return to Portfolio').'">'); + '<input type="submit" name="cancel" value="'.&mt('Discard Edits and Return to Portfolio').'" />'); } } @@ -1295,7 +1341,21 @@ ENDEDIT return; } +sub store_portfolio_metadata { + my ($formname,$content,$path,$new_fn) = @_; + $env{'form.'.$formname}=$content."\n"; + $env{'form.'.$formname.'.filename'}=$new_fn; + my $result =&Apache::lonnet::userfileupload($formname,'',$path); + if ($result =~ /(error|notfound)/) { + return '<p><font color="red">'. + &mt('Could not write metadata').', '. + &mt('FAIL').'</font></p>'; + } else { + return '<p><font color="blue">'.&mt('Wrote Metadata'). + ' '.&Apache::lonlocal::locallocaltime(time).'</font></p>'; + } +} + 1; __END__ -