Diff for /loncom/interface/lonmeta.pm between versions 1.142 and 1.152

version 1.142, 2005/12/19 20:08:40 version 1.152, 2006/03/02 20:57:15
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);
   
     if ($uri =~ /\.meta$/) {      if ($uri =~ /\.meta$/) {
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);
             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 543  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 766  sub present_uneditable_metadata { Line 793  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 1044  sub present_editable_metadata { Line 1072  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 1165  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')){
                     $output.=('<p>'.$lt{$field_name}.': '.                      $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',                      'new_'.$field_name,'defaultmeta',
                     undef,undef,undef,undef,                      undef,undef,undef,undef,
                     $Apache::lonpublisher::metadatafields{'courserestricted'}).'</p>');                      $Apache::lonpublisher::metadatafields{'courserestricted'}).'</p>'."\n");
                  }                   }
             } else {              } else {
   
Line 1168  ENDEDIT Line 1200  ENDEDIT
                                 
             }              }
         }          }
    if ($env{'form.store'}) {
     $r->print($output.'<br /><input type="submit" name="store" value="'.      my $mfh;
                   &mt('Store Catalog Information').'">');      my $formname='store'; 
               my $file_content;
     }  
     $r->print('</form>');  
   
     if ($env{'form.store'}) {  
  my $mfh;  
  my $formname='store';   
  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.'>';
  }  
  if ($fn =~ /\/portfolio\//) {  
     $fn =~ /\/portfolio\/(.*)$/;  
     my $new_fn = '/'.$1;  
     $env{'form.'.$formname}=$file_content."\n";  
     $env{'form.'.$formname.'.filename'}=$new_fn;  
     &Apache::lonnet::userfileupload('uploaddoc','',  
     'portfolio'.$env{'form.currentpath'});  
     if (&Apache::lonnet::userfileupload($formname,'','portfolio') eq 'error: no uploaded file') {  
  $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>');  
     }      }
  } else {      if ($fn =~ m|/portfolio/|) {
     if (!  ($mfh=Apache::File->new('>'.$fn))) {   my ($path, $new_fn) = ($fn =~ m|/(portfolio.*)/([^/]*)$|);
  $r->print('<p><font color="red">'.   $env{'form.'.$formname}=$file_content."\n";
   &mt('Could not write metadata').', '.   $env{'form.'.$formname.'.filename'}=$new_fn;
   &mt('FAIL').'</font></p>');   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>');
    }
     } else {      } else {
  print $mfh $file_content;   if (!  ($mfh=Apache::File->new('>'.$fn))) {
  $r->print('<p><font color="blue">'.&mt('Wrote Metadata').      $r->print('<p><font color="red">'.
   ' '.&Apache::lonlocal::locallocaltime(time).        &mt('Could not write metadata').', '.
   '</font></p>');        &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="'.
                     &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>');
   
     return;      return;
 }  }
   

Removed from v.1.142  
changed lines
  Added in v.1.152


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>