Diff for /loncom/interface/lonmeta.pm between versions 1.116 and 1.129

version 1.116, 2005/10/25 01:23:47 version 1.129, 2005/11/19 00:00:38
Line 247  sub fieldnames { Line 247  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') {      if (! defined($file_type) || $file_type ne 'portfolio') {
         %fields =           %fields = 
         (%fields,          (%fields,
Line 302  sub select_course { Line 304  sub select_course {
     }      }
     $r->print('<h3>Course Related Meta-Data</h3><br />');      $r->print('<h3>Course Related Meta-Data</h3><br />');
     $r->print('<form action="" method="post">');      $r->print('<form action="" method="post">');
     $r->print('Select your test course<br />');      $r->print('Select course restrictions<br />');
     $r->print('<select name="metacourse" >');      $r->print('<select name="metacourse" >');
     my $meta_not_found = 1;      my $meta_not_found = 1;
     foreach my $key (keys (%courses)) {          foreach my $key (keys (%courses)) {    
Line 313  sub select_course { Line 315  sub select_course {
             $r->print('Select your course<br />');              $r->print('Select your course<br />');
             $r->print('<select name="metacourse" >');              $r->print('<select name="metacourse" >');
         }          }
         $r->print('<option value="'.$key.'">');          $key =~ m/(^.+)\.description$/;
           $r->print('<option value="'.$1.'">');
         $r->print($courses{$key});          $r->print($courses{$key});
         $r->print('</option>');          $r->print('</option>');
     }      }
Line 480  sub prettyinput { Line 483  sub prettyinput {
     if (! defined($size)) {      if (! defined($size)) {
         $size = 80;          $size = 80;
     }      }
       my $output;
     if (defined($course_key)) {      if (defined($course_key)) {
         my $stu_add;          my $stu_add;
         my $only_one;          my $only_one;
           my %meta_options;
           my @cur_values_inst;
           my $cur_values_stu;
           my $values = $env{$course_key.'.metadata.'.$_.'.values'};
         if ($env{$course_key.'.metadata.'.$_.'.options'} =~ m/stuadd/) {          if ($env{$course_key.'.metadata.'.$_.'.options'} =~ m/stuadd/) {
             $stu_add = 'true';              $stu_add = 'true';
         }          }
         if ($env{$course_key.'.metadata.'.$_.'.options'} =~ m/onlyone/) {          if ($env{$course_key.'.metadata.'.$_.'.options'} =~ m/onlyone/) {
             $only_one = 'true';              $only_one = 'true';
         }          }
         title' => 'Title',          # need to take instructor values out of list where instructor and student
           # values may be mixed.
           if ($values && $stu_add) {
               foreach (split(/,/,$values)) {
                   $_ =~ s/^\s+//;
                   $meta_options{$_} = $_;
               }
               foreach (split(/,/,$value)) {
                   $_ =~ s/^\s+//;
                   if ($meta_options{$_}) {
                       push(@cur_values_inst,$_);
                   } else {
                       $cur_values_stu .= $_.',';
                   }
               }
           } else {
               $cur_values_stu = $value;
           }
         if ($type eq 'author') {          if ($type eq 'author') {
               return 
               '<input type="text" name="'.$fieldname.'" size="'.$size.'" '.
               'value="'.$value.'" />'.
           &relatedfield(1,$relatedsearchflag,$relatedsep,$fieldname,
                         $relatedvalue); 
               
           }
           if ($type eq 'courserestricted') {
               return ('<input type="hidden" name="new_courserestricted" value="'.$course_key.'" />');
         }          }
         if ($type eq 'authorspace') {          if ($type eq 'authorspace') {
         }          }
Line 499  sub prettyinput { Line 533  sub prettyinput {
         if ($type eq 'subject') {          if ($type eq 'subject') {
         }          }
         if ($type eq 'keywords') {          if ($type eq 'keywords') {
               if ($values) {
                   if ($only_one) {
                       $output .= (&Apache::loncommon::select_form($value,'new_keywords',%meta_options));
                   } else {
                       $output .= (&Apache::loncommon::multiple_select_form('new_keywords',\@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  'notes') {          if ($type eq  'notes') {
         }          }
         if ($type eq  'abstract') {          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 1038  ENDEDIT Line 1088  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','courserestricted');
  } 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 1096  ENDEDIT
                  'lowestgradelevel','highestgradelevel','sourceavail','sourcerights',                   'lowestgradelevel','highestgradelevel','sourceavail','sourcerights',
                  'obsolete','obsoletereplacement');                   'obsolete','obsoletereplacement');
         }          }
           my $metacourse;
           if ($env{'form.metacourse'} ) {
               $Apache::lonpublisher::metadatafields{'courserestricted'} = $env{'form.metacourse'};
               $metacourse = $env{'form.metacourse'};
            } else {
               if (! $Apache::lonpublisher::metadatafields{'courserestricted'}) {
                   $Apache::lonpublisher::metadatafields{'courserestricted'}=
                       'none';
                   $metacourse = 'none';
               } else {
                   $metacourse = $Apache::lonpublisher::metadatafields{'courserestricted'};
               }
           }
           if (! $Apache::lonpublisher::metadatafields{'copyright'}) {
                   $Apache::lonpublisher::metadatafields{'copyright'}=
                   'default';
           }
           if ($metacourse ne 'none') {
                $r->print('Document metadata restricted by :<strong> '.$env{$metacourse.".description"}."</strong><br />");
           }
           
         foreach (@fields) {          foreach (@fields) {
             if (defined($env{'form.new_'.$_})) {              if (defined($env{'form.new_'.$_})) {
                 $Apache::lonpublisher::metadatafields{$_}=                  $Apache::lonpublisher::metadatafields{$_}=
                     $env{'form.new_'.$_};                      join(',',&Apache::loncommon::get_env_multiple('form.new_'.$_));
             }  
             if (! $Apache::lonpublisher::metadatafields{'copyright'}) {  
                 $Apache::lonpublisher::metadatafields{'copyright'}=  
                     'default';  
             }              }
             if ($env{'form.metacourse'}) {              my $field_name = $_;
               if ($metacourse ne 'none') {
                 # handle restrictions here                  # handle restrictions here
                 $env{'form.metacourse'} =~ m/(^.+)\.description$/;                  if ($env{$metacourse.'.metadata.'.$_.'.options'} =~ m/active/){
                 my $key_base = $1;  
                 if ($env{$key_base.'.metadata.'.$_.'.options'} =~ m/active/) {  
                     $output.=('<p>'.$lt{$_}.': '.                      $output.=('<p>'.$lt{$_}.': '.
                             &prettyinput($_,                                &prettyinput($_,
    $Apache::lonpublisher::metadatafields{$_},     $Apache::lonpublisher::metadatafields{$_},
    'new_'.$_,'defaultmeta',undef,undef,undef,undef,$key_base).'</p>');     'new_'.$_,'defaultmeta',undef,undef,undef,undef,$metacourse).'</p>');
                 }                   } elsif ($_ eq 'courserestricted') {
                               $output.=(
                                   &prettyinput($field_name,
       $Apache::lonpublisher::metadatafields{$_},
       'new_'.$field_name,'defaultmeta',undef,undef,undef,undef,$metacourse));
                    }
             } else {              } else {
                 $output.=('<p>'.$lt{$_}.': '.                  if ($_ ne 'courserestricted') {
                       $output.=('<p>'.$lt{$_}.': '.
                             &prettyinput($_,                              &prettyinput($_,
    $Apache::lonpublisher::metadatafields{$_},     $Apache::lonpublisher::metadatafields{$_},
    'new_'.$_,'defaultmeta').'</p>');     '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'}) {          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) {              foreach my $meta_field (keys %env) {
                 if (&Apache::loncommon::get_env_multiple('form.keywords')) {                  if (&Apache::loncommon::get_env_multiple('form.new_keywords')) {
                 $Apache::lonpublisher::metadatafields{'coursekeyword'} =                       $Apache::lonpublisher::metadatafields{'keywords'} = 
                         join (', ', &Apache::loncommon::get_env_multiple('form.keywords'));                          join (',', &Apache::loncommon::get_env_multiple('form.new_keywords'));
                 }                  }
             }              }
             foreach (sort keys %Apache::lonpublisher::metadatafields) {              foreach (sort keys %Apache::lonpublisher::metadatafields) {

Removed from v.1.116  
changed lines
  Added in v.1.129


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