Diff for /loncom/interface/lonparmset.pm between versions 1.246 and 1.250

version 1.246, 2005/08/30 01:25:53 version 1.250, 2005/09/14 17:56:25
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 {
  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 2731  sub setinstmeta { Line 2752  sub setinstmeta {
     my $output;      my $output;
     my $item_num;      my $item_num;
     my $put_result;      my $put_result;
     if ($env{'form.serial'}) {  
         $next_meta = $env{'form.serial'};  
     } else {  
         $next_meta = 1;  
     }  
     $r->print(&Apache::lonxml::xmlbegin());      $r->print(&Apache::lonxml::xmlbegin());
     $r->print('<head>      $r->print('<head>
             <title>LON-CAPA Set Instructor Metadata</title>              <title>LON-CAPA Set Instructor Metadata</title>
Line 2749  sub setinstmeta { Line 2765  sub setinstmeta {
     foreach my $field (%env) {      foreach my $field (%env) {
         # start by looking for populated fields          # start by looking for populated fields
         if ($field=~m/type(\d+)/) {          if ($field=~m/type(\d+)/) {
             my $item_num = $1;       my $name;
             my $name = 'metadata.'.$item_num.'.type';      my $value;
             my $value = $env{'form.type'.$item_num};  
             $put_result = &Apache::lonnet::put('environment',              $put_result = &Apache::lonnet::put('environment',
                                                   {$name=>$value},$dom,$crs);                                                    {$name=>$value},$dom,$crs);
             $name = 'metadata.'.$item_num.'.values';  
             $value = $env{'form.values'.$item_num};  
             $put_result = &Apache::lonnet::put('environment',              $put_result = &Apache::lonnet::put('environment',
                                                   {$name=>$value},$dom,$crs);                                                    {$name=>$value},$dom,$crs);
         }          }
         if ($field=~m/newfield/) {          if ($field=~m/newfield/) {
             my $item_num = $env{'form.serial'};              my $name = 'metadata.'.$env{'form.titlenew'};
             my $name = 'metadata.'.$item_num.'.type';              my %meta_hash = {values=>[$env{'form.valuesnew'}],
             my $value = $env{'form.typenew'};              allow_pick=>'many',
             $put_result = &Apache::lonnet::put('environment',              allow_type=>'no'};
                                                   {$name=>$value},$dom,$crs);             
             $name = 'metadata.'.$item_num.'.values';              my $value = \%meta_hash;
             $value = $env{'form.valuesnew'};  
             $put_result = &Apache::lonnet::put('environment',              $put_result = &Apache::lonnet::put('environment',
                                                   {$name=>$value},$dom,$crs);                                                    {$name=>$value},$dom,$crs);
             $name = 'metadata.'.$item_num.'.title';  
             $value = $env{'form.titlenew'};  
             $put_result = &Apache::lonnet::put('environment',  
                                                   {$name=>$value},$dom,$crs);  
               
         }          }
           
                 
     }       } 
     &Apache::lonnet::coursedescription($env{'request.course.id'});            &Apache::lonnet::coursedescription($env{'request.course.id'});      
     foreach my $key (sort keys %env) {      foreach my $key (sort keys %env) {
         if ($key=~m/^course\.$env{'request.course.id'}\.metadata\.\d+\.title$/) {          if ($key=~m/^course\.$env{'request.course.id'}\.metadata\.(.+)$/) {
             $key=~m/(^course\.$env{'request.course.id'}\.metadata\.)(\d+)\.title/;              my $meta_data_item = $1;
             $key_base = $1;              my $meta_hash=$env{$key};
             $item_num = $2;              $output.='<tr><td>'.$meta_data_item.'</td>';
             if ($item_num ge $next_meta) {              $output.='<td>Select one: <input type="checkbox" name="" value="one" /><br />';
                 $next_meta = $item_num + 1;              $output.='Select many: <input type="checkbox" name="type" value="many" /></td>';
             }              $output.='<td><input name="values" type="text" value="$env{$key_base.$item_num.'.'" /></td></tr>';
             $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>';  
         }          }
     }      }
     $output.='<tr><td><i>Create new instructor metadata item</i><br />';      $output.='<tr><td><i>Create new instructor metadata item</i><br />';
     $output.='<input type="text" name="titlenew" /></td>';      $output.='<input type="text" name="titlenew" /></td>';
     $output.='<td>Select one: <input type="radio" name="typenew" value="one" /><br />';      $output.='<td>students must pick only one: <input type="checkbox" name="pickonenew" value="one" /><br />';
     $output.='Select many: <input type="radio" name="typenew" value="many" /></td>';      $output.='Allow student to type extra info: <input type="checkbox" name="typeextranew" value="extra" /></td>';
     $output.='<td><input name="valuesnew" type="text" value="" /></td></tr>';      $output.='<td><input name="valuesnew" type="text" value="" /></td></tr>';
     $output.='<input type="hidden" name="serial" value="'.$next_meta.'" />';      $output.='<input type="hidden" name="serial" value="'.$next_meta.'" />';
     $output.='<input type="hidden" name="state" value="save" /></tr>';      $output.='<input type="hidden" name="state" value="save" /></tr>';

Removed from v.1.246  
changed lines
  Added in v.1.250


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