version 1.144, 2005/12/19 21:17:25
|
version 1.154, 2006/04/26 14:53:52
|
Line 71 sub get_dynamic_metadata_from_sql {
|
Line 71 sub get_dynamic_metadata_from_sql {
|
if (! defined($authordom) || ! defined($author)) { |
if (! defined($authordom) || ! defined($author)) { |
return (); |
return (); |
} |
} |
my @Fields = ('url','count','course', |
my @Fields = ('url','count','course','course_list', |
'goto','goto_list', |
'goto','goto_list', |
'comefrom','comefrom_list', |
'comefrom','comefrom_list', |
'sequsage','sequsage_list', |
'sequsage','sequsage_list', |
Line 248 sub fieldnames {
|
Line 248 sub fieldnames {
|
'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 = |
Line 290 sub fieldnames {
|
Line 295 sub fieldnames {
|
return &Apache::lonlocal::texthash(%fields); |
return &Apache::lonlocal::texthash(%fields); |
} |
} |
|
|
|
sub portfolio_linked_path { |
|
my ($path) = @_; |
|
my $result = &Apache::portfolio::make_anchor('portfolio','/'); |
|
my $fullpath = '/'; |
|
my (undef,@tree) = split('/',$path); |
|
my $filename = pop(@tree); |
|
foreach my $dir (@tree) { |
|
$fullpath .= $dir.'/'; |
|
$result .= '/'; |
|
$result .= &Apache::portfolio::make_anchor($dir,$fullpath); |
|
} |
|
$result .= "/$filename"; |
|
return $result; |
|
} |
|
|
sub portfolio_display_uri { |
sub portfolio_display_uri { |
my ($uri)=@_; |
my ($uri,$as_links)=@_; |
$uri =~ s|.*/(portfolio/.*)$|$1|; |
$uri =~ s|.*/(portfolio/.*)$|$1|; |
my ($res_uri,$meta_uri) = ($uri,$uri); |
my ($res_uri,$meta_uri) = ($uri,$uri); |
|
|
Line 300 sub portfolio_display_uri {
|
Line 320 sub portfolio_display_uri {
|
} else { |
} else { |
$meta_uri .= '.meta'; |
$meta_uri .= '.meta'; |
} |
} |
return ($res_uri,$meta_uri); |
|
|
my ($path) = ($res_uri =~ m|^portfolio(.*/)[^/]*$|); |
|
|
|
if ($as_links) { |
|
$res_uri = &portfolio_linked_path($res_uri); |
|
$meta_uri = &portfolio_linked_path($meta_uri); |
|
} |
|
return ($res_uri,$meta_uri,$path); |
} |
} |
|
|
sub pre_select_course { |
sub pre_select_course { |
my ($r,$uri) = @_; |
my ($r,$uri) = @_; |
my $output; |
my $output; |
my $fn=&Apache::lonnet::filelocation('',$uri); |
my $fn=&Apache::lonnet::filelocation('',$uri); |
my ($res_uri,$meta_uri) = &portfolio_display_uri($uri); |
my ($res_uri,$meta_uri,$path) = &portfolio_display_uri($uri); |
%Apache::lonpublisher::metadatafields=(); |
%Apache::lonpublisher::metadatafields=(); |
%Apache::lonpublisher::metadatakeys=(); |
%Apache::lonpublisher::metadatakeys=(); |
my $result=&Apache::lonnet::getfile($fn); |
my $result=&Apache::lonnet::getfile($fn); |
Line 322 sub pre_select_course {
|
Line 349 sub pre_select_course {
|
$r->print($output.'<br /><input type="submit" name="store" value="'. |
$r->print($output.'<br /><input type="submit" name="store" value="'. |
&mt('Associate Resource With Selected Course').'">'); |
&mt('Associate Resource With Selected Course').'">'); |
$r->print('</form>'); |
$r->print('</form>'); |
|
|
|
$r->print('<br /><br /><form method="POST" action="/adm/portfolio">'. |
|
'<input type="hidden" name="currentpath" value="'.$path.'" />'. |
|
'<input type="submit" name="cancel" value="'.&mt('Cancel').'">'. |
|
'</form>'); |
|
|
return; |
return; |
} |
} |
sub select_course { |
sub select_course { |
my %courses; |
my $output=$/; |
my $output; |
my $current_restriction= |
my $selected; |
$Apache::lonpublisher::metadatafields{'courserestricted'}; |
foreach my $key (keys (%env)) { |
my $selected = ($current_restriction eq 'none' ? 'selected="selected"' |
if ($key =~ m/\.metadata\./) { |
: ''); |
$key =~ m/^course\.(.+)(\.metadata.+$)/; |
|
my $course = $1; |
|
my $coursekey = 'course.'.$course.'.description'; |
|
my $value = $env{$coursekey}; |
|
$courses{$coursekey} = $value; |
|
} |
|
} |
|
&Apache::lonnet::logthis('the restricted is'.$Apache::lonpublisher::metadatafields{'courserestricted'}); |
|
my $meta_not_found = 1; |
|
if ($Apache::lonpublisher::metadatafields{'courserestricted'} eq 'none') { |
|
$selected = ' SELECTED '; |
|
} else { |
|
$selected = ''; |
|
} |
|
$output .= '<select name="new_courserestricted" >'; |
$output .= '<select name="new_courserestricted" >'; |
$output .= '<option value="none" '.$selected.'>None</option>'; |
$output .= '<option value="none" '.$selected.'>'. |
foreach my $key (keys (%courses)) { |
&mt('None').'</option>'.$/; |
$key =~ m/(^.+)\.description$/; |
my %courses; |
if ($Apache::lonpublisher::metadatafields{'courserestricted'} eq $1) { |
foreach my $key (keys(%env)) { |
$selected = ' SELECTED '; |
if ($key !~ m/^course\.(.+)\.description$/) { next; } |
} else { |
my $cid = $1; |
$selected = ''; |
if ($env{$key} !~ /\S/) { next; } |
} |
$courses{$key} = $cid; |
$output .= '<option value="'.$1.'"'.$selected.'>'; |
} |
$output .= $courses{$key}; |
foreach my $key (sort { lc($env{$a}) cmp lc($env{$b}) } (keys(%courses))) { |
$output .= '</option>'; |
my $cid = 'course.'.$courses{$key}; |
|
my $selected = ($current_restriction eq $cid ? 'selected="selected"' |
|
: ''); |
|
if ($env{$key} !~ /\S/) { next; } |
|
$output .= '<option value="'.$cid.'" '.$selected.'>'; |
|
$output .= $env{$key}; |
|
$output .= '</option>'.$/; |
|
$selected = ''; |
} |
} |
$output .= '</select><br />'; |
$output .= '</select><br />'; |
return ($output); |
return ($output); |
Line 420 sub prettyprint {
|
Line 447 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 457 sub prettyprint {
|
Line 484 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 517 sub prettyinput {
|
Line 545 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; |
Line 674 sub handler {
|
Line 703 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=~/\/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, |
|
{'domain' => $resdomain,})); |
if ($env{'form.store'}) { |
if ($env{'form.store'}) { |
&present_editable_metadata($r,$uri,'portfolio'); |
&present_editable_metadata($r,$uri,'portfolio'); |
} else { |
} else { |
Line 694 sub handler {
|
Line 721 sub handler {
|
} |
} |
} elsif ($uri=~/^\/\~/) { |
} elsif ($uri=~/^\/\~/) { |
# 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 766 sub present_uneditable_metadata {
|
Line 795 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 $currentversion=&Apache::lonnet::getversion($disuri); |
my $versiondisplay=''; |
my $versiondisplay=''; |
Line 916 sub print_dynamic_metadata {
|
Line 946 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 1044 sub present_editable_metadata {
|
Line 1076 sub present_editable_metadata {
|
$disuri=~s/^\/\~/\/priv\//; |
$disuri=~s/^\/\~/\/priv\//; |
$disuri=~s/\.meta$//; |
$disuri=~s/\.meta$//; |
my $meta_uri = $disuri; |
my $meta_uri = $disuri; |
|
my $path; |
if ($disuri =~ m|/portfolio/|) { |
if ($disuri =~ m|/portfolio/|) { |
($disuri, $meta_uri) = &portfolio_display_uri($disuri); |
($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'}\//; |
Line 1136 ENDEDIT
|
Line 1169 ENDEDIT
|
$Apache::lonpublisher::metadatafields{'copyright'}= |
$Apache::lonpublisher::metadatafields{'copyright'}= |
'default'; |
'default'; |
} |
} |
if ($Apache::lonpublisher::metadatafields{'courserestricted'} ne 'none') { |
if ($file_type eq 'portfolio') { |
$r->print(&mt('Associated with course [_1]','<strong>'.$env{$Apache::lonpublisher::metadatafields{'courserestricted'}.".description"}. |
if ($Apache::lonpublisher::metadatafields{'courserestricted'} ne 'none') { |
'</strong>').'<br />'); |
$r->print(&mt('Associated with course [_1]','<strong>'.$env{$Apache::lonpublisher::metadatafields{'courserestricted'}.".description"}. |
} else { |
'</strong>').'<br />'); |
$r->print("This resource is not associated with a course.<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 ($Apache::lonpublisher::metadatafields{'courserestricted'} ne 'none') { |
if ($Apache::lonpublisher::metadatafields{'courserestricted'} ne 'none' |
|
&& exists($env{$Apache::lonpublisher::metadatafields{'courserestricted'}.'.metadata.'.$field_name.'.options'})) { |
# handle restrictions here |
# handle restrictions here |
if (($env{$Apache::lonpublisher::metadatafields{'courserestricted'}.'.metadata.'.$field_name.'.options'} =~ m/active/) || |
if (($env{$Apache::lonpublisher::metadatafields{'courserestricted'}.'.metadata.'.$field_name.'.options'} =~ m/active/) || |
($field_name eq 'courserestricted')){ |
($field_name eq 'courserestricted')){ |
Line 1199 ENDEDIT
|
Line 1235 ENDEDIT
|
'<>&"'). |
'<>&"'). |
'</'.$tag.'>'; |
'</'.$tag.'>'; |
} |
} |
&Apache::lonnet::logthis(" file ".$file_content); |
|
if ($fn =~ m|/portfolio/|) { |
if ($fn =~ m|/portfolio/|) { |
my ($path, $new_fn) = ($fn =~ m|/(portfolio.*)/([^/]*)$|); |
my ($path, $new_fn) = ($fn =~ m|/(portfolio.*)/([^/]*)$|); |
$env{'form.'.$formname}=$file_content."\n"; |
$env{'form.'.$formname}=$file_content."\n"; |
Line 1232 ENDEDIT
|
Line 1267 ENDEDIT
|
|
|
$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') { |
|
$r->print('</form> |
|
<br /><br /><form method="POST" action="/adm/portfolio">'. |
|
'<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; |