version 1.136, 2005/12/09 23:49:45
|
version 1.144, 2005/12/19 21:17:25
|
Line 290 sub fieldnames {
|
Line 290 sub fieldnames {
|
return &Apache::lonlocal::texthash(%fields); |
return &Apache::lonlocal::texthash(%fields); |
} |
} |
|
|
|
sub portfolio_display_uri { |
|
my ($uri)=@_; |
|
$uri =~ s|.*/(portfolio/.*)$|$1|; |
|
my ($res_uri,$meta_uri) = ($uri,$uri); |
|
|
|
if ($uri =~ /\.meta$/) { |
|
$res_uri =~ s/\.meta//; |
|
} else { |
|
$meta_uri .= '.meta'; |
|
} |
|
return ($res_uri,$meta_uri); |
|
} |
|
|
|
sub pre_select_course { |
|
my ($r,$uri) = @_; |
|
my $output; |
|
my $fn=&Apache::lonnet::filelocation('',$uri); |
|
my ($res_uri,$meta_uri) = &portfolio_display_uri($uri); |
|
%Apache::lonpublisher::metadatafields=(); |
|
%Apache::lonpublisher::metadatakeys=(); |
|
my $result=&Apache::lonnet::getfile($fn); |
|
if ($result == -1){ |
|
$r->print(&mt('Creating new file [_1]'),$meta_uri); |
|
} else { |
|
&Apache::lonpublisher::metaeval($result); |
|
} |
|
$r->print('<hr /><form method="post" action="" >'); |
|
$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').'">'); |
|
$r->print('</form>'); |
|
return; |
|
} |
sub select_course { |
sub select_course { |
my ($r)=@_; |
|
my %courses; |
my %courses; |
|
my $output; |
|
my $selected; |
foreach my $key (keys (%env)) { |
foreach my $key (keys (%env)) { |
if ($key =~ m/\.metadata\./) { |
if ($key =~ m/\.metadata\./) { |
$key =~ m/^course\.(.+)(\.metadata.+$)/; |
$key =~ m/^course\.(.+)(\.metadata.+$)/; |
Line 302 sub select_course {
|
Line 337 sub select_course {
|
$courses{$coursekey} = $value; |
$courses{$coursekey} = $value; |
} |
} |
} |
} |
$r->print('<h3>Associate resource with a course</h3><br />'); |
&Apache::lonnet::logthis('the restricted is'.$Apache::lonpublisher::metadatafields{'courserestricted'}); |
$r->print('<form action="" method="post">'); |
|
$r->print('Select course <br />'); |
|
$r->print('<select name="metacourse" >'); |
|
my $meta_not_found = 1; |
my $meta_not_found = 1; |
|
if ($Apache::lonpublisher::metadatafields{'courserestricted'} eq 'none') { |
|
$selected = ' SELECTED '; |
|
} else { |
|
$selected = ''; |
|
} |
|
$output .= '<select name="new_courserestricted" >'; |
|
$output .= '<option value="none" '.$selected.'>None</option>'; |
foreach my $key (keys (%courses)) { |
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" >'); |
|
} |
|
$key =~ m/(^.+)\.description$/; |
$key =~ m/(^.+)\.description$/; |
$r->print('<option value="'.$1.'">'); |
if ($Apache::lonpublisher::metadatafields{'courserestricted'} eq $1) { |
$r->print($courses{$key}); |
$selected = ' SELECTED '; |
$r->print('</option>'); |
} else { |
} |
$selected = ''; |
unless ($meta_not_found) { |
} |
$r->print('</select><br />'); |
$output .= '<option value="'.$1.'"'.$selected.'>'; |
$r->print('<input type="submit" value="Associate" />'); |
$output .= $courses{$key}; |
$r->print('</form>'); |
$output .= '</option>'; |
} |
} |
return 'ok'; |
$output .= '</select><br />'; |
|
return ($output); |
} |
} |
# Pretty printing of metadata field |
# Pretty printing of metadata field |
|
|
Line 516 sub prettyinput {
|
Line 549 sub prettyinput {
|
$cur_values_stu = $value; |
$cur_values_stu = $value; |
} |
} |
if ($type eq 'courserestricted') { |
if ($type eq 'courserestricted') { |
return ('<input type="hidden" name="new_courserestricted" value="'.$course_key.'" />'); |
return (&select_course()); |
|
# return ('<input type="hidden" name="new_courserestricted" value="'.$course_key.'" />'); |
} |
} |
if (($type eq 'keywords') || ($type eq 'subject') |
if (($type eq 'keywords') || ($type eq 'subject') |
|| ($type eq 'author')||($type eq 'notes') |
|| ($type eq 'author')||($type eq 'notes') |
Line 604 sub prettyinput {
|
Line 638 sub prettyinput {
|
&relatedfield(0,$relatedsearchflag,$relatedsep); |
&relatedfield(0,$relatedsearchflag,$relatedsep); |
} |
} |
if ($type eq 'courserestricted') { |
if ($type eq 'courserestricted') { |
return ('<input type="hidden" name="new_courserestricted" value="'.$course_key.'" />'); |
return (&select_course()); |
|
#return ('<input type="hidden" name="new_courserestricted" value="'.$course_key.'" />'); |
} |
} |
|
|
# Dates |
# Dates |
Line 648 sub handler {
|
Line 683 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)= |
($resdomain,$resuser)= |
(&Apache::lonnet::declutter($uri)=~m|^(\w+)/(\w+)/portfolio|); |
(&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'); |
if ($env{'form.store'}) { |
&select_course($r); |
&present_editable_metadata($r,$uri,'portfolio'); |
|
} else { |
|
&pre_select_course($r,$uri); |
|
} |
} elsif ($uri=~/^\/\~/) { |
} elsif ($uri=~/^\/\~/) { |
# Construction space |
# Construction space |
$r->print(&Apache::loncommon::bodytag |
$r->print(&Apache::loncommon::bodytag |
Line 1005 sub present_editable_metadata {
|
Line 1043 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 $meta_uri = $disuri; |
|
if ($disuri =~ m|/portfolio/|) { |
|
($disuri, $meta_uri) = &portfolio_display_uri($disuri); |
|
} |
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$//; |
Line 1059 ENDDEL
|
Line 1100 ENDDEL
|
%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 '.$disuri); |
$r->print(&mt('Creating new file [_1]'),$meta_uri); |
} else { |
} else { |
&Apache::lonpublisher::metaeval($result); |
&Apache::lonpublisher::metaeval($result); |
} |
} |
Line 1075 ENDEDIT
|
Line 1116 ENDEDIT
|
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','standards','courserestricted'); |
'highestgradelevel','standards'); |
} else { |
} else { |
@fields = ('author','title','subject','keywords','abstract','notes', |
@fields = ('author','title','subject','keywords','abstract','notes', |
'copyright','customdistributionfile','language', |
'copyright','customdistributionfile','language', |
Line 1083 ENDEDIT
|
Line 1124 ENDEDIT
|
'lowestgradelevel','highestgradelevel','sourceavail','sourcerights', |
'lowestgradelevel','highestgradelevel','sourceavail','sourcerights', |
'obsolete','obsoletereplacement'); |
'obsolete','obsoletereplacement'); |
} |
} |
my $metacourse; |
if ((! $Apache::lonpublisher::metadatafields{'courserestricted'}) && |
if ($env{'form.metacourse'} ) { |
(! $env{'form.new_courserestricted'})) { |
$Apache::lonpublisher::metadatafields{'courserestricted'} = $env{'form.metacourse'}; |
$Apache::lonpublisher::metadatafields{'courserestricted'}= |
$metacourse = $env{'form.metacourse'}; |
'none'; |
} else { |
} elsif ($env{'form.new_courserestricted'}) { |
if (! $Apache::lonpublisher::metadatafields{'courserestricted'}) { |
$Apache::lonpublisher::metadatafields{'courserestricted'}= |
$Apache::lonpublisher::metadatafields{'courserestricted'}= |
$env{'form.new_courserestricted'}; |
'none'; |
} |
$metacourse = 'none'; |
|
} else { |
|
$metacourse = $Apache::lonpublisher::metadatafields{'courserestricted'}; |
|
} |
|
} |
|
if (! $Apache::lonpublisher::metadatafields{'copyright'}) { |
if (! $Apache::lonpublisher::metadatafields{'copyright'}) { |
$Apache::lonpublisher::metadatafields{'copyright'}= |
$Apache::lonpublisher::metadatafields{'copyright'}= |
'default'; |
'default'; |
} |
} |
if ($metacourse ne 'none') { |
if ($Apache::lonpublisher::metadatafields{'courserestricted'} ne 'none') { |
$r->print('Using: <strong> '.$env{$metacourse.".description"}."</strong> metadata framework<br />"); |
$r->print(&mt('Associated with course [_1]','<strong>'.$env{$Apache::lonpublisher::metadatafields{'courserestricted'}.".description"}. |
|
'</strong>').'<br />'); |
|
} else { |
|
$r->print("This resource is not associated with a course.<br />"); |
} |
} |
foreach my $field_name(@fields) { |
foreach my $field_name (@fields) { |
|
|
if (defined($env{'form.new_'.$field_name})) { |
if (defined($env{'form.new_'.$field_name})) { |
$Apache::lonpublisher::metadatafields{$field_name}= |
$Apache::lonpublisher::metadatafields{$field_name}= |
join(',',&Apache::loncommon::get_env_multiple('form.new_'.$field_name)); |
join(',',&Apache::loncommon::get_env_multiple('form.new_'.$field_name)); |
} |
} |
if ($metacourse ne 'none') { |
if ($Apache::lonpublisher::metadatafields{'courserestricted'} ne 'none') { |
# handle restrictions here |
# handle restrictions here |
if ($env{$metacourse.'.metadata.'.$field_name.'.options'} =~ m/active/){ |
if (($env{$Apache::lonpublisher::metadatafields{'courserestricted'}.'.metadata.'.$field_name.'.options'} =~ m/active/) || |
$output.=('<p>'.$lt{$field_name}.': '. |
($field_name eq 'courserestricted')){ |
|
$output.=("\n".'<p>'.$lt{$field_name}.': '. |
&prettyinput($field_name, |
&prettyinput($field_name, |
$Apache::lonpublisher::metadatafields{$field_name}, |
$Apache::lonpublisher::metadatafields{$field_name}, |
'new_'.$field_name,'defaultmeta',undef,undef,undef,undef,$metacourse).'</p>'); |
'new_'.$field_name,'defaultmeta', |
} elsif ($field_name eq 'courserestricted') { |
undef,undef,undef,undef, |
$output.=( |
$Apache::lonpublisher::metadatafields{'courserestricted'}).'</p>'."\n"); |
&prettyinput($field_name, |
|
$Apache::lonpublisher::metadatafields{$field_name}, |
|
'new_'.$field_name,'defaultmeta',undef,undef,undef,undef,$metacourse)); |
|
} |
} |
} else { |
} else { |
if ($field_name ne 'courserestricted') { |
|
$output.=('<p>'.$lt{$field_name}.': '. |
$output.=('<p>'.$lt{$field_name}.': '. |
&prettyinput($field_name, |
&prettyinput($field_name, |
$Apache::lonpublisher::metadatafields{$field_name}, |
$Apache::lonpublisher::metadatafields{$field_name}, |
'new_'.$field_name,'defaultmeta').'</p>'); |
'new_'.$field_name,'defaultmeta').'</p>'); |
} else { |
|
$output.=&prettyinput($field_name, |
|
$Apache::lonpublisher::metadatafields{$field_name}, |
|
'new_'.$field_name,'defaultmeta'); |
|
} |
|
} |
} |
} |
} |
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 (&Apache::loncommon::get_env_multiple('form.new_keywords')) { |
if (&Apache::loncommon::get_env_multiple('form.new_keywords')) { |
$Apache::lonpublisher::metadatafields{'keywords'} = |
$Apache::lonpublisher::metadatafields{'keywords'} = |
join (',', &Apache::loncommon::get_env_multiple('form.new_keywords')); |
join (',', &Apache::loncommon::get_env_multiple('form.new_keywords')); |
} |
} |
|
} |
foreach (sort keys %Apache::lonpublisher::metadatafields) { |
foreach (sort keys %Apache::lonpublisher::metadatafields) { |
next if ($_ =~ /\./); |
next if ($_ =~ /\./); |
my $unikey=$_; |
my $unikey=$_; |
$unikey=~/^([A-Za-z]+)/; |
$unikey=~/^([A-Za-z]+)/; |
my $tag=$1; |
my $tag=$1; |
$tag=~tr/A-Z/a-z/; |
$tag=~tr/A-Z/a-z/; |
$file_content.= "\n\<$tag"; |
$file_content.= "\n\<$tag"; |
foreach (split(/\,/, |
foreach (split(/\,/, |
$Apache::lonpublisher::metadatakeys{$unikey}) |
$Apache::lonpublisher::metadatakeys{$unikey}) |
) { |
) { |
my $value= |
my $value= |
$Apache::lonpublisher::metadatafields{$unikey.'.'.$_}; |
$Apache::lonpublisher::metadatafields{$unikey.'.'.$_}; |
$value=~s/\"/\'\'/g; |
$value=~s/\"/\'\'/g; |
$file_content.=' '.$_.'="'.$value.'"' ; |
$file_content.=' '.$_.'="'.$value.'"' ; |
# print $mfh ' '.$_.'="'.$value.'"'; |
# print $mfh ' '.$_.'="'.$value.'"'; |
} |
} |
$file_content.= '>'. |
$file_content.= '>'. |
&HTML::Entities::encode |
&HTML::Entities::encode |
($Apache::lonpublisher::metadatafields{$unikey}, |
($Apache::lonpublisher::metadatafields{$unikey}, |
'<>&"'). |
'<>&"'). |
'</'.$tag.'>'; |
'</'.$tag.'>'; |
} |
} |
&Apache::lonnet::logthis(" file ".$file_content); |
if ($fn =~ /\/portfolio\//) { |
if ($fn =~ m|/portfolio/|) { |
$fn =~ /\/portfolio\/(.*)$/; |
my ($path, $new_fn) = ($fn =~ m|/(portfolio.*)/([^/]*)$|); |
my $new_fn = '/'.$1; |
$env{'form.'.$formname}=$file_content."\n"; |
$env{'form.'.$formname}=$file_content."\n"; |
$env{'form.'.$formname.'.filename'}=$new_fn; |
$env{'form.'.$formname.'.filename'}=$new_fn; |
my $result =&Apache::lonnet::userfileupload($formname,'', |
&Apache::lonnet::userfileupload('uploaddoc','', |
$path); |
'portfolio'.$env{'form.currentpath'}); |
|
if (&Apache::lonnet::userfileupload($formname,'','portfolio') eq 'error: no uploaded file') { |
if ($result =~ /(error|notfound)/) { |
$r->print('<p><font color="red">'. |
$r->print('<p><font color="red">'. |
&mt('Could not write metadata').', '. |
&mt('Could not write metadata').', '. |
&mt('FAIL').'</font></p>'); |
&mt('FAIL').'</font></p>'); |
} else { |
} else { |
$r->print('<p><font color="blue">'.&mt('Wrote Metadata'). |
|
' '.&Apache::lonlocal::locallocaltime(time). |
|
'</font></p>'); |
|
} |
|
} else { |
|
if (! ($mfh=Apache::File->new('>'.$fn))) { |
|
$r->print('<p><font color="red">'. |
|
&mt('Could not write metadata').', '. |
|
&mt('FAIL').'</font></p>'); |
|
} else { |
|
print $mfh $file_content; |
|
$r->print('<p><font color="blue">'.&mt('Wrote Metadata'). |
$r->print('<p><font color="blue">'.&mt('Wrote Metadata'). |
' '.&Apache::lonlocal::locallocaltime(time). |
' '.&Apache::lonlocal::locallocaltime(time). |
'</font></p>'); |
'</font></p>'); |
} |
} |
} |
} else { |
} |
if (! ($mfh=Apache::File->new('>'.$fn))) { |
|
$r->print('<p><font color="red">'. |
|
&mt('Could not write metadata').', '. |
|
&mt('FAIL').'</font></p>'); |
|
} else { |
|
print $mfh $file_content; |
|
$r->print('<p><font color="blue">'.&mt('Wrote Metadata'). |
|
' '.&Apache::lonlocal::locallocaltime(time). |
|
'</font></p>'); |
|
} |
|
} |
|
} |
|
|
$r->print($output.'<br /><input type="submit" name="store" value="'. |
$r->print($output.'<br /><input type="submit" name="store" value="'. |
&mt('Store Catalog Information').'">'); |
&mt('Store Catalog Information').'">'); |
|
|
} |
} |
$r->print('</form>'); |
$r->print('</form>'); |
|
|
return; |
return; |
} |
} |
|
|