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

version 1.112, 2005/10/14 16:34:17 version 1.118, 2005/10/25 18:47:49
Line 238  sub diffgraph { Line 238  sub diffgraph {
 sub fieldnames {  sub fieldnames {
     my $file_type=shift;      my $file_type=shift;
     my %fields =       my %fields = 
         ('metadata.title' => 'Title',          ('title' => 'Title',
          'metadata.author' =>'Author(s)',           'author' =>'Author(s)',
          'metadata.authorspace' => 'Author Space',           'authorspace' => 'Author Space',
          'metadata.modifyinguser' => 'Last Modifying User',           'modifyinguser' => 'Last Modifying User',
          'metadata.subject' => 'Subject',           'subject' => 'Subject',
          'metadata.keywords' => 'Keyword(s)',           'keywords' => 'Keyword(s)',
          'metadata.notes' => 'Notes',           'notes' => 'Notes',
          'metadata.abstract' => 'Abstract',           'abstract' => 'Abstract',
          'metadata.lowestgradelevel' => 'Lowest Grade Level',           'lowestgradelevel' => 'Lowest Grade Level',
          'metadata.highestgradelevel' => 'Highest Grade Level');           'highestgradelevel' => 'Highest Grade Level');
     if (! defined($file_type) || $file_type ne 'portfolio') {      if (! defined($file_type) || $file_type ne 'portfolio') {
         %fields =           %fields = 
         (%fields,          (%fields,
Line 290  sub fieldnames { Line 290  sub fieldnames {
   
 sub select_course {  sub select_course {
     my ($r)=@_;      my ($r)=@_;
     my @courses;      my %courses;
     foreach my $key (keys (%env)) {       foreach my $key (keys (%env)) { 
                   if ($key =~ m/\.metadata\./) {
         if ($key =~ m/^(course\..+)\.metadata\..+\.options/) {              $key =~ m/^course\.(.+)(\.metadata.+$)/;
             my $course_key = $1;              my $course = $1;
             $course_key .= '.description';              my $coursekey = 'course.'.$course.'.description';
             $r->print($env{$course_key}.' of '.$course_key.'<br />');              my $value = $env{$coursekey};
             push @courses, $key;              $courses{$coursekey} = $value;
         }          }
     }      }
     foreach (@courses) {      $r->print('<h3>Course Related Meta-Data</h3><br />');
         $r->print($_.' was found<br />');  
     }  
     $r->print('<h3>Portfolio 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 your test course<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 (%env)) {          foreach my $key (keys (%courses)) {    
                   if ($meta_not_found) {
         if ($key =~ /\.metadata\./) {              undef($meta_not_found);
             if ($meta_not_found) {              $r->print('<h3>Portfolio Meta-Data</h3><br />');
                 undef($meta_not_found);              $r->print('<form action="" method="post">');
                 $r->print('<h3>Portfolio Meta-Data</h3><br />');              $r->print('Select your course<br />');
                 $r->print('<form action="" method="post">');              $r->print('<select name="metacourse" >');
                 $r->print('Select your course<br />');          }
                 $r->print('<select name="metacourse" >');          $r->print('<option value="'.$key.'">');
             }          $r->print($courses{$key});
             my $course_key = $key;          $r->print('</option>');
             $course_key =~ s/\.metadata\..*//;  
             $r->print('<option value="'.$course_key.'">');  
             $r->print($env{$course_key.'.description'});  
             $r->print('</option>');  
         }  
     }      }
     unless ($meta_not_found) {      unless ($meta_not_found) {
         $r->print('</select><br />');          $r->print('</select><br />');
Line 484  sub relatedfield { Line 476  sub relatedfield {
   
 sub prettyinput {  sub prettyinput {
     my ($type,$value,$fieldname,$formname,      my ($type,$value,$fieldname,$formname,
  $relatedsearchflag,$relatedsep,$relatedvalue,$size)=@_;   $relatedsearchflag,$relatedsep,$relatedvalue,$size,$course_key)=@_;
     if (! defined($size)) {      if (! defined($size)) {
         $size = 80;          $size = 80;
     }      }
       if (defined($course_key)) {
           my $stu_add;
           my $only_one;
           if ($env{$course_key.'.metadata.'.$_.'.options'} =~ m/stuadd/) {
               $stu_add = 'true';
           }
           if ($env{$course_key.'.metadata.'.$_.'.options'} =~ m/onlyone/) {
               $only_one = 'true';
           }
           if ($type eq 'author') {
           }
           if ($type eq 'authorspace') {
           }
           if ($type eq 'modifyinguser') {
           }
           if ($type eq 'subject') {
           }
           if ($type eq 'keywords') {
           }
           if ($type eq  'notes') {
           }
           if ($type eq  'abstract') {
    }
           if (($type eq 'lowestgradelevel') ||
       ($type eq 'highestgradelevel')) {
       return &Apache::loncommon::select_level_form($value,$fieldname).
               &relatedfield(0,$relatedsearchflag,$relatedsep); 
           }
           return(); 
       }
     # Language      # Language
     if ($type eq 'language') {      if ($type eq 'language') {
  return &selectbox($fieldname,   return &selectbox($fieldname,
Line 1015  ENDEDIT Line 1037  ENDEDIT
  my $output;   my $output;
  my @fields;   my @fields;
  if ($file_type eq 'portfolio') {   if ($file_type eq 'portfolio') {
     @fields =  ('author','metadata.title','metadata.subject','metadata.keywords','abstract','notes','lowestgradelevel',      @fields =  ('author','title','subject','keywords','abstract','notes','lowestgradelevel',
                 'highestgradelevel');                  'highestgradelevel');
  } else {   } else {
     @fields = ('author','title','subject','keywords','abstract','notes',      @fields = ('author','title','subject','keywords','abstract','notes',
Line 1033  ENDEDIT Line 1055  ENDEDIT
                 $Apache::lonpublisher::metadatafields{'copyright'}=                  $Apache::lonpublisher::metadatafields{'copyright'}=
                     'default';                      'default';
             }              }
             $output.=('<p>'.$lt{$_}.': '.  
                       &prettyinput($_,  
    $Apache::lonpublisher::metadatafields{$_},  
    'new_'.$_,'defaultmeta').'</p>');  
             if ($env{'form.metacourse'}) {              if ($env{'form.metacourse'}) {
                 $r->print('This is the instructor metadata area<br />');                  # handle restrictions here
                 # have to find all the metadata items, so we'll loop through and find them                  $env{'form.metacourse'} =~ m/(^.+)\.description$/;
                 $r->print('<form method="post" action="" size="3" >');                  my $key_base = $1;
                 $r->print('The course is: '.$env{'form.metacourse'}.'<br>');                  if ($env{$key_base.'.metadata.'.$_.'.options'} =~ m/active/) {
                 foreach my $key (sort keys %env) {                      $output.=('<p>'.$lt{$_}.': '.
                     if ($key=~m/^($env{'form.metacourse'}\.metadata\.)(\d+)\.title/) {                              &prettyinput($_,
                         my $key_base = $1;     $Apache::lonpublisher::metadatafields{$_},
                         my $item_num = $2;     'new_'.$_,'defaultmeta',undef,undef,undef,undef,$key_base).'</p>');
                         # found one, so let's display it  
                         my $title = $env{$key_base.$item_num.'.title'};  
                         my $type = $env{$key_base.$item_num.'.type'};  
                         my @choices = sort(split /, /,$env{$key_base.$item_num.'.values'});  
                         $r->print($title.'<br />');  
                         $r->print($type.'<br />');  
               
             foreach my $word (@choices) {  
                 my $checked;  
                 if ($Apache::lonpublisher::metadatafields{'coursekeyword'}=~ m/$word/) {  
                     $checked = 1;  
                 } else {  
                     undef($checked);  
                 }                  }
                 $r->print(&Apache::lonhtmlcommon::checkbox('instmeta_'.$env{'form.metacourse'}.'_'.$item_num,$checked,$word).$word.'<br />');              } else {
             }                  $output.=('<p>'.$lt{$_}.': '.
         }                              &prettyinput($_,
     }        $Apache::lonpublisher::metadatafields{$_},
     $r->print('<br /><input type="submit" name="store" value="Assign Meta-data" />');     'new_'.$_,'defaultmeta').'</p>');
     $r->print('</form>');  
     return 'ok';  
             }              }
         }          }
         if ($env{'form.store'}) {          if ($env{'form.store'}) {
Line 1074  ENDEDIT Line 1077  ENDEDIT
             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 ($meta_field=~m/^form.instmeta_(.+)_(\d+)$/) {  
                     $r->print('Found a field<br>');  
                 }  
                 if (&Apache::loncommon::get_env_multiple('form.keywords')) {                  if (&Apache::loncommon::get_env_multiple('form.keywords')) {
                 $Apache::lonpublisher::metadatafields{'coursekeyword'} =                   $Apache::lonpublisher::metadatafields{'coursekeyword'} = 
                         join (', ', &Apache::loncommon::get_env_multiple('form.keywords'));                          join (', ', &Apache::loncommon::get_env_multiple('form.keywords'));
Line 1111  ENDEDIT Line 1111  ENDEDIT
                 $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'});
         my $status =&Apache::lonnet::userfileupload($formname,'','portfolio');  
                 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').', '.

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


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