Diff for /loncom/interface/lonmeta.pm between versions 1.118 and 1.151

version 1.118, 2005/10/25 18:47:49 version 1.151, 2006/03/02 20:16:10
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 243  sub fieldnames { Line 243  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');
       
       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 282  sub fieldnames { Line 289  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) = @_;
       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 {
       my ($uri,$as_links)=@_;
       $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);
    $meta_uri = &portfolio_linked_path($meta_uri);
       }
       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('</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;
   }
 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 your test course<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" >');  
         }  
         $r->print('<option value="'.$key.'">');  
         $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 384  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 421  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 480  sub prettyinput { Line 542  sub prettyinput {
     if (! defined($size)) {      if (! defined($size)) {
         $size = 80;          $size = 80;
     }      }
     if (defined($course_key)) {      my $output;
       if (defined($course_key) 
    && exists($env{$course_key.'.metadata.'.$type.'.options'})) {
         my $stu_add;          my $stu_add;
         my $only_one;          my $only_one;
         if ($env{$course_key.'.metadata.'.$_.'.options'} =~ m/stuadd/) {          my %meta_options;
           my @cur_values_inst;
           my $cur_values_stu;
           my $values = $env{$course_key.'.metadata.'.$type.'.values'};
           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';
         }          }
         if ($type eq 'author') {          # need to take instructor values out of list where instructor and student
         }          # values may be mixed.
         if ($type eq 'authorspace') {          if ($values) {
         }              foreach my $item (split(/,/,$values)) {
         if ($type eq 'modifyinguser') {                  $item =~ s/^\s+//;
         }                  $meta_options{$item} = $item;
         if ($type eq 'subject') {              }
         }              foreach my $item (split(/,/,$value)) {
         if ($type eq 'keywords') {                  $item =~ s/^\s+//;
                   if ($meta_options{$item}) {
                       push(@cur_values_inst,$item);
                   } else {
                       $cur_values_stu .= $item.',';
                   }
               }
           } else {
               $cur_values_stu = $value;
         }          }
         if ($type eq  'notes') {          if ($type eq 'courserestricted') {
               return (&select_course());
               # return ('<input type="hidden" name="new_courserestricted" value="'.$course_key.'" />');
           }
           if (($type eq 'keywords') || ($type eq 'subject')
                || ($type eq 'author')||($type eq  'notes')
                || ($type eq  'abstract')|| ($type eq  'title')|| ($type eq  'standards')) {
               if ($values) {
                   if ($only_one) {
                       $output .= (&Apache::loncommon::select_form($cur_values_inst[0],'new_'.$type,%meta_options));
                   } else {
                       $output .= (&Apache::loncommon::multiple_select_form('new_'.$type,\@cur_values_inst,undef,\%meta_options));
                   }
               }
               if ($stu_add) {
                   $output .= '<input type="text" name="'.$fieldname.'" size="'.$size.'" '.
                   'value="'.$cur_values_stu.'" />'.
                   &relatedfield(1,$relatedsearchflag,$relatedsep,$fieldname,
                         $relatedvalue); 
               }
               return ($output);
         }          }
         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 570  sub prettyinput { Line 664  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 611  sub handler { Line 710  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 968  sub present_editable_metadata { Line 1070  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;
       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$//;
Line 1022  ENDDEL Line 1128  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 1038  ENDEDIT Line 1144  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');                  '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 1046  ENDEDIT Line 1152  ENDEDIT
                  'lowestgradelevel','highestgradelevel','sourceavail','sourcerights',                   'lowestgradelevel','highestgradelevel','sourceavail','sourcerights',
                  'obsolete','obsoletereplacement');                   'obsolete','obsoletereplacement');
         }          }
         foreach (@fields) {          if ((! $Apache::lonpublisher::metadatafields{'courserestricted'}) &&
             if (defined($env{'form.new_'.$_})) {                  (! $env{'form.new_courserestricted'})) {
                 $Apache::lonpublisher::metadatafields{$_}=              $Apache::lonpublisher::metadatafields{'courserestricted'}=
                     $env{'form.new_'.$_};                  'none';
             }          } elsif ($env{'form.new_courserestricted'}) {
             if (! $Apache::lonpublisher::metadatafields{'copyright'}) {              $Apache::lonpublisher::metadatafields{'courserestricted'}=
                   $env{'form.new_courserestricted'}; 
           }           
           if (! $Apache::lonpublisher::metadatafields{'copyright'}) {
                 $Apache::lonpublisher::metadatafields{'copyright'}=                  $Apache::lonpublisher::metadatafields{'copyright'}=
                     'default';                  'default';
           }
    if ($file_type eq 'portfolio') {
       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));
             }              }
             if ($env{'form.metacourse'}) {              if ($Apache::lonpublisher::metadatafields{'courserestricted'} ne 'none'
    && exists($env{$Apache::lonpublisher::metadatafields{'courserestricted'}.'.metadata.'.$field_name.'.options'})) {
                 # handle restrictions here                  # handle restrictions here
                 $env{'form.metacourse'} =~ m/(^.+)\.description$/;                  if (($env{$Apache::lonpublisher::metadatafields{'courserestricted'}.'.metadata.'.$field_name.'.options'} =~ m/active/) ||
                 my $key_base = $1;                      ($field_name eq 'courserestricted')){
                 if ($env{$key_base.'.metadata.'.$_.'.options'} =~ m/active/) {                      $output.=("\n".'<p>'.$lt{$field_name}.': '.
                     $output.=('<p>'.$lt{$_}.': '.                                &prettyinput($field_name,
                             &prettyinput($_,     $Apache::lonpublisher::metadatafields{$field_name},
    $Apache::lonpublisher::metadatafields{$_},                      'new_'.$field_name,'defaultmeta',
    'new_'.$_,'defaultmeta',undef,undef,undef,undef,$key_base).'</p>');                      undef,undef,undef,undef,
                 }                      $Apache::lonpublisher::metadatafields{'courserestricted'}).'</p>'."\n");
                    }
             } else {              } else {
                 $output.=('<p>'.$lt{$_}.': '.  
                             &prettyinput($_,                      $output.=('<p>'.$lt{$field_name}.': '.
    $Apache::lonpublisher::metadatafields{$_},                              &prettyinput($field_name,
    'new_'.$_,'defaultmeta').'</p>');     $Apache::lonpublisher::metadatafields{$field_name},
      'new_'.$field_name,'defaultmeta').'</p>');
                  
             }              }
         }          }
         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.keywords')) {   $Apache::lonpublisher::metadatafields{'keywords'} = 
                 $Apache::lonpublisher::metadatafields{'coursekeyword'} =       join (',', &Apache::loncommon::get_env_multiple('form.new_keywords'));
                         join (', ', &Apache::loncommon::get_env_multiple('form.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 =~ m|/portfolio/|) {
             if ($fn =~ /\/portfolio\//) {   my ($path, $new_fn) = ($fn =~ m|/(portfolio.*)/([^/]*)$|);
                 $fn =~ /\/portfolio\/(.*)$/;   $env{'form.'.$formname}=$file_content."\n";
                 my $new_fn = '/'.$1;   $env{'form.'.$formname.'.filename'}=$new_fn;
                 $env{'form.'.$formname}=$file_content;   my $result =&Apache::lonnet::userfileupload($formname,'',
                 $env{'form.'.$formname.'.filename'}=$new_fn;      $path);
                 &Apache::lonnet::userfileupload('uploaddoc','',  
          'portfolio'.$env{'form.currentpath'});   if ($result =~ /(error|notfound)/) {
                 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').  
   ' '.&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').'">');
   
    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;
 }  }
   

Removed from v.1.118  
changed lines
  Added in v.1.151


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