Diff for /loncom/interface/lonparmset.pm between versions 1.242 and 1.248

version 1.242, 2005/08/27 00:03:32 version 1.248, 2005/09/02 22:35:48
Line 1950  sub crsenv { Line 1950  sub crsenv {
      'disablesigfigs'       'disablesigfigs'
                              );                               );
  foreach my $parameter (sort(keys(%values))) {   foreach my $parameter (sort(keys(%values))) {
             unless ($parameter =~ m/^internal\./) {              unless (($parameter =~ m/^internal\./)||($parameter =~ m/^metadata\./)) {
                 if (! $descriptions{$parameter}) {                  if (! $descriptions{$parameter}) {
                     $descriptions{$parameter}=$parameter;                      $descriptions{$parameter}=$parameter;
                     push(@Display_Order,$parameter);                      push(@Display_Order,$parameter);
Line 2189  sub listdata { Line 2189  sub listdata {
     my $pointer=0;      my $pointer=0;
     $tableopen=0;      $tableopen=0;
     my $foundkeys=0;      my $foundkeys=0;
       my %keyorder=&standardkeyorder();
     foreach my $thiskey (sort {      foreach my $thiskey (sort {
    my $return;
  if ($sortorder eq 'realmstudent') {   if ($sortorder eq 'realmstudent') {
     my ($astudent,$arealm)=($a=~/^$env{'request.course.id'}\.([^\.]+)\.(.+)\.[^\.]+$/);      my ($astudent,$arealm)=($a=~/^\Q$env{'request.course.id'}\E\.\[([^\.]+)\]\.(.+)\.[^\.]+$/);
     my ($bstudent,$brealm)=($b=~/^$env{'request.course.id'}\.([^\.]+)\.(.+)\.[^\.]+$/);      my ($bstudent,$brealm)=($b=~/^\Q$env{'request.course.id'}\E\.\[([^\.]+)\]\.(.+)\.[^\.]+$/);
     if (!defined($astudent) && !defined($bstudent) &&      if (!defined($astudent)) {
  !defined($arealm) && !defined($brealm)) {   ($arealm)=($a=~/^\Q$env{'request.course.id'}\E\.(.+)$/);
  ($arealm)=($a=~/^$env{'request.course.id'}\.(.+)\.[^\.]+$/);      }
  ($brealm)=($b=~/^$env{'request.course.id'}\.(.+)\.[^\.]+$/);      if (!defined($bstudent)) {
    ($brealm)=($b=~/^\Q$env{'request.course.id'}\E\.(.+)$/);
       }
       $arealm=~s/\.type//;
       my ($ares, $aparm) = ($arealm=~/^(.*)\.(.*)$/);
       $aparm=$keyorder{'parameter_0_'.$aparm};
       $brealm=~s/\.type//;
       my ($bres, $bparm) = ($brealm=~/^(.*)\.(.*)$/);
       $bparm=$keyorder{'parameter_0_'.$bparm};   
       if ($ares eq $bres) {
    if (defined($aparm) && defined($bparm)) {
       ($aparm <=> $bparm);
    } elsif (defined($aparm)) {
       -1;
    } elsif (defined($bparm)) {
       1;
    } else {
       ($arealm cmp $brealm) || ($astudent cmp $bstudent);
    }
       } else {
    ($arealm cmp $brealm) || ($astudent cmp $bstudent);
     }      }
             ($arealm cmp $brealm) || ($astudent cmp $bstudent);  
  } else {   } else {
     $a cmp $b;      $a cmp $b;
  }   }
     } keys %{$listdata}) {      } keys %{$listdata}) {
     
  if ($$listdata{$thiskey.'.type'}) {   if ($$listdata{$thiskey.'.type'}) {
             my $thistype=$$listdata{$thiskey.'.type'};              my $thistype=$$listdata{$thiskey.'.type'};
             if ($$resourcedata{$thiskey.'.type'}) {              if ($$resourcedata{$thiskey.'.type'}) {
Line 2728  ENDMAINFORMHEAD Line 2750  ENDMAINFORMHEAD
 sub setinstmeta {  sub setinstmeta {
     my ($r)=@_;      my ($r)=@_;
     my $next_meta;      my $next_meta;
     if ($env{'form.nextmeta'}) {      my $output;
         $next_meta = $env{'form.nextmeta'};      my $item_num;
       my $put_result;
       if ($env{'form.serial'}) {
           $next_meta = $env{'form.serial'};
     } else {      } else {
         $next_meta = 1;          $next_meta = 1;
     }      }
Line 2742  sub setinstmeta { Line 2767  sub setinstmeta {
     'Set Instructor Metadata'));      'Set Instructor Metadata'));
     my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};      my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};      my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
     if ($env{'form.state'}eq 'add') {      my $key_base = $env{'course.'.$env{'request.course.id'}.'.metadata.'};
         $r->print('<strong>Compose a new metadata item:</strong><br />');      foreach my $field (%env) {
         $r->print('<form method="post" action="/adm/parmset">');          # start by looking for populated fields
         $r->print ('Title of item: '.&Apache::lonhtmlcommon::textbox("title",undef,undef,undef).'<br />');          if ($field=~m/type(\d+)/) {
         $r->print ('List if items (comma separated): '.&Apache::lonhtmlcommon::textbox("values",undef,undef,undef).'<br />');              my $item_num = $1;
         $r->print ('Select one: <input type="radio" name="type" value="one"><br />');              my $name = 'metadata.'.$item_num.'.type';
         $r->print ('Select many: <input type="radio" name="type" value="many"><br />');              my $value = $env{'form.type'.$item_num};
         $r->print('<input type="hidden" name="serial" value="'.$next_meta.'" />');              $put_result = &Apache::lonnet::put('environment',
         $r->print('<input type="hidden" name="action" value="setinstmeta" />');                                                    {$name=>$value},$dom,$crs);
         $r->print('<input type="hidden" name="state" value="save" />');              $name = 'metadata.'.$item_num.'.values';
         $r->print('<input type="submit" value="Save Metadata">');              $value = $env{'form.values'.$item_num};
         $r->print('</form>');              $put_result = &Apache::lonnet::put('environment',
     } elsif ($env{'form.state'}eq 'save') {                                                    {$name=>$value},$dom,$crs);
         $r->print('Here we save the metadata');          }
     } else {          if ($field=~m/newfield/) {
         foreach my $key (sort keys %env) {              my $item_num = $env{'form.serial'};
             my $found_one = 0;              my $name = 'metadata.'.$item_num.'.type';
             if ($key=~m/^course\.$env{'request.course.id'}\.metadata\.title/) {              my $value = $env{'form.typenew'};
                 unless ($found_one) {              $put_result = &Apache::lonnet::put('environment',
                     $found_one = 1;                                                    {$name=>$value},$dom,$crs);
                     $r->print('<strong>Existing Metadata</strong><br >');              $name = 'metadata.'.$item_num.'.values';
                 }              $value = $env{'form.valuesnew'};
                 $r->print($env{$key}.'<br />');              $put_result = &Apache::lonnet::put('environment',
                 $key=~~m/^course\.$env{'request.course.id'}\.metadata\.title\.(d*)\./;                                                    {$name=>$value},$dom,$crs);
                 if ($1 ge $next_meta) {              $name = 'metadata.'.$item_num.'.title';
                     $next_meta = $1 ++;              $value = $env{'form.titlenew'};
                 }              $put_result = &Apache::lonnet::put('environment',
                                                     {$name=>$value},$dom,$crs);
               
           }
           
                 
       } 
       &Apache::lonnet::coursedescription($env{'request.course.id'});      
       foreach my $key (sort keys %env) {
           if ($key=~m/^course\.$env{'request.course.id'}\.metadata\.\d+\.title$/) {
               $key=~m/(^course\.$env{'request.course.id'}\.metadata\.)(\d+)\.title/;
               $key_base = $1;
               $item_num = $2;
               if ($item_num ge $next_meta) {
                   $next_meta = $item_num + 1;
             }              }
               $output.='<tr><td>'.$env{$key}.'</td>';
               $output.='<td>Select one: <input type="radio" name="type'.$item_num.'" value="one" /><br />';
               $output.='Select many: <input type="radio" name="type'.$item_num.'" value="many" /></td>';
               $output.='<td><input name="values'.$item_num.'" type="text" value="'.$env{$key_base.$item_num.'.values'}.'" /></td></tr>';
         }          }
         $r->print('<a href="/adm/parmset?action=setinstmeta&state=add&nextmeta='.$next_meta.'">Add Metadata Item</a><br />');  
     }      }
       $output.='<tr><td><i>Create new instructor metadata item</i><br />';
       $output.='<input type="text" name="titlenew" /></td>';
       $output.='<td>Select one: <input type="radio" name="typenew" value="one" /><br />';
       $output.='Select many: <input type="radio" name="typenew" value="many" /></td>';
       $output.='<td><input name="valuesnew" type="text" value="" /></td></tr>';
       $output.='<input type="hidden" name="serial" value="'.$next_meta.'" />';
       $output.='<input type="hidden" name="state" value="save" /></tr>';
       $r->print(<<ENDenv);       
           <form method="post" action="/adm/parmset?action=setinstmeta" name="form">
           
           <p>
           <table border=2>
           <tr><th>Title</th><th>Options</th><th>Choices</th></tr>
           $output
           </table>
           <input type="submit" name="instmeta" value="Update Instructor Metadata">
           </form>
   
   ENDenv
           
       
     $r->print('</body>      $r->print('</body>
                 </html>');                  </html>');
     return 'ok';      return 'ok';
Line 2962  sub handler { Line 3025  sub handler {
                                              'pres_marker',                                               'pres_marker',
                                              'pres_value',                                               'pres_value',
                                              'pres_type',                                               'pres_type',
                                              'udom','uname','symb']);                                               'udom','uname','symb','serial']);
   
   
     &Apache::lonhtmlcommon::clear_breadcrumbs();      &Apache::lonhtmlcommon::clear_breadcrumbs();

Removed from v.1.242  
changed lines
  Added in v.1.248


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