version 1.128, 2005/11/18 23:47:33
|
version 1.169, 2006/08/16 18:02:01
|
Line 39 use Apache::lonpublisher;
|
Line 39 use Apache::lonpublisher;
|
use Apache::lonlocal; |
use Apache::lonlocal; |
use Apache::lonmysql; |
use Apache::lonmysql; |
use Apache::lonmsg; |
use Apache::lonmsg; |
|
use lib '/home/httpd/lib/perl/'; |
|
use LONCAPA; |
|
|
|
|
############################################################ |
############################################################ |
Line 71 sub get_dynamic_metadata_from_sql {
|
Line 73 sub get_dynamic_metadata_from_sql {
|
if (! defined($authordom) || ! defined($author)) { |
if (! defined($authordom) || ! defined($author)) { |
return (); |
return (); |
} |
} |
my @Fields = ('url','count','course', |
my $query = 'SELECT * FROM metadata WHERE url LIKE "'.$url.'%"'; |
'goto','goto_list', |
|
'comefrom','comefrom_list', |
|
'sequsage','sequsage_list', |
|
'stdno','stdno_list', |
|
'dependencies', |
|
'avetries','avetries_list', |
|
'difficulty','difficulty_list', |
|
'disc','disc_list', |
|
'clear','technical','correct', |
|
'helpful','depth'); |
|
# |
|
my $query = 'SELECT '.join(',',@Fields). |
|
' FROM metadata WHERE url LIKE "'.$url.'%"'; |
|
my $server = &Apache::lonnet::homeserver($author,$authordom); |
my $server = &Apache::lonnet::homeserver($author,$authordom); |
my $reply = &Apache::lonnet::metadata_query($query,undef,undef, |
my $reply = &Apache::lonnet::metadata_query($query,undef,undef, |
,[$server]); |
,[$server]); |
Line 106 sub get_dynamic_metadata_from_sql {
|
Line 95 sub get_dynamic_metadata_from_sql {
|
while (my $result = <$fh>) { |
while (my $result = <$fh>) { |
chomp($result); |
chomp($result); |
next if (! $result); |
next if (! $result); |
my @Data = |
my %hash=&LONCAPA::lonmetadata::metadata_col_to_hash(map { &unescape($_) } split(/\,/,$result)); |
map { |
foreach my $key (keys(%hash)) { |
&Apache::lonnet::unescape($_); |
$ReturnHash{$hash{'url'}}->{$key}=$hash{$key}; |
} split(',',$result); |
|
my $url = $Data[0]; |
|
for (my $i=0;$i<=$#Fields;$i++) { |
|
$ReturnHash{$url}->{$Fields[$i]}=$Data[$i]; |
|
} |
} |
} |
} |
$finished = 1; |
$finished = 1; |
Line 185 sub authordisplay {
|
Line 170 sub authordisplay {
|
my ($aname,$adom)=@_; |
my ($aname,$adom)=@_; |
return &Apache::loncommon::aboutmewrapper |
return &Apache::loncommon::aboutmewrapper |
(&Apache::loncommon::plainname($aname,$adom), |
(&Apache::loncommon::plainname($aname,$adom), |
$aname,$adom,'preview').' <tt>['.$aname.'@'.$adom.']</tt>'; |
$aname,$adom,'preview').' <tt>['.$aname.':'.$adom.']</tt>'; |
} |
} |
|
|
# Pretty display |
# Pretty display |
Line 243 sub fieldnames {
|
Line 228 sub fieldnames {
|
'authorspace' => 'Author Space', |
'authorspace' => 'Author Space', |
'modifyinguser' => 'Last Modifying User', |
'modifyinguser' => 'Last Modifying User', |
'subject' => 'Subject', |
'subject' => 'Subject', |
|
'standards' => 'Standards', |
'keywords' => 'Keyword(s)', |
'keywords' => 'Keyword(s)', |
'notes' => 'Notes', |
'notes' => 'Notes', |
'abstract' => 'Abstract', |
'abstract' => 'Abstract', |
'lowestgradelevel' => 'Lowest Grade Level', |
'lowestgradelevel' => 'Lowest Grade Level', |
'highestgradelevel' => 'Highest Grade Level', |
'highestgradelevel' => 'Highest Grade Level'); |
'courserestricted' => 'Course Restricting Metadata'); |
|
|
if (! defined($file_type) || $file_type ne 'portfolio') { |
|
%fields = |
|
(%fields, |
|
'courserestricted' => 'Course Restricting Metadata'); |
|
} |
|
|
if (! defined($file_type) || $file_type ne 'portfolio') { |
if (! defined($file_type) || $file_type ne 'portfolio') { |
%fields = |
%fields = |
(%fields, |
(%fields, |
'domain' => 'Domain', |
'domain' => 'Domain', |
'standards' => 'Standards', |
|
'mime' => 'MIME Type', |
'mime' => 'MIME Type', |
'language' => 'Language', |
'language' => 'Language', |
'creationdate' => 'Creation Date', |
'creationdate' => 'Creation Date', |
Line 284 sub fieldnames {
|
Line 274 sub fieldnames {
|
'stdno' => 'Total number of students who have worked on this problem', |
'stdno' => 'Total number of students who have worked on this problem', |
'difficulty' => 'Degree of difficulty', |
'difficulty' => 'Degree of difficulty', |
'disc' => 'Degree of discrimination', |
'disc' => 'Degree of discrimination', |
'dependencies' => 'Resources used by this resource', |
'dependencies' => 'Resources used by this resource', |
); |
); |
} |
} |
return &Apache::lonlocal::texthash(%fields); |
return &Apache::lonlocal::texthash(%fields); |
} |
} |
|
|
|
sub portfolio_linked_path { |
|
my ($path,$group,$port_path) = @_; |
|
|
|
my $start = 'portfolio'; |
|
if ($group) { |
|
$start = "groups/$group/".$start; |
|
} |
|
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 .= '/'; |
|
my %anchor_fields = ( |
|
'selectfile' => $dir, |
|
'currentpath' => $fullpath |
|
); |
|
$result .= &Apache::portfolio::make_anchor($port_path,\%anchor_fields,$dir); |
|
} |
|
$result .= "/$filename"; |
|
return $result; |
|
} |
|
|
|
sub get_port_path_and_group { |
|
my ($uri)=@_; |
|
|
|
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
|
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
|
|
|
my ($port_path,$group); |
|
if ($uri =~ m{^/editupload/\Q$cdom\E/\Q$cnum\E/groups/}) { |
|
$group = (split('/',$uri))[5]; |
|
$port_path = '/adm/coursegrp_portfolio'; |
|
} else { |
|
$port_path = '/adm/portfolio'; |
|
} |
|
if ($env{'form.group'} ne $group) { |
|
$env{'form.group'} = $group; |
|
} |
|
return ($port_path,$group); |
|
} |
|
|
|
sub portfolio_display_uri { |
|
my ($uri,$as_links)=@_; |
|
|
|
my ($port_path,$group) = &get_port_path_and_group($uri); |
|
|
|
$uri =~ s|.*/(portfolio/.*)$|$1|; |
|
my ($res_uri,$meta_uri) = ($uri,$uri); |
|
if ($uri =~ /\.meta$/) { |
|
$res_uri =~ s/\.meta//; |
|
} else { |
|
$meta_uri .= '.meta'; |
|
} |
|
|
|
my ($path) = ($res_uri =~ m|^portfolio(.*/)[^/]*$|); |
|
if ($as_links) { |
|
$res_uri = &portfolio_linked_path($res_uri,$group,$port_path); |
|
$meta_uri = &portfolio_linked_path($meta_uri,$group,$port_path); |
|
} |
|
return ($res_uri,$meta_uri,$path); |
|
} |
|
|
|
sub pre_select_course { |
|
my ($r,$uri) = @_; |
|
my $output; |
|
my $fn=&Apache::lonnet::filelocation('',$uri); |
|
my ($res_uri,$meta_uri,$path) = &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('<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); |
|
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.'" />'. |
|
$group_input. |
|
'<input type="submit" name="cancel" value="'.&mt('Cancel').'" />'. |
|
'</form>'); |
|
|
|
return; |
|
} |
sub select_course { |
sub select_course { |
my ($r)=@_; |
my $output=$/; |
|
my $current_restriction= |
|
$Apache::lonpublisher::metadatafields{'courserestricted'}; |
|
my $selected = ($current_restriction eq 'none' ? 'selected="selected"' |
|
: ''); |
|
|
|
$output .= '<select name="new_courserestricted" >'; |
|
$output .= '<option value="none" '.$selected.'>'. |
|
&mt('None').'</option>'.$/; |
my %courses; |
my %courses; |
foreach my $key (keys (%env)) { |
foreach my $key (keys(%env)) { |
if ($key =~ m/\.metadata\./) { |
if ($key !~ m/^course\.(.+)\.description$/) { next; } |
$key =~ m/^course\.(.+)(\.metadata.+$)/; |
my $cid = $1; |
my $course = $1; |
if ($env{$key} !~ /\S/) { next; } |
my $coursekey = 'course.'.$course.'.description'; |
$courses{$key} = $cid; |
my $value = $env{$coursekey}; |
} |
$courses{$coursekey} = $value; |
foreach my $key (sort { lc($env{$a}) cmp lc($env{$b}) } (keys(%courses))) { |
} |
my $cid = 'course.'.$courses{$key}; |
} |
my $selected = ($current_restriction eq $cid ? 'selected="selected"' |
$r->print('<h3>Course Related Meta-Data</h3><br />'); |
: ''); |
$r->print('<form action="" method="post">'); |
if ($env{$key} !~ /\S/) { next; } |
$r->print('Select course restrictions<br />'); |
$output .= '<option value="'.$cid.'" '.$selected.'>'; |
$r->print('<select name="metacourse" >'); |
$output .= $env{$key}; |
my $meta_not_found = 1; |
$output .= '</option>'.$/; |
foreach my $key (keys (%courses)) { |
$selected = ''; |
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$/; |
|
$r->print('<option value="'.$1.'">'); |
|
$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'; |
$output .= '</select><br />'; |
|
return ($output); |
} |
} |
# Pretty printing of metadata field |
# Pretty printing of metadata field |
|
|
Line 387 sub prettyprint {
|
Line 473 sub prettyprint {
|
($type eq 'comefrom_list') || |
($type eq 'comefrom_list') || |
($type eq 'sequsage_list') || |
($type eq 'sequsage_list') || |
($type eq 'dependencies')) { |
($type eq 'dependencies')) { |
return '<ul><font size="-1">'.join("\n",map { |
return '<font size="-1"><ul>'.join("\n",map { |
my $url = &Apache::lonnet::clutter($_); |
my $url = &Apache::lonnet::clutter($_); |
my $title = &Apache::lonnet::gettitle($url); |
my $title = &Apache::lonnet::gettitle($url); |
if ($title eq '') { |
if ($title eq '') { |
Line 424 sub prettyprint {
|
Line 510 sub prettyprint {
|
# List of courses |
# List of courses |
if ($type=~/\_list/) { |
if ($type=~/\_list/) { |
my @Courses = split(/\s*\,\s*/,$value); |
my @Courses = split(/\s*\,\s*/,$value); |
my $Str; |
my $Str='<font size="-1"><ul>'; |
foreach my $course (@Courses) { |
foreach my $course (@Courses) { |
my %courseinfo = &Apache::lonnet::coursedescription($course); |
my %courseinfo = |
|
&Apache::lonnet::coursedescription($course, |
|
{'one_time' => 1}); |
if (! exists($courseinfo{'num'}) || $courseinfo{'num'} eq '') { |
if (! exists($courseinfo{'num'}) || $courseinfo{'num'} eq '') { |
next; |
next; |
} |
} |
if ($Str ne '') { $Str .= '<br />'; } |
$Str .= '<li><a href="/public/'.$courseinfo{'domain'}.'/'. |
$Str .= '<a href="/public/'.$courseinfo{'domain'}.'/'. |
|
$courseinfo{'num'}.'/syllabus" target="preview">'. |
$courseinfo{'num'}.'/syllabus" target="preview">'. |
$courseinfo{'description'}.'</a>'; |
$courseinfo{'description'}.'</a></li>'; |
} |
} |
return $Str; |
return $Str.'</ul></font>'; |
} |
} |
# No pretty print found |
# No pretty print found |
return $value; |
return $value; |
Line 484 sub prettyinput {
|
Line 571 sub prettyinput {
|
$size = 80; |
$size = 80; |
} |
} |
my $output; |
my $output; |
if (defined($course_key)) { |
if (defined($course_key) |
|
&& exists($env{$course_key.'.metadata.'.$type.'.options'})) { |
my $stu_add; |
my $stu_add; |
my $only_one; |
my $only_one; |
my %meta_options; |
my %meta_options; |
my @cur_values_inst; |
my @cur_values_inst; |
my $cur_values_stu; |
my $cur_values_stu; |
my $values = $env{$course_key.'.metadata.'.$_.'.values'}; |
my $values = $env{$course_key.'.metadata.'.$type.'.values'}; |
if ($env{$course_key.'.metadata.'.$_.'.options'} =~ m/stuadd/) { |
if ($env{$course_key.'.metadata.'.$type.'.options'} =~ m/stuadd/) { |
$stu_add = 'true'; |
$stu_add = 'true'; |
} |
} |
if ($env{$course_key.'.metadata.'.$_.'.options'} =~ m/onlyone/) { |
if ($env{$course_key.'.metadata.'.$type.'.options'} =~ m/onlyone/) { |
$only_one = 'true'; |
$only_one = 'true'; |
} |
} |
# need to take instructor values out of list where instructor and student |
# need to take instructor values out of list where instructor and student |
# values may be mixed. |
# values may be mixed. |
if ($values && $stu_add) { |
if ($values) { |
foreach (split(/,/,$values)) { |
foreach my $item (split(/,/,$values)) { |
$_ =~ s/^\s+//; |
$item =~ s/^\s+//; |
$meta_options{$_} = $_; |
$meta_options{$item} = $item; |
} |
} |
foreach (split(/,/,$value)) { |
foreach my $item (split(/,/,$value)) { |
$_ =~ s/^\s+//; |
$item =~ s/^\s+//; |
if ($meta_options{$_}) { |
if ($meta_options{$item}) { |
push(@cur_values_inst,$_); |
push(@cur_values_inst,$item); |
} else { |
} else { |
$cur_values_stu .= $_.','; |
$cur_values_stu .= $item.','; |
} |
} |
} |
} |
} |
} else { |
if ($type eq 'author') { |
$cur_values_stu = $value; |
return |
|
'<input type="text" name="'.$fieldname.'" size="'.$size.'" '. |
|
'value="'.$value.'" />'. |
|
&relatedfield(1,$relatedsearchflag,$relatedsep,$fieldname, |
|
$relatedvalue); |
|
|
|
} |
} |
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 'authorspace') { |
|
} |
|
if ($type eq 'modifyinguser') { |
|
} |
} |
if ($type eq 'subject') { |
if (($type eq 'keywords') || ($type eq 'subject') |
} |
|| ($type eq 'author')||($type eq 'notes') |
if ($type eq 'keywords') { |
|| ($type eq 'abstract')|| ($type eq 'title')|| ($type eq 'standards')) { |
if ($only_one) { |
if ($values) { |
$output .= (&Apache::loncommon::select_form($value,'new_keywords',%meta_options)); |
if ($only_one) { |
} else { |
$output .= (&Apache::loncommon::select_form($cur_values_inst[0],'new_'.$type,%meta_options)); |
$output .= (&Apache::loncommon::multiple_select_form('new_keywords',\@cur_values_inst,undef,\%meta_options)); |
} else { |
|
$output .= (&Apache::loncommon::multiple_select_form('new_'.$type,\@cur_values_inst,undef,\%meta_options)); |
|
} |
} |
} |
if ($stu_add) { |
if ($stu_add) { |
$output .= '<input type="text" name="'.$fieldname.'" size="'.$size.'" '. |
$output .= '<input type="text" name="'.$fieldname.'" size="'.$size.'" '. |
Line 544 sub prettyinput {
|
Line 625 sub prettyinput {
|
} |
} |
return ($output); |
return ($output); |
} |
} |
if ($type eq 'notes') { |
|
} |
|
if ($type eq 'abstract') { |
|
} |
|
|
|
if (($type eq 'lowestgradelevel') || |
if (($type eq 'lowestgradelevel') || |
($type eq 'highestgradelevel')) { |
($type eq 'highestgradelevel')) { |
return &Apache::loncommon::select_level_form($value,$fieldname). |
return &Apache::loncommon::select_level_form($value,$fieldname). |
Line 616 sub prettyinput {
|
Line 692 sub prettyinput {
|
",'rights')\">".&mt('Select').'</a>'. |
",'rights')\">".&mt('Select').'</a>'. |
&relatedfield(0,$relatedsearchflag,$relatedsep); |
&relatedfield(0,$relatedsearchflag,$relatedsep); |
} |
} |
|
if ($type eq 'courserestricted') { |
|
return (&select_course()); |
|
#return ('<input type="hidden" name="new_courserestricted" value="'.$course_key.'" />'); |
|
} |
|
|
# Dates |
# Dates |
if (($type eq 'creationdate') || |
if (($type eq 'creationdate') || |
($type eq 'lastrevisiondate')) { |
($type eq 'lastrevisiondate')) { |
Line 639 sub prettyinput {
|
Line 720 sub prettyinput {
|
sub handler { |
sub handler { |
my $r=shift; |
my $r=shift; |
# |
# |
|
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, |
|
['currentpath']); |
my $uri=$r->uri; |
my $uri=$r->uri; |
# |
# |
# Set document type |
# Set document type |
Line 648 sub handler {
|
Line 731 sub handler {
|
# |
# |
my ($resdomain,$resuser)= |
my ($resdomain,$resuser)= |
(&Apache::lonnet::declutter($uri)=~/^(\w+)\/(\w+)\//); |
(&Apache::lonnet::declutter($uri)=~/^(\w+)\/(\w+)\//); |
my $html=&Apache::lonxml::xmlbegin(); |
|
$r->print($html.'<head><title>'. |
|
'Catalog Information'. |
|
'</title></head>'); |
|
if ($uri=~m:/adm/bombs/(.*)$:) { |
if ($uri=~m:/adm/bombs/(.*)$:) { |
$r->print(&Apache::loncommon::bodytag('Error Messages')); |
$r->print(&Apache::loncommon::start_page('Error Messages')); |
# Looking for all bombs? |
# Looking for all bombs? |
&report_bombs($r,$uri); |
&report_bombs($r,$uri); |
} elsif ($uri=~/\/portfolio\//) { |
} elsif ($uri=~m|^/editupload/[^/]+/[^/]+/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::start_page('Edit Portfolio File Catalog Information', |
('Edit Portfolio File Information','','','',$resdomain)); |
undef, |
&present_editable_metadata($r,$uri,'portfolio'); |
{'domain' => $resdomain,})); |
&select_course($r); |
if ($env{'form.store'}) { |
} elsif ($uri=~/^\/\~/) { |
&present_editable_metadata($r,$uri,'portfolio'); |
|
} else { |
|
&pre_select_course($r,$uri); |
|
} |
|
} elsif ($uri=~m|^/~|) { |
# Construction space |
# Construction space |
$r->print(&Apache::loncommon::bodytag |
$r->print(&Apache::loncommon::start_page('Edit Catalog nformation', |
('Edit Catalog Information','','','',$resdomain)); |
undef, |
|
{'domain' => $resdomain,})); |
&present_editable_metadata($r,$uri); |
&present_editable_metadata($r,$uri); |
} else { |
} else { |
$r->print(&Apache::loncommon::bodytag |
$r->print(&Apache::loncommon::start_page('Catalog Information', |
('Catalog Information','','','',$resdomain)); |
undef, |
|
{'domain' => $resdomain,})); |
&present_uneditable_metadata($r,$uri); |
&present_uneditable_metadata($r,$uri); |
} |
} |
$r->print('</body></html>'); |
$r->print(&Apache::loncommon::end_page()); |
return OK; |
return OK; |
} |
} |
|
|
Line 727 ENDCLEAR
|
Line 812 ENDCLEAR
|
sub present_uneditable_metadata { |
sub present_uneditable_metadata { |
my ($r,$uri) = @_; |
my ($r,$uri) = @_; |
# |
# |
|
my $uploaded = ($uri =~ m|/uploaded/|); |
my %content=(); |
my %content=(); |
# Read file |
# Read file |
foreach (split(/\,/,&Apache::lonnet::metadata($uri,'keys'))) { |
foreach (split(/\,/,&Apache::lonnet::metadata($uri,'keys'))) { |
Line 737 sub present_uneditable_metadata {
|
Line 823 sub present_uneditable_metadata {
|
my ($thisversion)=($uri=~/\.(\d+)\.(\w+)\.meta$/); |
my ($thisversion)=($uri=~/\.(\d+)\.(\w+)\.meta$/); |
$uri=~s/\.meta$//; |
$uri=~s/\.meta$//; |
my $disuri=&Apache::lonnet::clutter($uri); |
my $disuri=&Apache::lonnet::clutter($uri); |
|
$disuri=~s/^\/adm\/wrapper//; |
# version |
# version |
my $currentversion=&Apache::lonnet::getversion($disuri); |
|
my $versiondisplay=''; |
my $versiondisplay=''; |
if ($thisversion) { |
if (!$uploaded) { |
$versiondisplay=&mt('Version').': '.$thisversion. |
my $currentversion=&Apache::lonnet::getversion($disuri); |
' ('.&mt('most recent version').': '. |
if ($thisversion) { |
($currentversion>0 ? |
$versiondisplay=&mt('Version').': '.$thisversion. |
$currentversion : |
' ('.&mt('most recent version').': '. |
&mt('information not available')).')'; |
($currentversion>0 ? |
} else { |
$currentversion : |
$versiondisplay='Version: '.$currentversion; |
&mt('information not available')).')'; |
|
} else { |
|
$versiondisplay='Version: '.$currentversion; |
|
} |
} |
} |
# crumbify displayed URL uri target prefix form size |
# crumbify displayed URL uri target prefix form size |
$disuri=&Apache::lonhtmlcommon::crumbs($disuri,undef, undef, undef,'+1'); |
$disuri=&Apache::lonhtmlcommon::crumbs($disuri,undef, undef, undef,'+1'); |
Line 767 sub present_uneditable_metadata {
|
Line 856 sub present_uneditable_metadata {
|
if (! defined($title)) { |
if (! defined($title)) { |
$title = 'Untitled Resource'; |
$title = 'Untitled Resource'; |
} |
} |
foreach ('title', |
my @fields; |
'author', |
if ($uploaded) { |
'subject', |
@fields = ('title','author','subject','keywords','notes','abstract', |
'keywords', |
'lowestgradelevel','highestgradelevel','standards','mime', |
'notes', |
'owner'); |
'abstract', |
} else { |
'lowestgradelevel', |
@fields = ('title', |
'highestgradelevel', |
'author', |
'standards', |
'subject', |
'mime', |
'keywords', |
'language', |
'notes', |
'creationdate', |
'abstract', |
'lastrevisiondate', |
'lowestgradelevel', |
'owner', |
'highestgradelevel', |
'copyright', |
'standards', |
'customdistributionfile', |
'mime', |
'sourceavail', |
'language', |
'sourcerights', |
'creationdate', |
'obsolete', |
'lastrevisiondate', |
'obsoletereplacement') { |
'owner', |
$table.='<tr><td bgcolor="#AAAAAA">'.$lt{$_}. |
'copyright', |
|
'customdistributionfile', |
|
'sourceavail', |
|
'sourcerights', |
|
'obsolete', |
|
'obsoletereplacement'); |
|
} |
|
foreach my $field (@fields) { |
|
$table.='<tr><td bgcolor="#AAAAAA">'.$lt{$field}. |
'</td><td bgcolor="#CCCCCC">'. |
'</td><td bgcolor="#CCCCCC">'. |
&prettyprint($_,$content{$_}).'</td></tr>'; |
&prettyprint($field,$content{$field}).'</td></tr>'; |
delete $content{$_}; |
delete($content{$field}); |
} |
} |
# |
# |
$r->print(<<ENDHEAD); |
$r->print(<<ENDHEAD); |
Line 804 $versiondisplay
|
Line 901 $versiondisplay
|
$table |
$table |
</table> |
</table> |
ENDHEAD |
ENDHEAD |
if ($env{'user.adv'}) { |
if (!$uploaded && $env{'user.adv'}) { |
&print_dynamic_metadata($r,$uri,\%content); |
&print_dynamic_metadata($r,$uri,\%content); |
} |
} |
return; |
return; |
Line 887 sub print_dynamic_metadata {
|
Line 984 sub print_dynamic_metadata {
|
foreach my $identifier (sort(keys(%{$dynmeta{'stats'}}))) { |
foreach my $identifier (sort(keys(%{$dynmeta{'stats'}}))) { |
my $data = $dynmeta{'stats'}->{$identifier}; |
my $data = $dynmeta{'stats'}->{$identifier}; |
my $course = $data->{'course'}; |
my $course = $data->{'course'}; |
my %courseinfo = &Apache::lonnet::coursedescription($course); |
my %courseinfo = |
|
&Apache::lonnet::coursedescription($course, |
|
{'one_time' => 1}); |
if (! exists($courseinfo{'num'}) || $courseinfo{'num'} eq '') { |
if (! exists($courseinfo{'num'}) || $courseinfo{'num'} eq '') { |
&Apache::lonnet::logthis('lookup for '.$course.' failed'); |
&Apache::lonnet::logthis('lookup for '.$course.' failed'); |
next; |
next; |
Line 1012 sub present_editable_metadata {
|
Line 1111 sub present_editable_metadata {
|
# Header |
# Header |
my $disuri=$uri; |
my $disuri=$uri; |
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; |
|
my $path; |
|
if ($disuri =~ m|/portfolio/|) { |
|
($disuri, $meta_uri, $path) = &portfolio_display_uri($disuri,1); |
|
} |
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) { |
Line 1044 sub present_editable_metadata {
|
Line 1147 sub present_editable_metadata {
|
my $goback=&mt('Back to Source File'); |
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" action="" name="defaultmeta"> |
ENDBOMBS |
ENDBOMBS |
if ($showdel) { |
if ($showdel) { |
$r->print(<<ENDDEL); |
$r->print(<<ENDDEL); |
Line 1068 ENDDEL
|
Line 1171 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); |
} |
} |
$r->print(<<ENDEDIT); |
$r->print(<<ENDEDIT); |
<h1>$displayfile</h1> |
<h1>$displayfile</h1> |
<form method="post" name="defaultmeta"> |
<form method="post" action="" name="defaultmeta"> |
ENDEDIT |
ENDEDIT |
$r->print('<script language="JavaScript">'. |
$r->print('<script type="JavaScript">'. |
&Apache::loncommon::browser_and_searcher_javascript(). |
&Apache::loncommon::browser_and_searcher_javascript(). |
'</script>'); |
'</script>'); |
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', |
'highestgradelevel','courserestricted'); |
'notes','lowestgradelevel', |
|
'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 1092 ENDEDIT
|
Line 1196 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') { |
|
$r->print('Document metadata restricted by :<strong> '.$env{$metacourse.".description"}."</strong><br />"); |
|
} |
} |
|
if ($file_type eq 'portfolio') { |
foreach (@fields) { |
if (! $Apache::lonpublisher::metadatafields{'mime'}) { |
if (defined($env{'form.new_'.$_})) { |
($Apache::lonpublisher::metadatafields{'mime'}) = |
$Apache::lonpublisher::metadatafields{$_}= |
( $target=~/\.(\w+)$/ ); |
join(',',&Apache::loncommon::get_env_multiple('form.new_'.$_)); |
} |
|
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 />'); |
|
} else { |
|
$r->print("This resource is not associated with a course.<br />"); |
|
} |
|
} |
|
foreach my $field_name (@fields) { |
|
|
|
if (defined($env{'form.new_'.$field_name})) { |
|
$Apache::lonpublisher::metadatafields{$field_name}= |
|
join(',',&Apache::loncommon::get_env_multiple('form.new_'.$field_name)); |
} |
} |
my $field_name = $_; |
if ($Apache::lonpublisher::metadatafields{'courserestricted'} ne 'none' |
if ($metacourse ne 'none') { |
&& exists($env{$Apache::lonpublisher::metadatafields{'courserestricted'}.'.metadata.'.$field_name.'.options'})) { |
# handle restrictions here |
# handle restrictions here |
if ($env{$metacourse.'.metadata.'.$_.'.options'} =~ m/active/){ |
if (($env{$Apache::lonpublisher::metadatafields{'courserestricted'}.'.metadata.'.$field_name.'.options'} =~ m/active/) || |
$output.=('<p>'.$lt{$_}.': '. |
($field_name eq 'courserestricted')){ |
&prettyinput($_, |
$output.=("\n".'<p>'.$lt{$field_name}.': '. |
$Apache::lonpublisher::metadatafields{$_}, |
&prettyinput($field_name, |
'new_'.$_,'defaultmeta',undef,undef,undef,undef,$metacourse).'</p>'); |
$Apache::lonpublisher::metadatafields{$field_name}, |
} elsif ($_ eq 'courserestricted') { |
'new_'.$field_name,'defaultmeta', |
$output.=( |
undef,undef,undef,undef, |
&prettyinput($field_name, |
$Apache::lonpublisher::metadatafields{'courserestricted'}).'</p>'."\n"); |
$Apache::lonpublisher::metadatafields{$_}, |
|
'new_'.$field_name,'defaultmeta',undef,undef,undef,undef,$metacourse)); |
|
} |
} |
} else { |
} else { |
if ($_ ne 'courserestricted') { |
|
$output.=('<p>'.$lt{$_}.': '. |
|
&prettyinput($_, |
|
$Apache::lonpublisher::metadatafields{$_}, |
|
'new_'.$_,'defaultmeta').'</p>'); |
|
} else { |
|
$output.=&prettyinput($field_name, |
|
$Apache::lonpublisher::metadatafields{$_}, |
|
'new_'.$field_name,'defaultmeta'); |
|
} |
|
} |
|
} |
|
$output.=('<p>'.$lt{$_}.': '. |
|
&prettyinput($_, |
|
$Apache::lonpublisher::metadatafields{$_}, |
|
'new_'.$_,'defaultmeta',undef,undef,undef,undef,$metacourse).'</p>'); |
|
|
|
if ($env{'form.store'}) { |
$output.=('<p>'.$lt{$field_name}.': '. |
my $mfh; |
&prettyinput($field_name, |
my $formname='store'; |
$Apache::lonpublisher::metadatafields{$field_name}, |
my $file_content; |
'new_'.$field_name,'defaultmeta').'</p>'); |
foreach my $meta_field (keys %env) { |
|
if (&Apache::loncommon::get_env_multiple('form.new_keywords')) { |
|
$Apache::lonpublisher::metadatafields{'keywords'} = |
|
join (',', &Apache::loncommon::get_env_multiple('form.new_keywords')); |
|
} |
|
} |
|
foreach (sort keys %Apache::lonpublisher::metadatafields) { |
|
next if ($_ =~ /\./); |
|
my $unikey=$_; |
|
$unikey=~/^([A-Za-z]+)/; |
|
my $tag=$1; |
|
$tag=~tr/A-Z/a-z/; |
|
$file_content.= "\n\<$tag"; |
|
foreach (split(/\,/, |
|
$Apache::lonpublisher::metadatakeys{$unikey}) |
|
) { |
|
my $value= |
|
$Apache::lonpublisher::metadatafields{$unikey.'.'.$_}; |
|
$value=~s/\"/\'\'/g; |
|
$file_content.=' '.$_.'="'.$value.'"' ; |
|
# print $mfh ' '.$_.'="'.$value.'"'; |
|
} |
|
$file_content.= '>'. |
|
&HTML::Entities::encode |
|
($Apache::lonpublisher::metadatafields{$unikey}, |
|
'<>&"'). |
|
'</'.$tag.'>'; |
|
} |
} |
if ($fn =~ /\/portfolio\//) { |
} |
$fn =~ /\/portfolio\/(.*)$/; |
if ($env{'form.store'}) { |
my $new_fn = '/'.$1; |
my $mfh; |
$env{'form.'.$formname}=$file_content; |
my $formname='store'; |
$env{'form.'.$formname.'.filename'}=$new_fn; |
my $file_content; |
&Apache::lonnet::userfileupload('uploaddoc','', |
if (&Apache::loncommon::get_env_multiple('form.new_keywords')) { |
'portfolio'.$env{'form.currentpath'}); |
$Apache::lonpublisher::metadatafields{'keywords'} = |
if (&Apache::lonnet::userfileupload($formname,'','portfolio') eq 'error: no uploaded file') { |
join (',', &Apache::loncommon::get_env_multiple('form.new_keywords')); |
$r->print('<p><font color="red">'. |
} |
&mt('Could not write metadata').', '. |
|
&mt('FAIL').'</font></p>'); |
foreach (sort keys %Apache::lonpublisher::metadatafields) { |
} else { |
next if ($_ =~ /\./); |
$r->print('<p><font color="blue">'.&mt('Wrote Metadata'). |
my $unikey=$_; |
' '.&Apache::lonlocal::locallocaltime(time). |
$unikey=~/^([A-Za-z]+)/; |
'</font></p>'); |
my $tag=$1; |
} |
$tag=~tr/A-Z/a-z/; |
} else { |
$file_content.= "\n\<$tag"; |
if (! ($mfh=Apache::File->new('>'.$fn))) { |
foreach (split(/\,/, |
$r->print('<p><font color="red">'. |
$Apache::lonpublisher::metadatakeys{$unikey}) |
&mt('Could not write metadata').', '. |
) { |
&mt('FAIL').'</font></p>'); |
my $value= |
} else { |
$Apache::lonpublisher::metadatafields{$unikey.'.'.$_}; |
print $mfh $file_content; |
$value=~s/\"/\'\'/g; |
|
$file_content.=' '.$_.'="'.$value.'"' ; |
|
# print $mfh ' '.$_.'="'.$value.'"'; |
|
} |
|
$file_content.= '>'. |
|
&HTML::Entities::encode |
|
($Apache::lonpublisher::metadatafields{$unikey}, |
|
'<>&"'). |
|
'</'.$tag.'>'; |
|
} |
|
if ($fn =~ m|^$Apache::lonnet::perlvar{'lonDocRoot'}/userfiles/portfolio/|) { |
|
my ($path, $new_fn) = ($fn =~ m|/(portfolio.*)/([^/]*)$|); |
|
$r->print(&store_portfolio_metadata($formname,$file_content,$path, |
|
$new_fn)); |
|
unless ($env{'form.associate'}) { |
|
$r->print(&Apache::portfolio::done("return",'/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",'/adm/portfolio')); |
|
return; |
|
} |
|
} 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>'); |
} |
} |
} |
unless ($env{'form.associate'}) { |
} |
$r->print(&Apache::portfolio::done("return",'/adm/portfolio')); |
|
return; |
|
} |
|
} |
|
} |
|
|
$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').'" />'); |
|
|
|
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.'">'. |
|
'<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').'" />'); |
|
} |
} |
} |
|
|
$r->print('</form>'); |
$r->print('</form>'); |
|
|
return; |
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; |
1; |
__END__ |
__END__ |
|
|
|
|