version 1.98, 2005/07/08 10:39:49
|
version 1.114, 2005/10/19 21:53:16
|
Line 17
|
Line 17
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
# GNU General Public License for more details. |
# GNU General Public License for more details. |
# |
# |
# You should have received a copy of the GNU General Public License |
# You should have received a copy of the GNU General Public License |
# along with LON-CAPA; if not, write to the Free Software |
# along with LON-CAPA; if not, write to the Free Software |
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
# |
# |
Line 33 use LONCAPA::lonmetadata();
|
Line 33 use LONCAPA::lonmetadata();
|
use Apache::Constants qw(:common); |
use Apache::Constants qw(:common); |
use Apache::lonnet; |
use Apache::lonnet; |
use Apache::loncommon(); |
use Apache::loncommon(); |
use Apache::lonhtmlcommon(); |
use Apache::lonhtmlcommon(); |
use Apache::lonmsg; |
use Apache::lonmsg; |
use Apache::lonpublisher; |
use Apache::lonpublisher; |
use Apache::lonlocal; |
use Apache::lonlocal; |
Line 237 sub diffgraph {
|
Line 237 sub diffgraph {
|
# The field names |
# The field names |
sub fieldnames { |
sub fieldnames { |
my $file_type=shift; |
my $file_type=shift; |
my %fields = |
my %fields; |
('title' => 'Title', |
%fields = |
|
(%fields, |
|
'title' => 'Title', |
'author' =>'Author(s)', |
'author' =>'Author(s)', |
'authorspace' => 'Author Space', |
'authorspace' => 'Author Space', |
'modifyinguser' => 'Last Modifying User', |
'modifyinguser' => 'Last Modifying User', |
Line 248 sub fieldnames {
|
Line 250 sub fieldnames {
|
'abstract' => 'Abstract', |
'abstract' => 'Abstract', |
'lowestgradelevel' => 'Lowest Grade Level', |
'lowestgradelevel' => 'Lowest Grade Level', |
'highestgradelevel' => 'Highest Grade Level'); |
'highestgradelevel' => 'Highest Grade Level'); |
|
if ($file_type eq 'portfolio') { |
|
%fields = |
|
(%fields, |
|
'title' => 'Title', |
|
'author' =>'Author(s)', |
|
'authorspace' => 'Author Space', |
|
'modifyinguser' => 'Last Modifying User', |
|
'subject' => 'Subject', |
|
'keywords' => 'Keyword(s)', |
|
'notes' => 'Notes', |
|
'abstract' => 'Abstract', |
|
'lowestgradelevel' => 'Lowest Grade Level', |
|
'highestgradelevel' => 'Highest Grade Level'); |
|
} |
|
if ($file_type eq 'restrictedportfolio') { |
|
%fields = |
|
(%fields, |
|
'metadata.title' => 'Title', |
|
'metadata.author' =>'Author(s)', |
|
'metadata.authorspace' => 'Author Space', |
|
'metadata.modifyinguser' => 'Last Modifying User', |
|
'metadata.subject' => 'Subject', |
|
'metadata.keywords' => 'Keyword(s)', |
|
'metadata.notes' => 'Notes', |
|
'metadata.abstract' => 'Abstract', |
|
'metadata.lowestgradelevel' => 'Lowest Grade Level', |
|
'metadata.highestgradelevel' => 'Highest Grade Level'); |
|
} |
if (! defined($file_type) || $file_type ne 'portfolio') { |
if (! defined($file_type) || $file_type ne 'portfolio') { |
%fields = |
%fields = |
(%fields, |
(%fields, |
Line 288 sub fieldnames {
|
Line 318 sub fieldnames {
|
return &Apache::lonlocal::texthash(%fields); |
return &Apache::lonlocal::texthash(%fields); |
} |
} |
|
|
|
sub select_course { |
|
my ($r)=@_; |
|
my %courses; |
|
foreach my $key (keys (%env)) { |
|
if ($key =~ m/\.metadata\./) { |
|
$key =~ m/^course\.(.+)(\.metadata.+$)/; |
|
my $course = $1; |
|
my $coursekey = 'course.'.$course.'.description'; |
|
my $value = $env{$coursekey}; |
|
$courses{$coursekey} = $value; |
|
} |
|
} |
|
$r->print('<h3>Course Related Meta-Data</h3><br />'); |
|
$r->print('<form action="" method="post">'); |
|
$r->print('Select your test course<br />'); |
|
$r->print('<select name="metacourse" >'); |
|
my $meta_not_found = 1; |
|
foreach my $key (keys (%courses)) { |
|
if ($meta_not_found) { |
|
undef($meta_not_found); |
|
$r->print('<h3>Portfolio Meta-Data</h3><br />'); |
|
$r->print('<form action="" method="post">'); |
|
$r->print('Select your course<br />'); |
|
$r->print('<select name="metacourse" >'); |
|
} |
|
$r->print('<option value="'.$key.'">'); |
|
$r->print($courses{$key}); |
|
$r->print('</option>'); |
|
} |
|
unless ($meta_not_found) { |
|
$r->print('</select><br />'); |
|
$r->print('<input type="submit" value="Assign Portfolio Metadata" />'); |
|
$r->print('</form>'); |
|
} |
|
return 'ok'; |
|
} |
# Pretty printing of metadata field |
# Pretty printing of metadata field |
|
|
sub prettyprint { |
sub prettyprint { |
Line 545 sub handler {
|
Line 611 sub handler {
|
# Looking for all bombs? |
# Looking for all bombs? |
&report_bombs($r,$uri); |
&report_bombs($r,$uri); |
} elsif ($uri=~/\/portfolio\//) { |
} elsif ($uri=~/\/portfolio\//) { |
|
($resdomain,$resuser)= |
|
(&Apache::lonnet::declutter($uri)=~m|^(\w+)/(\w+)/portfolio|); |
$r->print(&Apache::loncommon::bodytag |
$r->print(&Apache::loncommon::bodytag |
('Edit Portfolio File Information','','','',$resdomain)); |
('Edit Portfolio File Information','','','',$resdomain)); |
&present_editable_metadata($r,$uri,'portfolio'); |
&present_editable_metadata($r,$uri,'portfolio'); |
|
&select_course($r); |
} elsif ($uri=~/^\/\~/) { |
} elsif ($uri=~/^\/\~/) { |
# Construction space |
# Construction space |
$r->print(&Apache::loncommon::bodytag |
$r->print(&Apache::loncommon::bodytag |
Line 883 sub print_dynamic_metadata {
|
Line 951 sub print_dynamic_metadata {
|
return; |
return; |
} |
} |
|
|
|
|
|
|
##################################################### |
##################################################### |
##################################################### |
##################################################### |
### ### |
### ### |
Line 898 sub present_editable_metadata {
|
Line 968 sub present_editable_metadata {
|
my $fn=&Apache::lonnet::filelocation('',$uri); |
my $fn=&Apache::lonnet::filelocation('',$uri); |
$disuri=~s/^\/\~/\/priv\//; |
$disuri=~s/^\/\~/\/priv\//; |
$disuri=~s/\.meta$//; |
$disuri=~s/\.meta$//; |
|
$disuri=~s|^/editupload||; |
my $target=$uri; |
my $target=$uri; |
$target=~s/^\/\~/\/res\/$env{'request.role.domain'}\//; |
$target=~s/^\/\~/\/res\/$env{'request.role.domain'}\//; |
$target=~s/\.meta$//; |
$target=~s/\.meta$//; |
my $bombs=&Apache::lonmsg::retrieve_author_res_msg($target); |
my $bombs=&Apache::lonmsg::retrieve_author_res_msg($target); |
if ($bombs) { |
if ($bombs) { |
|
my $showdel=1; |
if ($env{'form.delmsg'}) { |
if ($env{'form.delmsg'}) { |
if (&Apache::lonmsg::del_url_author_res_msg($target) eq 'ok') { |
if (&Apache::lonmsg::del_url_author_res_msg($target) eq 'ok') { |
$bombs=&mt('Messages deleted.'); |
$bombs=&mt('Messages deleted.'); |
|
$showdel=0; |
} else { |
} else { |
$bombs=&mt('Error deleting messages'); |
$bombs=&mt('Error deleting messages'); |
} |
} |
Line 915 sub present_editable_metadata {
|
Line 988 sub present_editable_metadata {
|
$cleardir=~s/\/[^\/]+$/\//; |
$cleardir=~s/\/[^\/]+$/\//; |
if (&Apache::lonmsg::clear_author_res_msg($cleardir) eq 'ok') { |
if (&Apache::lonmsg::clear_author_res_msg($cleardir) eq 'ok') { |
$bombs=&mt('Messages cleared.'); |
$bombs=&mt('Messages cleared.'); |
|
$showdel=0; |
} else { |
} else { |
$bombs=&mt('Error clearing messages'); |
$bombs=&mt('Error clearing messages'); |
} |
} |
} |
} |
my $del=&mt('Delete Messages for this Resource'); |
my $del=&mt('Delete Messages for this Resource'); |
my $clear=&mt('Clear all Messages in Subdirectory'); |
my $clear=&mt('Clear all Messages in Subdirectory'); |
|
my $goback=&mt('Back to Source File'); |
$r->print(<<ENDBOMBS); |
$r->print(<<ENDBOMBS); |
<h1>$disuri</h1> |
<h1>$disuri</h1> |
<form method="post" name="defaultmeta"> |
<form method="post" name="defaultmeta"> |
|
ENDBOMBS |
|
if ($showdel) { |
|
$r->print(<<ENDDEL); |
<input type="submit" name="delmsg" value="$del" /> |
<input type="submit" name="delmsg" value="$del" /> |
<input type="submit" name="clearmsg" value="$clear" /> |
<input type="submit" name="clearmsg" value="$clear" /> |
<br />$bombs |
ENDDEL |
ENDBOMBS |
} else { |
|
$r->print('<a href="'.$disuri.'" />'.$goback.'</a>'); |
|
} |
|
$r->print('<br />'.$bombs); |
} else { |
} else { |
my $displayfile='Catalog Information for '.$disuri; |
my $displayfile='Catalog Information for '.$disuri; |
if ($disuri=~/\/default$/) { |
if ($disuri=~/\/default$/) { |
Line 941 ENDBOMBS
|
Line 1022 ENDBOMBS
|
%Apache::lonpublisher::metadatakeys=(); |
%Apache::lonpublisher::metadatakeys=(); |
my $result=&Apache::lonnet::getfile($fn); |
my $result=&Apache::lonnet::getfile($fn); |
if ($result == -1){ |
if ($result == -1){ |
$r->print('Creating new '.$fn); |
$r->print('Creating new '.$disuri); |
} else { |
} else { |
&Apache::lonpublisher::metaeval($result); |
&Apache::lonpublisher::metaeval($result); |
} |
} |
Line 952 ENDEDIT
|
Line 1033 ENDEDIT
|
$r->print('<script language="JavaScript">'. |
$r->print('<script language="JavaScript">'. |
&Apache::loncommon::browser_and_searcher_javascript(). |
&Apache::loncommon::browser_and_searcher_javascript(). |
'</script>'); |
'</script>'); |
|
if (($file_type eq 'portfolio') && $env{'form.metacourse'}) { |
|
$file_type = 'restrictedportfolio'; |
|
} |
my %lt=&fieldnames($file_type); |
my %lt=&fieldnames($file_type); |
my $output; |
my $output; |
my @fields; |
my @fields; |
if ($file_type eq 'portfolio') { |
if ($file_type eq 'portfolio') { |
@fields = ('author','title','subject','keywords','abstract','notes','lowestgradelevel', |
@fields = ('author','title','subject','keywords','abstract','notes','lowestgradelevel', |
'highestgradelevel'); |
'highestgradelevel'); |
|
} elsif ($file_type eq 'restrictedportfolio') { |
|
@fields = ('metadata.author','metadata.title','metadata.subject','metadata.keywords','metadata.abstract','metadata.notes','metadata.lowestgradelevel', |
|
'metadata.highestgradelevel'); |
} else { |
} else { |
@fields = ('author','title','subject','keywords','abstract','notes', |
@fields = ('author','title','subject','keywords','abstract','notes', |
'copyright','customdistributionfile','language', |
'copyright','customdistributionfile','language', |
Line 978 ENDEDIT
|
Line 1065 ENDEDIT
|
&prettyinput($_, |
&prettyinput($_, |
$Apache::lonpublisher::metadatafields{$_}, |
$Apache::lonpublisher::metadatafields{$_}, |
'new_'.$_,'defaultmeta').'</p>'); |
'new_'.$_,'defaultmeta').'</p>'); |
|
|
} |
} |
if ($env{'form.store'}) { |
if ($env{'form.store'}) { |
my $mfh; |
my $mfh; |
my $formname='store'; |
my $formname='store'; |
my $file_content; |
my $file_content; |
|
foreach my $meta_field (keys %env) { |
|
if ($meta_field=~m/^form.instmeta_(.+)_(\d+)$/) { |
|
$r->print('Found a field<br>'); |
|
} |
|
if (&Apache::loncommon::get_env_multiple('form.keywords')) { |
|
$Apache::lonpublisher::metadatafields{'coursekeyword'} = |
|
join (', ', &Apache::loncommon::get_env_multiple('form.keywords')); |
|
} |
|
} |
foreach (sort keys %Apache::lonpublisher::metadatafields) { |
foreach (sort keys %Apache::lonpublisher::metadatafields) { |
next if ($_ =~ /\./); |
next if ($_ =~ /\./); |
my $unikey=$_; |
my $unikey=$_; |