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

version 1.140, 2005/12/19 16:00:05 version 1.142, 2005/12/19 20:08:40
Line 289  sub fieldnames { Line 289  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 {  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 $disuri=$uri;      my ($res_uri,$meta_uri) = &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);
     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('<form method="post" action="" >');      $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();      $output = &select_course();
     $r->print($output.'<br /><input type="submit" name="store" value="'.      $r->print($output.'<br /><input type="submit" name="store" value="'.
                   &mt('Select Metadata Course Restrictions').'">');                    &mt('Associate Resource With Selected Course').'">');
     $r->print('</form>');      $r->print('</form>');
     return;      return;
 }  }
Line 1028  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 1082  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 1119  ENDEDIT Line 1137  ENDEDIT
                 'default';                  'default';
         }          }
         if ($Apache::lonpublisher::metadatafields{'courserestricted'} ne 'none') {          if ($Apache::lonpublisher::metadatafields{'courserestricted'} ne 'none') {
             $r->print('Using: <strong> '.$env{$Apache::lonpublisher::metadatafields{'courserestricted'}.".description"}.              $r->print(&mt('Associated with course [_1]','<strong>'.$env{$Apache::lonpublisher::metadatafields{'courserestricted'}.".description"}.
                         "</strong> metadata framework<br />");                          '</strong>').'<br />');
         } else {          } else {
             $r->print("This resource is not associated with a metadata framework<br />");              $r->print("This resource is not associated with a course.<br />");
         }          }
         foreach my $field_name(@fields) {          foreach my $field_name(@fields) {
   
Line 1156  ENDEDIT Line 1174  ENDEDIT
                   
     }      }
     $r->print('</form>');      $r->print('</form>');
             if ($env{'form.store'}) {  
             my $mfh;      if ($env{'form.store'}) {
             my $formname='store';    my $mfh;
             my $file_content;   my $formname='store'; 
             foreach my $meta_field (keys %env) {   my $file_content;
                 if (&Apache::loncommon::get_env_multiple('form.new_keywords')) {   foreach my $meta_field (keys %env) {
                     $Apache::lonpublisher::metadatafields{'keywords'} =       if (&Apache::loncommon::get_env_multiple('form.new_keywords')) {
                         join (',', &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 ($_ =~ /\./);   foreach (sort keys %Apache::lonpublisher::metadatafields) {
                 my $unikey=$_;      next if ($_ =~ /\./);
                 $unikey=~/^([A-Za-z]+)/;      my $unikey=$_;
                 my $tag=$1;      $unikey=~/^([A-Za-z]+)/;
                 $tag=~tr/A-Z/a-z/;      my $tag=$1;
                 $file_content.= "\n\<$tag";      $tag=~tr/A-Z/a-z/;
                 foreach (split(/\,/,      $file_content.= "\n\<$tag";
                              $Apache::lonpublisher::metadatakeys{$unikey})      foreach (split(/\,/,
                          ) {     $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\//) {   if ($fn =~ /\/portfolio\//) {
                 $fn =~ /\/portfolio\/(.*)$/;      $fn =~ /\/portfolio\/(.*)$/;
                 my $new_fn = '/'.$1;      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;
                 &Apache::lonnet::userfileupload('uploaddoc','',      &Apache::lonnet::userfileupload('uploaddoc','',
          'portfolio'.$env{'form.currentpath'});      'portfolio'.$env{'form.currentpath'});
                 if (&Apache::lonnet::userfileupload($formname,'','portfolio') eq 'error: no uploaded file') {      if (&Apache::lonnet::userfileupload($formname,'','portfolio') eq 'error: no uploaded file') {
                     $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').   $r->print('<p><font color="blue">'.&mt('Wrote Metadata').
   ' '.&Apache::lonlocal::locallocaltime(time).    ' '.&Apache::lonlocal::locallocaltime(time).
   '</font></p>');    '</font></p>');
                 }      }
             } else {   } else {
                 if (!  ($mfh=Apache::File->new('>'.$fn))) {      if (!  ($mfh=Apache::File->new('>'.$fn))) {
                     $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 {
                     print $mfh $file_content;   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>');
                 }      }
             }   }
         }      }
       
     return;      return;
 }  }
   

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


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