Diff for /loncom/interface/lonmeta.pm between versions 1.126 and 1.133

version 1.126, 2005/11/11 22:46:56 version 1.133, 2005/11/22 23:20:40
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',
Line 254  sub fieldnames { Line 255  sub fieldnames {
         %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 284  sub fieldnames { Line 284  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);
Line 483  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 $values = $env{$course_key.'.metadata.'.$_.'.values'};          my %meta_options;
         if ($env{$course_key.'.metadata.'.$_.'.options'} =~ m/stuadd/) {          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
             return           # values may be mixed.
             '<input type="text" name="'.$fieldname.'" size="'.$size.'" '.          if ($values) {
             'value="'.$value.'" />'.              foreach my $item (split(/,/,$values)) {
         &relatedfield(1,$relatedsearchflag,$relatedsep,$fieldname,                  $item =~ s/^\s+//;
                       $relatedvalue);                   $meta_options{$item} = $item;
                           }
               foreach my $item (split(/,/,$value)) {
                   $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 'courserestricted') {          if ($type eq 'courserestricted') {
             return ('<input type="hidden" name="new_courserestricted" value="'.$course_key.'" />');              return ('<input type="hidden" name="new_courserestricted" value="'.$course_key.'" />');
         }          }
         if ($type eq 'authorspace') {          if (($type eq 'keywords') || ($type eq 'subject')
         }               || ($type eq 'author')||($type eq  'notes')
         if ($type eq 'modifyinguser') {               || ($type eq  'abstract')|| ($type eq  'title')|| ($type eq  'standards')) {
         }              if ($values) {
         if ($type eq 'subject') {                  if ($only_one) {
         }                      $output .= (&Apache::loncommon::select_form($value,'new_'.$type,%meta_options));
         if ($type eq 'keywords') {                  } else {
             my %hash;                      $output .= (&Apache::loncommon::multiple_select_form('new_'.$type,\@cur_values_inst,undef,\%meta_options));
             my @cur_values;                  }
             foreach (split(/,/,$value)) {  
                 $_ =~ s/^\s+//;  
                 push(@cur_values,$_);  
             }  
             foreach (split(/,/,$values)) {  
                 $_ =~ s/^\s+//;  
                 $hash{$_} = $_;  
             }              }
             if ($only_one) {              if ($stu_add) {
                 return(&Apache::loncommon::select_form($value,'new_keywords',%hash));                  $output .= '<input type="text" name="'.$fieldname.'" size="'.$size.'" '.
             } else {                  'value="'.$cur_values_stu.'" />'.
                 return (&Apache::loncommon::multiple_select_form('new_keywords',\@cur_values,undef,\%hash));                  &relatedfield(1,$relatedsearchflag,$relatedsep,$fieldname,
                         $relatedvalue); 
             }              }
               return ($output);
         }          }
         if ($type eq  'notes') {  
         }  
         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 1067  ENDEDIT Line 1071  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','courserestricted');                  'highestgradelevel','standards','courserestricted');
  } else {   } else {
     @fields = ('author','title','subject','keywords','abstract','notes',      @fields = ('author','title','subject','keywords','abstract','notes',
                  'copyright','customdistributionfile','language',                   'copyright','customdistributionfile','language',
Line 1095  ENDEDIT Line 1099  ENDEDIT
         if ($metacourse ne 'none') {          if ($metacourse ne 'none') {
              $r->print('Document metadata restricted by :<strong> '.$env{$metacourse.".description"}."</strong><br />");               $r->print('Document metadata restricted by :<strong> '.$env{$metacourse.".description"}."</strong><br />");
         }          }
                   foreach my $field_name(@fields) {
         foreach (@fields) {  
             if (defined($env{'form.new_'.$_})) {              if (defined($env{'form.new_'.$field_name})) {
                 $Apache::lonpublisher::metadatafields{$_}=                  $Apache::lonpublisher::metadatafields{$field_name}=
                     join(',',&Apache::loncommon::get_env_multiple('form.new_'.$_));                      join(',',&Apache::loncommon::get_env_multiple('form.new_'.$field_name));
             }              }
             if ($metacourse ne 'none') {              if ($metacourse ne 'none') {
                 # handle restrictions here                  # handle restrictions here
                 if (($env{$metacourse.'.metadata.'.$_.'.options'} =~ m/active/)||                  if ($env{$metacourse.'.metadata.'.$field_name.'.options'} =~ m/active/){
                     ($_ eq 'courserestricted'))  {                      $output.=('<p>'.$lt{$field_name}.': '.
                     $output.=('<p>'.$lt{$_}.': '.                                &prettyinput($field_name,
                             &prettyinput($_,     $Apache::lonpublisher::metadatafields{$field_name},
    $Apache::lonpublisher::metadatafields{$_},     'new_'.$field_name,'defaultmeta',undef,undef,undef,undef,$metacourse).'</p>');
    'new_'.$_,'defaultmeta',undef,undef,undef,undef,$metacourse).'</p>');                   } elsif ($field_name eq 'courserestricted') {
                 }                              $output.=(
                                   &prettyinput($field_name,
       $Apache::lonpublisher::metadatafields{$field_name},
       'new_'.$field_name,'defaultmeta',undef,undef,undef,undef,$metacourse));
                    }
             } else {              } else {
                 $output.=('<p>'.$lt{$_}.': '.                  if ($field_name ne 'courserestricted') {
                             &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>');
           } else {
                       $output.=&prettyinput($field_name,
      $Apache::lonpublisher::metadatafields{$field_name},
      'new_'.$field_name,'defaultmeta');
                   }
             }              }
         }          }
         if ($env{'form.store'}) {          if ($env{'form.store'}) {

Removed from v.1.126  
changed lines
  Added in v.1.133


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