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

version 1.134, 2005/12/05 20:30:16 version 1.140, 2005/12/19 16:00:05
Line 289  sub fieldnames { Line 289  sub fieldnames {
     }      }
     return &Apache::lonlocal::texthash(%fields);      return &Apache::lonlocal::texthash(%fields);
 }  }
   sub pre_select_course {
       my ($r,$uri) = @_;
       my $output;
       my $fn=&Apache::lonnet::filelocation('',$uri);
       my $disuri=$uri;
       %Apache::lonpublisher::metadatafields=();
       %Apache::lonpublisher::metadatakeys=();
       my $result=&Apache::lonnet::getfile($fn);
       if ($result == -1){
           $r->print('Creating new '.$disuri);
       } else {
           &Apache::lonpublisher::metaeval($result);
       }
       $r->print('<form method="post" action="" >');
       $output = &select_course();
       $r->print($output.'<br /><input type="submit" name="store" value="'.
                     &mt('Select Metadata Course Restrictions').'">');
       $r->print('</form>');
       return;
   }
 sub select_course {  sub select_course {
     my ($r)=@_;  
     my %courses;      my %courses;
       my $output;
       my $selected;
     foreach my $key (keys (%env)) {       foreach my $key (keys (%env)) { 
         if ($key =~ m/\.metadata\./) {          if ($key =~ m/\.metadata\./) {
             $key =~ m/^course\.(.+)(\.metadata.+$)/;              $key =~ m/^course\.(.+)(\.metadata.+$)/;
Line 302  sub select_course { Line 322  sub select_course {
             $courses{$coursekey} = $value;              $courses{$coursekey} = $value;
         }          }
     }      }
     $r->print('<h3>Course Related Meta-Data</h3><br />');      &Apache::lonnet::logthis('the restricted is'.$Apache::lonpublisher::metadatafields{'courserestricted'});
     $r->print('<form action="" method="post">');  
     $r->print('Select course restrictions<br />');  
     $r->print('<select name="metacourse" >');  
     my $meta_not_found = 1;      my $meta_not_found = 1;
       if ($Apache::lonpublisher::metadatafields{'courserestricted'} eq 'none') {
           $selected = ' SELECTED ';
       } else {
           $selected = '';
       }
       $output .= '<select name="new_courserestricted" >';
       $output .= '<option value="none" '.$selected.'>None</option>';
     foreach my $key (keys (%courses)) {          foreach my $key (keys (%courses)) {    
         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" >');  
         }  
         $key =~ m/(^.+)\.description$/;          $key =~ m/(^.+)\.description$/;
         $r->print('<option value="'.$1.'">');          if ($Apache::lonpublisher::metadatafields{'courserestricted'} eq $1) {
         $r->print($courses{$key});              $selected = ' SELECTED ';
         $r->print('</option>');          } else {
     }              $selected = '';
     unless ($meta_not_found) {          }
         $r->print('</select><br />');          $output .= '<option value="'.$1.'"'.$selected.'>';
         $r->print('<input type="submit" value="Assign Portfolio Metadata" />');          $output .= $courses{$key};
         $r->print('</form>');          $output .= '</option>';
     }      }
     return 'ok';      $output .= '</select><br />';
       return ($output);
 }  }
 # Pretty printing of metadata field  # Pretty printing of metadata field
   
Line 516  sub prettyinput { Line 534  sub prettyinput {
             $cur_values_stu = $value;              $cur_values_stu = $value;
         }          }
         if ($type eq 'courserestricted') {          if ($type eq 'courserestricted') {
             return ('<input type="hidden" name="new_courserestricted" value="'.$course_key.'" />');              return (&select_course());
               # return ('<input type="hidden" name="new_courserestricted" value="'.$course_key.'" />');
         }          }
         if (($type eq 'keywords') || ($type eq 'subject')          if (($type eq 'keywords') || ($type eq 'subject')
              || ($type eq 'author')||($type eq  'notes')               || ($type eq 'author')||($type eq  'notes')
Line 603  sub prettyinput { Line 622  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 644  sub handler { Line 668  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 1071  ENDEDIT Line 1098  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','standards','courserestricted');                  '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 1079  ENDEDIT Line 1106  ENDEDIT
                  'lowestgradelevel','highestgradelevel','sourceavail','sourcerights',                   'lowestgradelevel','highestgradelevel','sourceavail','sourcerights',
                  'obsolete','obsoletereplacement');                   'obsolete','obsoletereplacement');
         }          }
         my $metacourse;          if ((! $Apache::lonpublisher::metadatafields{'courserestricted'}) &&
         if ($env{'form.metacourse'} ) {                  (! $env{'form.new_courserestricted'})) {
             $Apache::lonpublisher::metadatafields{'courserestricted'} = $env{'form.metacourse'};              $Apache::lonpublisher::metadatafields{'courserestricted'}=
             $metacourse = $env{'form.metacourse'};                  'none';
          } else {          } elsif ($env{'form.new_courserestricted'}) {
             if (! $Apache::lonpublisher::metadatafields{'courserestricted'}) {              $Apache::lonpublisher::metadatafields{'courserestricted'}=
                 $Apache::lonpublisher::metadatafields{'courserestricted'}=                  $env{'form.new_courserestricted'}; 
                     'none';          }           
                 $metacourse = 'none';  
             } else {  
                 $metacourse = $Apache::lonpublisher::metadatafields{'courserestricted'};  
             }  
         }  
         if (! $Apache::lonpublisher::metadatafields{'copyright'}) {          if (! $Apache::lonpublisher::metadatafields{'copyright'}) {
                 $Apache::lonpublisher::metadatafields{'copyright'}=                  $Apache::lonpublisher::metadatafields{'copyright'}=
                 'default';                  'default';
         }          }
         if ($metacourse ne 'none') {          if ($Apache::lonpublisher::metadatafields{'courserestricted'} ne 'none') {
              $r->print('Document metadata restricted by :<strong> '.$env{$metacourse.".description"}."</strong><br />");              $r->print('Using: <strong> '.$env{$Apache::lonpublisher::metadatafields{'courserestricted'}.".description"}.
                           "</strong> metadata framework<br />");
           } else {
               $r->print("This resource is not associated with a metadata framework<br />");
         }          }
         foreach my $field_name(@fields) {          foreach my $field_name(@fields) {
   
Line 1105  ENDEDIT Line 1130  ENDEDIT
                 $Apache::lonpublisher::metadatafields{$field_name}=                  $Apache::lonpublisher::metadatafields{$field_name}=
                     join(',',&Apache::loncommon::get_env_multiple('form.new_'.$field_name));                      join(',',&Apache::loncommon::get_env_multiple('form.new_'.$field_name));
             }              }
             if ($metacourse ne 'none') {              if ($Apache::lonpublisher::metadatafields{'courserestricted'} ne 'none') {
                 # handle restrictions here                  # handle restrictions here
                 if ($env{$metacourse.'.metadata.'.$field_name.'.options'} =~ m/active/){                  if (($env{$Apache::lonpublisher::metadatafields{'courserestricted'}.'.metadata.'.$field_name.'.options'} =~ m/active/) ||
                       ($field_name eq 'courserestricted')){
                     $output.=('<p>'.$lt{$field_name}.': '.                      $output.=('<p>'.$lt{$field_name}.': '.
                               &prettyinput($field_name,                                &prettyinput($field_name,
    $Apache::lonpublisher::metadatafields{$field_name},     $Apache::lonpublisher::metadatafields{$field_name},
    'new_'.$field_name,'defaultmeta',undef,undef,undef,undef,$metacourse).'</p>');                      'new_'.$field_name,'defaultmeta',
                  } elsif ($field_name eq 'courserestricted') {                      undef,undef,undef,undef,
                             $output.=(                      $Apache::lonpublisher::metadatafields{'courserestricted'}).'</p>');
                                 &prettyinput($field_name,  
     $Apache::lonpublisher::metadatafields{$field_name},  
     'new_'.$field_name,'defaultmeta',undef,undef,undef,undef,$metacourse));  
                  }                   }
             } else {              } else {
                 if ($field_name ne 'courserestricted') {  
                     $output.=('<p>'.$lt{$field_name}.': '.                      $output.=('<p>'.$lt{$field_name}.': '.
                             &prettyinput($field_name,                              &prettyinput($field_name,
    $Apache::lonpublisher::metadatafields{$field_name},     $Apache::lonpublisher::metadatafields{$field_name},
    'new_'.$field_name,'defaultmeta').'</p>');     'new_'.$field_name,'defaultmeta').'</p>');
         } else {                 
                     $output.=&prettyinput($field_name,  
    $Apache::lonpublisher::metadatafields{$field_name},  
    'new_'.$field_name,'defaultmeta');  
                 }  
             }              }
         }          }
         if ($env{'form.store'}) {  
       $r->print($output.'<br /><input type="submit" name="store" value="'.
                     &mt('Store Catalog Information').'">');
           
       }
       $r->print('</form>');
               if ($env{'form.store'}) {
             my $mfh;              my $mfh;
             my $formname='store';               my $formname='store'; 
             my $file_content;              my $file_content;
Line 1152  ENDEDIT Line 1177  ENDEDIT
                              $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.'"';
Line 1166  ENDEDIT Line 1191  ENDEDIT
             if ($fn =~ /\/portfolio\//) {              if ($fn =~ /\/portfolio\//) {
                 $fn =~ /\/portfolio\/(.*)$/;                  $fn =~ /\/portfolio\/(.*)$/;
                 my $new_fn = '/'.$1;                  my $new_fn = '/'.$1;
                 $env{'form.'.$formname}=$file_content;                  $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'});
Line 1192  ENDEDIT Line 1217  ENDEDIT
                 }                  }
             }              }
         }          }
  $r->print($output.'<br /><input type="submit" name="store" value="'.  
                   &mt('Store Catalog Information').'">');  
     }  
     $r->print('</form>');  
     return;      return;
 }  }
   

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


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