--- loncom/interface/lonmeta.pm	2005/08/13 19:32:28	1.105
+++ loncom/interface/lonmeta.pm	2005/08/25 20:46:32	1.107
@@ -1,7 +1,7 @@
 # The LearningOnline Network with CAPA
 # Metadata display handler
 #
-# $Id: lonmeta.pm,v 1.105 2005/08/13 19:32:28 banghart Exp $
+# $Id: lonmeta.pm,v 1.107 2005/08/25 20:46:32 banghart Exp $
 #
 # Copyright Michigan State University Board of Trustees
 #
@@ -577,17 +577,8 @@ sub handler {
     } elsif ($uri=~/\/portfolio\//) {
         $r->print(&Apache::loncommon::bodytag
           ('Edit Portfolio File Information','','','',$resdomain));
-        if ($env{'form.metacourse'}) {
-            &present_instructor_metadata($r,$uri,'portfolio');  
-        } 
-        elsif ($env{'form.keywords'}) {
-            &save_instructor_metadata($r);
-            &select_course($r);
-        } else {
-            &present_editable_metadata($r,$uri,'portfolio');
-            &select_course($r);
-        }
-        
+        &present_editable_metadata($r,$uri,'portfolio');
+        &select_course($r);
     } elsif ($uri=~/^\/\~/) { 
         # Construction space
         $r->print(&Apache::loncommon::bodytag
@@ -921,80 +912,7 @@ sub print_dynamic_metadata {
     $r->print("</table>");
     return;
 }
-sub save_instructor_metadata {
-    my ($r) = @_;
-    my $uri=$r->uri;
-    my $fn=&Apache::lonnet::filelocation('',$uri);
-    my @words =  &Apache::loncommon::get_env_multiple('form.keywords');
-    $r->print('This is the save instructor metadata area<br />');
-    my $mfh;
-    my $formname='store';
-    my $file_content;
-    foreach (sort keys %Apache::lonpublisher::metadatafields) {
-        next if ($_ =~ /\./);
-        my $unikey=$_;
-        $unikey=~/^([A-Za-z]+)/;
-        my $tag=$1;
-        $tag=~tr/A-Z/a-z/;
-        $file_content.= "\n\<$tag";
-        foreach (split(/\,/,
-                  $Apache::lonpublisher::metadatakeys{$unikey})
-                 ) {
-            my $value=$Apache::lonpublisher::metadatafields{$unikey.'.'.$_};
-            $value=~s/\"/\'\'/g;
-            $file_content.=' '.$_.'="'.$value.'"' ;
-                    # print $mfh ' '.$_.'="'.$value.'"';
-        }
-        $file_content.= '>'.
-        &HTML::Entities::encode
-              ($Apache::lonpublisher::metadatafields{$unikey},
-                     '<>&"').
-                     '</'.$tag.'>';
-    }
-
-    foreach my $word (@words) {
-        $r->print('You entered:'.$word.'<br />');
-    }
-    my $tag = 'keywords';
-    $file_content.= "\n\<$tag";
-    $file_content.= '>'.
-        &HTML::Entities::encode
-              (join(', ',@words),
-                     '<>&"').
-                     '</keywords>';
-    $fn =~ /\/portfolio\/(.*)$/;
-    my $new_fn = '/'.$1;
-    $env{'form.'.$formname}=$file_content;
-    $env{'form.'.$formname.'.filename'}=$new_fn;
-    &Apache::lonnet::userfileupload('uploaddoc','',
-	        'portfolio'.$env{'form.currentpath'});
-    my $status =&Apache::lonnet::userfileupload($formname,'','portfolio');
-    if (&Apache::lonnet::userfileupload($formname,'','portfolio') eq 'error: no uploaded file') {
-        $r->print('<p><font color="red">'.
-                      &mt('Could not write metadata').', '.
-                     &mt('FAIL').'</font></p>');
-    } else {
-        $r->print('<p><font color="blue">'.&mt('Wrote Metadata').
-	    ' '.&Apache::lonlocal::locallocaltime(time).
-	    '</font></p>');
-    }
-    return 'ok';
-}
-sub present_instructor_metadata {
-    my ($r,$uri, $file_type) = @_;
-    $r->print('This is the instructor metadata area<br />');
-    my @keywords = sort(split /, /,$env{$env{'form.metacourse'}.'.metadata.keywords'});
-    $r->print($env{'form.metacourse'}.'<br />');
-    $r->print('<form method="post" action="" size="3" >');
-    $r->print('<select name="keywords" size="3" multiple>');
-    foreach my $word (@keywords) {
-        $r->print('<option>'.$word.'</option>');
-    }
-    $r->print('</select>');
-    $r->print('<br /><input type="submit" value="Assign Meta-data" />');
-    $r->print('</form>');
-    return 'ok';
-}
+
 
 
 #####################################################
@@ -1102,11 +1020,34 @@ ENDEDIT
                       &prettyinput($_,
 				   $Apache::lonpublisher::metadatafields{$_},
 				   'new_'.$_,'defaultmeta').'</p>');
+            if ($env{'form.metacourse'}) {
+   
+    $r->print('This is the instructor metadata area<br />');
+    my @keywords = sort(split /, /,$env{$env{'form.metacourse'}.'.metadata.keywords'});
+    $r->print($env{'form.metacourse'}.'<br />');
+    $r->print('<form method="post" action="" size="3" >');
+    foreach my $word (@keywords) {
+        my $checked;
+        if ($Apache::lonpublisher::metadatafields{'coursekeyword'}=~ m/$word/) {
+            $checked = 1;
+        } else {
+            undef($checked);
+        }
+        $r->print(&Apache::lonhtmlcommon::checkbox('keywords',$checked,$word).$word.'<br />');
+    }
+    $r->print('<br /><input type="submit" name="store" value="Assign Meta-data" />');
+    $r->print('</form>');
+    return 'ok';
+            }
         }
         if ($env{'form.store'}) {
             my $mfh;
-            my $formname='store';
+            my $formname='store'; 
             my $file_content;
+            if (&Apache::loncommon::get_env_multiple('form.keywords')) {
+            $Apache::lonpublisher::metadatafields{'coursekeyword'} = 
+                        join (', ', &Apache::loncommon::get_env_multiple('form.keywords'));
+            }
             foreach (sort keys %Apache::lonpublisher::metadatafields) {
                 next if ($_ =~ /\./);
                 my $unikey=$_;