Diff for /loncom/interface/lonparmset.pm between versions 1.43 and 1.66

version 1.43, 2002/02/12 00:14:07 version 1.66, 2002/09/07 17:30:31
Line 25 Line 25
 #  #
 # http://www.lon-capa.org/  # http://www.lon-capa.org/
 #  #
 # (Handler to resolve ambiguous file locations  ###################################################################
 #  ###################################################################
 # (TeX Content Handler  
 #  =pod
 # YEAR=2000  
 # 05/29/00,05/30,10/11 Gerd Kortemeyer)  =head1 NAME
 #  
 # 10/11,10/12,10/16 Gerd Kortemeyer)  lonparmset - Handler to set parameters for assessments and course
 #  
 # 11/20,11/21,11/22,11/23,11/24,11/25,11/27,11/28,  =head1 SYNOPSIS
 # 12/08,12/12,  
 # YEAR=2001  lonparmset provides an interface to setting course parameters. 
 # 16/01/01,02/08,03/20,03/23,03/24,03/26,05/09,  
 # 07/05,07/06,08/08,08/09,09/01,09/21 Gerd Kortemeyer  =head1 DESCRIPTION
 # 12/17 Scott Harrison  
 # 12/19 Guy Albertelli  This module sets coursewide and assessment parameters.
 # 12/26,12/27 Gerd Kortemeyer  
 #  =head1 INTERNAL SUBROUTINES
 ###  
   =over 4
   
   =cut
   
   ###################################################################
   ###################################################################
   
 package Apache::lonparmset;  package Apache::lonparmset;
   
Line 52  use Apache::lonnet; Line 58  use Apache::lonnet;
 use Apache::Constants qw(:common :http REDIRECT);  use Apache::Constants qw(:common :http REDIRECT);
 use Apache::loncommon;  use Apache::loncommon;
 use GDBM_File;  use GDBM_File;
   use Apache::lonhomework;
   use Apache::lonxml;
   
   
 my %courseopt;  my %courseopt;
 my %useropt;  my %useropt;
 my %bighash;  
 my %parmhash;  my %parmhash;
   
 my @outpar;  
   
 my @ids;  my @ids;
 my %symbp;  my %symbp;
 my %mapp;  my %mapp;
Line 70  my %keyp; Line 75  my %keyp;
 my $uname;  my $uname;
 my $udom;  my $udom;
 my $uhome;  my $uhome;
   
 my $csec;  my $csec;
   my $coursename;
   
 my $fcat;  ##################################################
   ##################################################
   
 # -------------------------------------------- Figure out a cascading parameter  =pod
   
   =item parmval
   
   Figure out a cascading parameter.
   
   Inputs:  $what $id $def
   
   Returns: I am not entirely sure.
   
   =cut
   
   ##################################################
   ##################################################
 sub parmval {  sub parmval {
     my ($what,$id,$def)=@_;      my ($what,$id,$def)=@_;
     my $result='';      my $result='';
     @outpar=();      my @outpar=();
 # ----------------------------------------------------- Cascading lookup scheme  # ----------------------------------------------------- Cascading lookup scheme
   
     my $symbparm=$symbp{$id}.'.'.$what;      my $symbparm=$symbp{$id}.'.'.$what;
Line 155  sub parmval { Line 173  sub parmval {
  }   }
     }      }
   
     return $result;      return ($result,@outpar);
 }  }
   
 # ------------------------------------------------------------ Output for value  ##################################################
   ##################################################
   
   =pod
   
   =item valout
   
   Format a value for output.
   
   Inputs:  $value, $type
   
   Returns: $value, formatted for output.  If $type indicates it is a date,
   localtime($value) is returned.
   
   =cut
   
   ##################################################
   ##################################################
 sub valout {  sub valout {
     my ($value,$type)=@_;      my ($value,$type)=@_;
     return ($value?(($type=~/^date/)?localtime($value):$value):'  ');      my $result = '';
       # Values of zero are valid.
       if (! $value && $value ne '0') {
           $result = '  ';
       } else {
           if ($type eq 'date_interval') {
               my ($sec,$min,$hour,$mday,$mon,$year)=gmtime($value);
               $year=$year-70;
               $mday--;
               if ($year) {
    $result.=$year.' yrs ';
               }
               if ($mon) {
    $result.=$mon.' mths ';
               }
               if ($mday) {
    $result.=$mday.' days ';
               }
               if ($hour) {
    $result.=$hour.' hrs ';
               }
               if ($min) {
    $result.=$min.' mins ';
               }
               if ($sec) {
    $result.=$sec.' secs ';
               }
               $result=~s/\s+$//;
           } elsif ($type=~/^date/) {
               $result = localtime($value);
           } else {
               $result = $value;
           }
       }
       return $result;
 }  }
   
 # -------------------------------------------------------- Produces link anchor  ##################################################
   ##################################################
   
   =pod
   
   =item plink
   
   Produces a link anchor.
   
   Inputs: $type,$dis,$value,$marker,$return,$call
   
   Returns: scalar with html code for a link which will envoke the 
   javascript function 'pjump'.
   
   =cut
   
   ##################################################
   ##################################################
 sub plink {  sub plink {
     my ($type,$dis,$value,$marker,$return,$call)=@_;      my ($type,$dis,$value,$marker,$return,$call)=@_;
     my $winvalue=$value;      my $winvalue=$value;
Line 183  sub plink { Line 267  sub plink {
  &valout($value,$type).'</a><a name="'.$marker.'"></a>';   &valout($value,$type).'</a><a name="'.$marker.'"></a>';
 }  }
   
   
   sub startpage {
       my ($r,$id,$udom,$csec,$uname)=@_;
       $r->content_type('text/html');
       $r->send_http_header;
    
       my $bodytag=&Apache::loncommon::bodytag('Set Course Parameters','',
                                               'onUnload="pclose()"');
       $r->print(<<ENDHEAD);
   <html>
   <head>
   <title>LON-CAPA Course Parameters</title>
   <script>
   
       function pclose() {
           parmwin=window.open("/adm/rat/empty.html","LONCAPAparms",
                    "height=350,width=350,scrollbars=no,menubar=no");
           parmwin.close();
       }
   
       function pjump(type,dis,value,marker,ret,call) {
           document.parmform.pres_marker.value='';
           parmwin=window.open("/adm/rat/parameter.html?type="+escape(type)
                    +"&value="+escape(value)+"&marker="+escape(marker)
                    +"&return="+escape(ret)
                    +"&call="+escape(call)+"&name="+escape(dis),"LONCAPAparms",
                    "height=350,width=350,scrollbars=no,menubar=no");
   
       }
   
       function psub() {
           pclose();
           if (document.parmform.pres_marker.value!='') {
               document.parmform.action+='#'+document.parmform.pres_marker.value;
               var typedef=new Array();
               typedef=document.parmform.pres_type.value.split('_');
              if (document.parmform.pres_type.value!='') {
               if (typedef[0]=='date') {
                   eval('document.parmform.recent_'+
                        document.parmform.pres_type.value+
        '.value=document.parmform.pres_value.value;');
               } else {
                   eval('document.parmform.recent_'+typedef[0]+
        '.value=document.parmform.pres_value.value;');
               }
      }
               document.parmform.submit();
           } else {
               document.parmform.pres_value.value='';
               document.parmform.pres_marker.value='';
           }
       }
   
       function openWindow(url, wdwName, w, h, toolbar,scrollbar) {
           var options = "width=" + w + ",height=" + h + ",";
           options += "resizable=yes,scrollbars="+scrollbar+",status=no,";
           options += "menubar=no,toolbar="+toolbar+",location=no,directories=no";
           var newWin = window.open(url, wdwName, options);
           newWin.focus();
       }
   </script>
   </head>
   $bodytag
   <form method="post" action="/adm/parmset" name="envform">
   <h3>Course Environment</h3>
   <input type="submit" name="crsenv" value="Set Course Environment">
   </form>
   <form method="post" action="/adm/parmset" name="parmform">
   <h3>Course Assessments</h3>
   <b>
   Section/Group:
   <input type="text" value="$csec" size="6" name="csec">
   <br>
   For User 
   <input type="text" value="$uname" size="12" name="uname">
   or ID
   <input type="text" value="$id" size="12" name="id"> 
   at Domain 
   <input type="text" value="$udom" size="6" name="udom">
   </b>
   <input type="hidden" value='' name="pres_value">
   <input type="hidden" value='' name="pres_type">
   <input type="hidden" value='' name="pres_marker">
   ENDHEAD
   
   }
   
   sub print_row {
       my ($r,$which,$part,$name,$rid,$default,$defaulttype,$display,$defbgone,
    $defbgtwo,$parmlev)=@_;
   # get the values for the parameter in cascading order
   # empty levels will remain empty
       my ($result,@outpar)=&parmval($$part{$which}.'.'.$$name{$which},
     $rid,$$default{$which});
   # get the type for the parameters
   # problem: these may not be set for all levels
       my ($typeresult,@typeoutpar)=&parmval($$part{$which}.'.'.
                                             $$name{$which}.'.type',
     $rid,$$defaulttype{$which});
   # cascade down manually
       my $cascadetype=$defaulttype;
       for (my $i=$#typeoutpar;$i>0;$i--) {
    if ($typeoutpar[$i]) { 
               $cascadetype=$typeoutpar[$i];
    } else {
               $typeoutpar[$i]=$cascadetype;
           }
       }
    
       my $parm=$$display{$which};
   
       if ($parmlev eq 'full' || $parmlev eq 'brief') {
           $r->print('<td bgcolor='.$defbgtwo.' align="center">'
                     .$$part{$which}.'</td>');
       } else {    
           $parm=~s|\[.*\]\s||g;
       }
   
       $r->print('<td bgcolor='.$defbgone.'>'.$parm.'</td>');
      
       my $thismarker=$which;
       $thismarker=~s/^parameter\_//;
       my $mprefix=$rid.'&'.$thismarker.'&';
   
       if ($parmlev eq 'general') {
   
           if ($uname) {
               &print_td($r,3,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
           } elsif ($csec) {
               &print_td($r,6,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display); 
           } else {
               &print_td($r,9,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display); 
           }
       } elsif ($parmlev eq 'map') {
   
           if ($uname) {
               &print_td($r,2,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
           } elsif ($csec) {
               &print_td($r,5,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
           } else {
               &print_td($r,8,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
           }
       } else {
   
           &print_td($r,11,'#FFDDDD',$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
   
           if ($parmlev eq 'brief') {
   
              &print_td($r,7,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
   
              if ($csec) {
                  &print_td($r,4,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
              }
              if ($uname) {
                  &print_td($r,1,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
              }
           } else {
   
              &print_td($r,10,'#FFDDDD',$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
              &print_td($r,9,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
              &print_td($r,8,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
              &print_td($r,7,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
   
              if ($csec) {
                  &print_td($r,6,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                  &print_td($r,5,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                  &print_td($r,4,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
              }
              if ($uname) {
                  &print_td($r,3,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                  &print_td($r,2,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                  &print_td($r,1,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
              }
           } # end of $brief if/else
       } # end of $parmlev if/else
   
       if ($parmlev eq 'full' || $parmlev eq 'brief') {
           $r->print('<td bgcolor=#CCCCFF align="center">'.
                     &valout($outpar[$result],$typeoutpar[$result]).'</td>');
       }
       my $sessionval=&Apache::lonnet::EXT('resource.'.$$part{$which}.
                                           '.'.$$name{$which},$symbp{$rid});
       my $sessionvaltype=&Apache::lonnet::EXT('resource.'.$$part{$which}.
                                         '.'.$$name{$which}.'.type',$symbp{$rid});
       $r->print('<td bgcolor=#999999 align="center"><font color=#FFFFFF>'.
                     &valout($sessionval,$sessionvaltype).'&nbsp;'.
                     '</font></td>');
       $r->print('</tr>');
       $r->print("\n");
   }
   
   sub print_td {
       my ($r,$which,$defbg,$result,$outpar,$mprefix,$value,$typeoutpar,$display)=@_;
       $r->print('<td bgcolor='.(($result==$which)?'"#AAFFAA"':$defbg).
                 ' align="center">'.
                 &plink($$typeoutpar[$which],$$display{$value},$$outpar[$which],
                        $mprefix."$which",'parmform.pres','psub').'</td>'."\n");
   }
   
   sub get_env_multiple {
       my ($name) = @_;
       my @values;
       if (defined($ENV{$name})) {
           # exists is it an array
           if (ref($ENV{$name})) {
               @values=@{ $ENV{$name} };
           } else {
               $values[0]=$ENV{$name};
           }
       }
       return(@values);
   }
   
   =pod
   
   =item B<extractResourceInformation>: Given the course data hash, extractResourceInformation extracts lots of information about the course's resources into a variety of hashes.
   
   Input: See list below:
   
   =over 4
   
   =item B<ids>: An array that will contain all of the ids in the course.
   
   =item B<typep>: hash, id->type, where "type" contains the extension of the file, thus, I<problem exam quiz assess survey form>.
   
   =item B<keyp>: hash, id->key list, will contain a comma seperated list of the meta-data keys available for the given id
   
   =item B<allparms>: hash, name of parameter->display value (what is the display value?)
   
   =item B<allparts>: hash, part identification->text representation of part, where the text representation is "[Part $part]"
   
   =item B<allkeys>: hash, full key to part->display value (what's display value?)
   
   =item B<allmaps>: hash, ???
   
   =item B<fcat>: ???
   
   =item B<defp>: hash, ???
   
   =item B<mapp>: ??
   
   =item B<symbp>: hash, id->full sym?
   
   =back
   
   =cut
   
   sub extractResourceInformation {
       my $bighash = shift;
       my $ids = shift;
       my $typep = shift;
       my $keyp = shift;
       my $allparms = shift;
       my $allparts = shift;
       my $allkeys = shift;
       my $allmaps = shift;
       my $fcat = shift;
       my $defp = shift;
       my $mapp = shift;
       my $symbp = shift;
   
       foreach (keys %$bighash) {
    if ($_=~/^src\_(\d+)\.(\d+)$/) {
       my $mapid=$1;
       my $resid=$2;
       my $id=$mapid.'.'.$resid;
       my $srcf=$$bighash{$_};
       if ($srcf=~/\.(problem|exam|quiz|assess|survey|form)$/) {
    $$ids[$#$ids+1]=$id;
    $$typep{$id}=$1;
    $$keyp{$id}='';
    foreach (split(/\,/,&Apache::lonnet::metadata($srcf,'allpossiblekeys'))) {
     if ($_=~/^parameter\_(.*)/) {
                       my $key=$_;
                       my $allkey=$1;
                       $allkey=~s/\_/\./g;
                       my $display= &Apache::lonnet::metadata($srcf,$key.'.display');
                       my $name=&Apache::lonnet::metadata($srcf,$key.'.name');
                       my $part= &Apache::lonnet::metadata($srcf,$key.'.part');
                       my $parmdis = $display;
                       $parmdis =~ s|(\[Part.*$)||g;
                       my $partkey = $part;
                       $partkey =~ tr|_|.|;
                       $$allparms{$name} = $parmdis;
                       $$allparts{$part} = "[Part $part]";
                       $$allkeys{$allkey}=$display;
                       if ($allkey eq $fcat) {
           $$defp{$id}= &Apache::lonnet::metadata($srcf,$key);
       }
       if ($$keyp{$id}) {
           $$keyp{$id}.=','.$key;
       } else {
           $$keyp{$id}=$key;
       }
     }
    }
    $$mapp{$id}=
       &Apache::lonnet::declutter($$bighash{'map_id_'.$mapid});
                   $$mapp{$mapid}=$$mapp{$id};
    $$allmaps{$mapid}=$$mapp{$id};
    $$symbp{$id}=$$mapp{$id}.
    '___'.$resid.'___'.
       &Apache::lonnet::declutter($srcf);
                   $$symbp{$mapid}=$$mapp{$id}.'___(all)';
       }
    }
       }
   }
   
   ##################################################
   ##################################################
   
   =pod
   
   =item assessparms
   
   Show assessment data and parameters.  This is a large routine that should
   be simplified and shortened... someday.
   
   Inputs: $r
   
   Returns: nothing
   
   Variables used (guessed by Jeremy):
   
   =over 4
   
   =item B<pscat>: ParameterS CATegories? ends up a list of the types of parameters that exist, e.g., tol, weight, acc, opendate, duedate, answerdate, sig, maxtries, type.
   
   =item B<psprt>: ParameterS PaRTs? a list of the parts of a problem that we are displaying? Used to display only selected parts?
   
   =item B<allmaps>:
   
   =back
   
   =cut
   
   ##################################################
   ##################################################
 sub assessparms {  sub assessparms {
   
     my $r=shift;      my $r=shift;
 # -------------------------------------------------------- Variable declaration  # -------------------------------------------------------- Variable declaration
     my %allkeys;      my %allkeys;
     my %allmaps;      my %allmaps;
       my %alllevs;
   
       $alllevs{'Resource Level'}='full';
   #    $alllevs{'Resource Level [BRIEF]'}='brief';
       $alllevs{'Map Level'}='map';
       $alllevs{'Course Level'}='general';
   
       my %allparms;
       my %allparts;
   
     my %defp;      my %defp;
     %courseopt=();      %courseopt=();
     %useropt=();      %useropt=();
     %bighash=();      my %bighash=();
   
     @ids=();      @ids=();
     %symbp=();      %symbp=();
Line 204  sub assessparms { Line 637  sub assessparms {
     $udom=$ENV{'form.udom'};      $udom=$ENV{'form.udom'};
     unless ($udom) { $udom=$r->dir_config('lonDefDomain'); }      unless ($udom) { $udom=$r->dir_config('lonDefDomain'); }
   
     my $pscat=$ENV{'form.pscat'};      my @pscat=&get_env_multiple('form.pscat');
     my $pschp=$ENV{'form.pschp'};      my $pschp=$ENV{'form.pschp'};
       my @psprt=&get_env_multiple('form.psprt');
       my $showoptions=$ENV{'form.showoptions'};
   
     my $pssymb='';      my $pssymb='';
       my $parmlev='';
       my $prevvisit=$ENV{'form.prevvisit'};
   
   #    unless ($parmlev==$ENV{'form.parmlev'}) {
   #        $parmlev = 'full';
   #    }
    
       unless ($ENV{'form.parmlev'}) {
           $parmlev = 'map';
       } else {
           $parmlev = $ENV{'form.parmlev'};
       }
   
 # ----------------------------------------------- Was this started from grades?  # ----------------------------------------------- Was this started from grades?
   
Line 215  sub assessparms { Line 663  sub assessparms {
  my $url=$ENV{'form.url'};   my $url=$ENV{'form.url'};
  $url=~s-^http://($ENV{'SERVER_NAME'}|$ENV{'HTTP_HOST'})--;   $url=~s-^http://($ENV{'SERVER_NAME'}|$ENV{'HTTP_HOST'})--;
  $pssymb=&Apache::lonnet::symbread($url);   $pssymb=&Apache::lonnet::symbread($url);
  $pscat='all';   @pscat='all';
  $pschp='';   $pschp='';
           $parmlev = 'full';
     } elsif ($ENV{'form.symb'}) {      } elsif ($ENV{'form.symb'}) {
  $pssymb=$ENV{'form.symb'};   $pssymb=$ENV{'form.symb'};
  $pscat='all';   @pscat='all';
  $pschp='';   $pschp='';
           $parmlev = 'full';
     } else {      } else {
  $ENV{'form.url'}='';   $ENV{'form.url'}='';
     }      }
Line 250  sub assessparms { Line 700  sub assessparms {
     $ENV{'request.course.id'});      $ENV{'request.course.id'});
     if ($csec eq '-1') {      if ($csec eq '-1') {
  $message="<font color=red>".   $message="<font color=red>".
     "User '$uname' at domain '$udom' not in this course</font>";      "User '$uname' at domain '$udom' not ".
                       "in this course</font>";
  $uname='';   $uname='';
  $csec=$ENV{'form.csec'};   $csec=$ENV{'form.csec'};
     } else {      } else {
Line 266  sub assessparms { Line 717  sub assessparms {
   
     unless ($csec) { $csec=''; }      unless ($csec) { $csec=''; }
   
     $fcat=$ENV{'form.fcat'};      my $fcat=$ENV{'form.fcat'};
     unless ($fcat) { $fcat=''; }      unless ($fcat) { $fcat=''; }
   
 # ------------------------------------------------------------------- Tie hashs  # ------------------------------------------------------------------- Tie hashs
     if ((tie(%bighash,'GDBM_File',$ENV{'request.course.fn'}.'.db',      if (!(tie(%bighash,'GDBM_File',$ENV{'request.course.fn'}.'.db',
      &GDBM_READER,0640)) &&        &GDBM_READER(),0640))) {
  (tie(%parmhash,'GDBM_File',   $r->print("Unable to access course data. (File $ENV{'request.course.fn'}.db not tieable)");
      $ENV{'request.course.fn'}.'_parms.db',&GDBM_READER,0640))) {   return ;
       }
       if (!(tie(%parmhash,'GDBM_File',
         $ENV{'request.course.fn'}.'_parms.db',&GDBM_READER(),0640))) {
    $r->print("Unable to access parameter data. (File $ENV{'request.course.fn'}_parms.db not tieable)");
    return ;
       }
   
 # --------------------------------------------------------- Get all assessments  # --------------------------------------------------------- Get all assessments
         foreach (keys %bighash) {      extractResourceInformation(\%bighash, \@ids, \%typep,\%keyp, \%allparms, \%allparts, \%allkeys, \%allmaps, $fcat, \%defp, \%mapp, \%symbp);
     if ($_=~/^src\_(\d+)\.(\d+)$/) {  
  my $mapid=$1;      $mapp{'0.0'} = '';
  my $resid=$2;      $symbp{'0.0'} = '';
  my $id=$mapid.'.'.$resid;  
  my $srcf=$bighash{$_};  
  if ($srcf=~/\.(problem|exam|quiz|assess|survey|form)$/) {  
     $ids[$#ids+1]=$id;  
     $typep{$id}=$1;  
     $keyp{$id}='';  
     foreach (split(/\,/,  
    &Apache::lonnet::metadata($srcf,'keys'))) {  
  if ($_=~/^parameter\_(.*)/) {  
     my $key=$_;  
     my $allkey=$1;  
     $allkey=~s/\_/\./;  
     my $display=  
  &Apache::lonnet::metadata($srcf,$key.'.display');  
     unless ($display) {  
  $display=  
     &Apache::lonnet::metadata($srcf,$key.'.name');  
     }  
     $allkeys{$allkey}=$display;  
     if ($allkey eq $fcat) {  
  $defp{$id}=  
     &Apache::lonnet::metadata($srcf,$key);  
     }  
     if ($keyp{$id}) {  
  $keyp{$id}.=','.$key;  
     } else {  
  $keyp{$id}=$key;  
     }  
  }  
     }  
     $mapp{$id}=  
  &Apache::lonnet::declutter($bighash{'map_id_'.$mapid});  
     $allmaps{$mapid}=$mapp{$id};  
     $symbp{$id}=$mapp{$id}.  
  '___'.$resid.'___'.  
     &Apache::lonnet::declutter($srcf);  
  }  
             }  
         }  
 # ---------------------------------------------------------- Anything to store?  # ---------------------------------------------------------- Anything to store?
         if ($ENV{'form.pres_marker'}) {      if ($ENV{'form.pres_marker'}) {
     my ($sresid,$spnam,$snum)=split(/\&/,$ENV{'form.pres_marker'});   my ($sresid,$spnam,$snum)=split(/\&/,$ENV{'form.pres_marker'});
     $spnam=~s/\_([^\_]+)$/\.$1/;   $spnam=~s/\_([^\_]+)$/\.$1/;
 # ---------------------------------------------------------- Construct prefixes  # ---------------------------------------------------------- Construct prefixes
   
     my $symbparm=$symbp{$sresid}.'.'.$spnam;   my $symbparm=$symbp{$sresid}.'.'.$spnam;
     my $mapparm=$mapp{$sresid}.'___(all).'.$spnam;   my $mapparm=$mapp{$sresid}.'___(all).'.$spnam;
   
     my $seclevel=$ENV{'request.course.id'}.'.['.$csec.'].'.$spnam;   my $seclevel=$ENV{'request.course.id'}.'.['.$csec.'].'.$spnam;
     my $seclevelr=$ENV{'request.course.id'}.'.['.$csec.'].'.$symbparm;   my $seclevelr=$ENV{'request.course.id'}.'.['.$csec.'].'.$symbparm;
     my $seclevelm=$ENV{'request.course.id'}.'.['.$csec.'].'.$mapparm;   my $seclevelm=$ENV{'request.course.id'}.'.['.$csec.'].'.$mapparm;
   
     my $courselevel=$ENV{'request.course.id'}.'.'.$spnam;   my $courselevel=$ENV{'request.course.id'}.'.'.$spnam;
     my $courselevelr=$ENV{'request.course.id'}.'.'.$symbparm;   my $courselevelr=$ENV{'request.course.id'}.'.'.$symbparm;
     my $courselevelm=$ENV{'request.course.id'}.'.'.$mapparm;   my $courselevelm=$ENV{'request.course.id'}.'.'.$mapparm;
   
     my $storeunder='';   my $storeunder='';
     if (($snum==9) || ($snum==3)) { $storeunder=$courselevel; }   if (($snum==9) || ($snum==3)) { $storeunder=$courselevel; }
     if (($snum==8) || ($snum==2)) { $storeunder=$courselevelm; }   if (($snum==8) || ($snum==2)) { $storeunder=$courselevelm; }
     if (($snum==7) || ($snum==1)) { $storeunder=$courselevelr; }   if (($snum==7) || ($snum==1)) { $storeunder=$courselevelr; }
     if ($snum==6) { $storeunder=$seclevel; }   if ($snum==6) { $storeunder=$seclevel; }
     if ($snum==5) { $storeunder=$seclevelm; }   if ($snum==5) { $storeunder=$seclevelm; }
     if ($snum==4) { $storeunder=$seclevelr; }   if ($snum==4) { $storeunder=$seclevelr; }
     $storeunder=&Apache::lonnet::escape($storeunder);  
           my %storecontent = ($storeunder         => $ENV{'form.pres_value'},
     my $storecontent=                              $storeunder.'.type' => $ENV{'form.pres_type'});
  $storeunder.'='.   my $reply='';
     &Apache::lonnet::escape($ENV{'form.pres_value'}).'&'.   if ($snum>3) {
  $storeunder.'.type='.  
     &Apache::lonnet::escape($ENV{'form.pres_type'});  
   
     my $reply='';  
     if ($snum>3) {  
 # ---------------------------------------------------------------- Store Course  # ---------------------------------------------------------------- Store Course
 #  #
 # Expire sheets  # Expire sheets
  &Apache::lonnet::expirespread('','','studentcalc');      &Apache::lonnet::expirespread('','','studentcalc');
  if (($snum==7) || ($snum==4)) {      if (($snum==7) || ($snum==4)) {
     &Apache::lonnet::expirespread('','','assesscalc',$symbp{$sresid});   &Apache::lonnet::expirespread('','','assesscalc',$symbp{$sresid});
  } elsif (($snum==8) || ($snum==5)) {      } elsif (($snum==8) || ($snum==5)) {
     &Apache::lonnet::expirespread('','','assesscalc',$mapp{$sresid});   &Apache::lonnet::expirespread('','','assesscalc',$mapp{$sresid});
  } else {  
     &Apache::lonnet::expirespread('','','assesscalc');  
  }  
   
 # Store parameter  
  $reply=&Apache::lonnet::critical('put:'.  
  $ENV{'course.'.$ENV{'request.course.id'}.'.domain'}.':'.  
  $ENV{'course.'.$ENV{'request.course.id'}.'.num'}.':resourcedata:'.  
  $storecontent,  
  $ENV{'course.'.$ENV{'request.course.id'}.'.home'});  
     } else {      } else {
    &Apache::lonnet::expirespread('','','assesscalc');
       }
   # Store parameter
               $reply=&Apache::lonnet::cput
                   ('resourcedata',\%storecontent,
                    $ENV{'course.'.$ENV{'request.course.id'}.'.domain'},
                    $ENV{'course.'.$ENV{'request.course.id'}.'.num'});
    } else {
 # ------------------------------------------------------------------ Store User  # ------------------------------------------------------------------ Store User
 #  #
 # Expire sheets  # Expire sheets
  &Apache::lonnet::expirespread($uname,$udom,'studentcalc');      &Apache::lonnet::expirespread($uname,$udom,'studentcalc');
  if ($snum==1) {      if ($snum==1) {
     &Apache::lonnet::expirespread   &Apache::lonnet::expirespread
  ($uname,$udom,'assesscalc',$symbp{$sresid});      ($uname,$udom,'assesscalc',$symbp{$sresid});
  } elsif ($snum==2) {      } elsif ($snum==2) {
     &Apache::lonnet::expirespread   &Apache::lonnet::expirespread
  ($uname,$udom,'assesscalc',$mapp{$sresid});      ($uname,$udom,'assesscalc',$mapp{$sresid});
  } else {      } else {
     &Apache::lonnet::expirespread($uname,$udom,'assesscalc');   &Apache::lonnet::expirespread($uname,$udom,'assesscalc');
  }      }
   
 # Store parameter  # Store parameter
  $reply=      $reply=&Apache::lonnet::cput
     &Apache::lonnet::critical('put:'.$udom.':'.$uname.':resourcedata:'.                  ('resourcedata',\%storecontent,$udom,$uname);
       $storecontent,$uhome);   }
            }  
   
     if ($reply=~/^error\:(.*)/) {   if ($reply=~/^error\:(.*)/) {
  $message.="<font color=red>Write Error: $1</font>";      $message.="<font color=red>Write Error: $1</font>";
     }   }
 # ---------------------------------------------------------------- Done storing  # ---------------------------------------------------------------- Done storing
    }      }
 # -------------------------------------------------------------- Get coursedata  # -------------------------------------------------------------- Get coursedata
         my $reply=&Apache::lonnet::reply('dump:'.      %courseopt = &Apache::lonnet::dump
  $ENV{'course.'.$ENV{'request.course.id'}.'.domain'}.':'.          ('resourcedata',
  $ENV{'course.'.$ENV{'request.course.id'}.'.num'}.':resourcedata',           $ENV{'course.'.$ENV{'request.course.id'}.'.domain'},
  $ENV{'course.'.$ENV{'request.course.id'}.'.home'});           $ENV{'course.'.$ENV{'request.course.id'}.'.num'});
         if ($reply!~/^error\:/) {  
     foreach (split(/\&/,$reply)) {  
  my ($name,$value)=split(/\=/,$_);  
  $courseopt{&Apache::lonnet::unescape($name)}=  
     &Apache::lonnet::unescape($value);  
     }  
         }  
 # --------------------------------------------------- Get userdata (if present)  # --------------------------------------------------- Get userdata (if present)
         if ($uname) {      if ($uname) {
     my $reply=          %useropt=&Apache::lonnet::dump('resourcedata',$udom,$uname);
  &Apache::lonnet::reply('dump:'.$udom.':'.$uname.':resourcedata',$uhome);      }
     if ($reply!~/^error\:/) {  
  foreach (split(/\&/,$reply)) {  
     my ($name,$value)=split(/\=/,$_);  
     $useropt{&Apache::lonnet::unescape($name)}=  
  &Apache::lonnet::unescape($value);  
  }  
     }  
         }  
   
 # ------------------------------------------------------------------- Sort this  # ------------------------------------------------------------------- Sort this
   
         @ids=sort  {      @ids=sort  {
     if ($fcat eq '') {   if ($fcat eq '') {
  $a<=>$b;      $a<=>$b;
     } else {   } else {
  1*$outpar[&parmval($fcat,$a,$defp{$a})]<=>      my ($result,@outpar)=&parmval($fcat,$a,$defp{$a});
     1*$outpar[&parmval($fcat,$b,$defp{$b})];      my $aparm=$outpar[$result];
     }      ($result,@outpar)=&parmval($fcat,$b,$defp{$b});
  } @ids;      my $bparm=$outpar[$result];
       1*$aparm<=>1*$bparm;
    }
       } @ids;
   #----------------------------------------------- if all selected, fill in array
       if ($pscat[0] eq "all" || !@pscat) {@pscat = (keys %allparms);}
       if ($psprt[0] eq "all" || !@psprt) {@psprt = (keys %allparts);}
 # ------------------------------------------------------------------ Start page  # ------------------------------------------------------------------ Start page
  $r->content_type('text/html');  
  $r->send_http_header;  
  $r->print(<<ENDHEAD);  
 <html>  
 <head>  
 <title>LON-CAPA Course Parameters</title>  
 <script>  
   
     function pclose() {      &startpage($r,$id,$udom,$csec,$uname);
         parmwin=window.open("/adm/rat/empty.html","LONCAPAparms",  #    if ($ENV{'form.url'}) {
                  "height=350,width=350,scrollbars=no,menubar=no");  # $r->print('<input type="hidden" value="'.$ENV{'form.url'}.
         parmwin.close();  #  '" name="url"><input type="hidden" name="command" value="set">');
   #    }
       $r->print('<input type="hidden" value="true" name="prevvisit">');
   
       foreach ('tolerance','date_default','date_start','date_end',
        'date_interval','int','float','string') {
    $r->print('<input type="hidden" value="'.
     $ENV{'form.recent_'.$_}.'" name="recent_'.$_.'">');
     }      }
   
     function pjump(type,dis,value,marker,ret,call) {      $r->print('<h2>'.$message.'</h2><table>');
         document.parmform.pres_marker.value='';                          
         parmwin=window.open("/adm/rat/parameter.html?type="+escape(type)      $r->print('<tr><td><hr /></td></tr>');
                  +"&value="+escape(value)+"&marker="+escape(marker)  
                  +"&return="+escape(ret)      my $submitmessage;
                  +"&call="+escape(call)+"&name="+escape(dis),"LONCAPAparms",      if (($prevvisit) || ($pschp) || ($pssymb)) {
                  "height=350,width=350,scrollbars=no,menubar=no");          $submitmessage = "Update Display";
       } else {
           $submitmessage = "Display";
     }      }
       if (!$pssymb) {
     function psub() {          $r->print('<tr><td>Select Parameter Level</td><td>');
         pclose();          $r->print('<select name="parmlev">');
         if (document.parmform.pres_marker.value!='') {          foreach (reverse sort keys %alllevs) {
             document.parmform.action+='#'+document.parmform.pres_marker.value;              $r->print('<option value="'.$alllevs{$_}.'"');
             var typedef=new Array();              if ($parmlev eq $alllevs{$_}) {
             typedef=document.parmform.pres_type.value.split('_');                 $r->print(' selected'); 
            if (document.parmform.pres_type.value!='') {  
             if (typedef[0]=='date') {  
                 eval('document.parmform.recent_'+  
                      document.parmform.pres_type.value+  
      '.value=document.parmform.pres_value.value;');  
             } else {  
                 eval('document.parmform.recent_'+typedef[0]+  
      '.value=document.parmform.pres_value.value;');  
             }              }
    }              $r->print('>'.$_.'</option>');
             document.parmform.submit();  
         } else {  
             document.parmform.pres_value.value='';  
             document.parmform.pres_marker.value='';  
         }          }
           $r->print("</select></td>\n");
       
           $r->print('<td><input type="submit" name="dis" value="'.$submitmessage.'"></td>');
   
           $r->print('</tr><tr><td><hr /></td>');
   
           $r->print('<tr><td>Select Enclosing Map</td>');
           $r->print('<td colspan="2"><select name="pschp">');
           $r->print('<option value="all">All Maps</option>');
           foreach (sort {$allmaps{$a} cmp $allmaps{$b}} keys %allmaps) {
               $r->print('<option value="'.$_.'"');
               if (($pschp eq $_)) { $r->print(' selected'); }
               $r->print('>/res/'.$allmaps{$_}.'</option>');
           }
           $r->print("</select></td></tr>\n");
       } else {
           my ($map,$id,$resource)=split(/___/,$pssymb);
           $r->print("<tr><td>Specific Resource</td><td>$resource</td>");
           $r->print('<td><input type="submit" name="dis" value="'.$submitmessage.'"></td>');
           $r->print('</tr>');
           $r->print('<input type="hidden" value="'.$pssymb.'" name="symb">');
     }      }
   
 </script>      $r->print('<tr><td colspan="3"><hr /><input type="checkbox"');
 </head>      if ($showoptions eq 'show') {$r->print(" checked ");}
 <body bgcolor="#FFFFFF" onUnload="pclose()">      $r->print(' name="showoptions" value="show" onclick="form.submit();">Show More Options<hr /></td></tr>');
 <h1>Set Course Parameters</h1>  #    $r->print("<tr><td>Show: $showoptions</td></tr>");
 <form method="post" action="/adm/parmset" name="envform">  #    $r->print("<tr><td>pscat: @pscat</td></tr>");
 <h2>Course: $ENV{'course.'.$ENV{'request.course.id'}.'.description'}</h2>  #    $r->print("<tr><td>psprt: @psprt</td></tr>");
 <h3>Course Environment</h3>  #    $r->print("<tr><td>fcat:  $fcat</td></tr>");
 <input type="submit" name="crsenv" value="Set Course Environment">  
 </form>      if ($showoptions eq 'show') {
 <form method="post" action="/adm/parmset" name="parmform">          my $tempkey;
 <h3>Course Assessments</h3>  
 <b>          $r->print('<tr><td colspan="3" align="center">Select Parameters to View</td></tr>');
 Section/Group:   
 <input type="text" value="$csec" size="6" name="csec">          $r->print('<tr><td colspan="2"><table>');
 <br>          $r->print('<tr><td><input type="checkbox" name="pscat" value="all"');
 For User           $r->print(' checked') unless (@pscat);
 <input type="text" value="$uname" size="12" name="uname">          $r->print('>All Parameters</td>');
 or ID  
 <input type="text" value="$id" size="12" name="id">           my $cnt=0;
 at Domain   
 <input type="text" value="$udom" size="6" name="udom">          foreach $tempkey (sort { $allparms{$a} cmp $allparms{$b} }
 </b>                        keys %allparms ) {
 <input type="hidden" value='' name="pres_value">              ++$cnt;
 <input type="hidden" value='' name="pres_type">              $r->print('</tr><tr>') unless ($cnt%2);
 <input type="hidden" value='' name="pres_marker">               $r->print('<td><input type="checkbox" name="pscat" ');
 ENDHEAD              $r->print('value="'.$tempkey.'"');
  if ($ENV{'form.url'}) {              if ($pscat[0] eq "all" || grep $_ eq $tempkey, @pscat) {
     $r->print('<input type="hidden" value="'.$ENV{'form.url'}.                  $r->print(' checked');
       '" name="url"><input type="hidden" name="command" value="set">');              }
  }              $r->print('>'.$allparms{$tempkey}.'</td>');
  foreach ('tolerance','date_default','date_start','date_end',          }
  'date_interval','int','float','string') {          $r->print('</tr></table>');
     $r->print('<input type="hidden" value="'.  
       $ENV{'form.recent_'.$_}.'" name="recent_'.$_.'">');  #        $r->print('<tr><td>Select Parts</td><td>');
  }          $r->print('<td><select multiple name="psprt" size="5">');
           $r->print('<option value="all"');
         $r->print('<h2>'.$message.'</h2><table><tr><td>Sort list by</td><td>');          $r->print(' selected') unless (@psprt);
  $r->print('<select name="fcat">');          $r->print('>All Parts</option>');
           foreach $tempkey (sort keys %allparts) {
               unless ($tempkey =~ /\./) {
                   $r->print('<option value="'.$tempkey.'"');
                   if ($psprt[0] eq "all" ||  grep $_ == $tempkey, @psprt) {
                       $r->print(' selected');
                   }
                   $r->print('>'.$allparts{$tempkey}.'</option>');
               }
           }
           $r->print('</select></td></tr><tr><td colspan="3"><hr /></td></tr>');
   
           $r->print('<tr><td>Sort list by</td><td>');
           $r->print('<select name="fcat">');
         $r->print('<option value="">Enclosing Map</option>');          $r->print('<option value="">Enclosing Map</option>');
         foreach (reverse sort keys %allkeys) {          foreach (sort keys %allkeys) {
     $r->print('<option value="'.$_.'"');              $r->print('<option value="'.$_.'"');
             if ($fcat eq $_) { $r->print(' selected'); }              if ($fcat eq $_) { $r->print(' selected'); }
             $r->print('>'.$allkeys{$_}.'</option>');              $r->print('>'.$allkeys{$_}.'</option>');
         }          }
  $r->print('</select></tr><tr><td>Select Enclosing Map</td><td><select name=pschp>');          $r->print('</select></td>');
         $r->print('<option value=all>All Maps</option>');  
         foreach (keys %allmaps) {          $r->print('</tr><tr><td colspan="3"><hr /></td></tr>');
     $r->print('<option value="'.$_.'"');  
             if (($pssymb=~/^$allmaps{$_}/) ||       } else { # hide options - include any necessary extras here
                 ($pschp eq $_)) { $r->print(' selected'); }  
             $r->print('>'.$allmaps{$_}.'</option>');          $r->print('<input type="hidden" name="fcat" value="'.$fcat.'">'."\n");
         }  
         $r->print('</select></td></tr><tr><td>Select Parameter</td><td><select name=pscat>');          unless (@pscat) {
         $r->print('<option value=all>All Parameters</option>');            foreach (keys %allparms ) {
         foreach (reverse sort keys %allkeys) {              $r->print('<input type="hidden" name="pscat" value="'.$_.'">'."\n");
     $r->print('<option value="'.$_.'"');            }
             if ($pscat eq $_) { $r->print(' selected'); }          } else {
             $r->print('>'.$allkeys{$_}.'</option>');            foreach (@pscat) {
               $r->print('<input type="hidden" name="pscat" value="'.$_.'">'."\n");
             }
           }
   
           unless (@psprt) {
             foreach (keys %allparts ) {
               $r->print('<input type="hidden" name="psprt" value="'.$_.'">'."\n");
             }
           } else {
             foreach (@psprt) {
               $r->print('<input type="hidden" name="psprt" value="'.$_.'">'."\n");
             }
         }          }
         $r->print('</select></td></tr></table><br><input name=dis type="submit" value="Display">');  
  if (($pscat) || ($pschp) || ($pssymb)) {      }
       $r->print('</table>');
   
       my @temp_psprt;
       foreach my $t (@psprt) {
    push(@temp_psprt, grep {eval (/^$t\./ || ($_ == $t))} (keys %allparts));
       }
   
       @psprt = @temp_psprt;
   
       my @temp_pscat;
       map {
           my $cat = $_;
           push(@temp_pscat, map { $_.'.'.$cat } @psprt);
       } @pscat;
   
       @pscat = @temp_pscat;
   
       if (($prevvisit) || ($pschp) || ($pssymb)) {
 # ----------------------------------------------------------------- Start Table  # ----------------------------------------------------------------- Start Table
     my $catmarker='parameter_'.$pscat;          my @catmarker=map { tr|.|_|; 'parameter_'.$_; } @pscat;
     $catmarker=~s/\./\_/g;          my $csuname=$ENV{'user.name'};
     my $coursespan=$csec?8:5;          my $csudom=$ENV{'user.domain'};
     my $csuname=$ENV{'user.name'};  
     my $csudom=$ENV{'user.domain'};  
     $r->print(<<ENDTABLEHEAD);          if ($parmlev eq 'full' || $parmlev eq 'brief') {
 <p><table border=2>  
 <tr><td colspan=5></td>             my $coursespan=$csec?8:5;
 <th colspan=$coursespan>Any User</th>             $r->print('<p><table border=2>');
 ENDTABLEHEAD             $r->print('<tr><td colspan=5></td>');
     if ($uname) {             $r->print('<th colspan='.($coursespan).'>Any User</th>');
  $r->print("<th colspan=3 rowspan=2>User $uname at Domain $udom</th>");             if ($uname) {
     }                 $r->print("<th colspan=3 rowspan=2>");
     $r->print(<<ENDTABLETWO);                 $r->print("User $uname at Domain $udom</th>");
              }
              $r->print(<<ENDTABLETWO);
 <th rowspan=3>Parameter in Effect</th>  <th rowspan=3>Parameter in Effect</th>
 <th rowspan=3>Current Session Value<br>($csuname at $csudom)</th>  <th rowspan=3>Current Session Value<br>($csuname at $csudom)</th>
 </tr><tr><td colspan=5></td>  </tr><tr><td colspan=5></td><th colspan=2>Resource Level</th>
 <th colspan=2>Resource Level</th>  
 <th colspan=3>in Course</th>  <th colspan=3>in Course</th>
 ENDTABLETWO  ENDTABLETWO
     if ($csec) {             if ($csec) {
  $r->print("<th colspan=3>in Section/Group $csec</th>");                  $r->print("<th colspan=3>in Section/Group $csec</th>");
     }             }
     $r->print(<<ENDTABLEHEADFOUR);             $r->print(<<ENDTABLEHEADFOUR);
 </tr><tr><th>Assessment URL and Title</th><th>Type</th>  </tr><tr><th>Assessment URL and Title</th><th>Type</th>
 <th>Enclosing Map</th><th>Part No.</th><th>Parameter Name</th>  <th>Enclosing Map</th><th>Part No.</th><th>Parameter Name</th>
 <th>default</th><th>from Enclosing Map</th>  <th>default</th><th>from Enclosing Map</th>
 <th>general</th><th>for Enclosing Map</th><th>for Resource</th>  <th>general</th><th>for Enclosing Map</th><th>for Resource</th>
 ENDTABLEHEADFOUR  ENDTABLEHEADFOUR
     if ($csec) {  
  $r->print('<th>general</th><th>for Enclosing Map</th><th>for Resource</th>');             if ($csec) {
     }                 $r->print('<th>general</th><th>for Enclosing Map</th><th>for Resource</th>');
     if ($uname) {             }
  $r->print('<th>general</th><th>for Enclosing Map</th><th>for Resource</th>');  
     }             if ($uname) {
     $r->print('</tr>');                 $r->print('<th>general</th><th>for Enclosing Map</th><th>for Resource</th>');
     my $defbgone='';             }
     my $defbgtwo='';  
     foreach (@ids) {             $r->print('</tr>');
  my $rid=$_;  
  my ($inmapid)=($rid=~/\.(\d+)$/);             my $defbgone='';
  if (($pschp eq 'all') || ($allmaps{$pschp} eq $mapp{$rid}) ||             my $defbgtwo='';
     ($pssymb eq $mapp{$rid}.'___'.$inmapid.'___'.  
      &Apache::lonnet::declutter($bighash{'src_'.$rid}))) {             foreach (@ids) {
   
                   my $rid=$_;
                   my ($inmapid)=($rid=~/\.(\d+)$/);
   
                   if (($pschp eq 'all') || ($allmaps{$pschp} eq $mapp{$rid}) ||
                       ($pssymb eq $symbp{$rid})) {
 # ------------------------------------------------------ Entry for one resource  # ------------------------------------------------------ Entry for one resource
     if ($defbgone eq '"E0E099"') {                      if ($defbgone eq '"E0E099"') {
  $defbgone='"E0E0DD"';                          $defbgone='"E0E0DD"';
     } else {                      } else {
  $defbgone='"E0E099"';                          $defbgone='"E0E099"';
     }                      }
     if ($defbgtwo eq '"FFFF99"') {                      if ($defbgtwo eq '"FFFF99"') {
  $defbgtwo='"FFFFDD"';                          $defbgtwo='"FFFFDD"';
     } else {                      } else {
  $defbgtwo='"FFFF99"';                          $defbgtwo='"FFFF99"';
     }                      }
     @outpar=();                      my $thistitle='';
     my $thistitle='';                      my %name=   ();
     my %name=   ();                      undef %name;
     undef %name;                      my %part=   ();
     my %part=   ();                      my %display=();
     my %display=();                      my %type=   ();
     my %type=   ();                      my %default=();
     my %default=();                      my $uri=&Apache::lonnet::declutter($bighash{'src_'.$rid});
     my $uri=&Apache::lonnet::declutter($bighash{'src_'.$rid});  
                       foreach (split(/\,/,$keyp{$rid})) {
     foreach (split(/\,/,$keyp{$rid})) {                          my $tempkeyp = $_;
  if (($_ eq $catmarker) || ($pscat eq 'all')) {                          if (grep $_ eq $tempkeyp, @catmarker) {
     $part{$_}=&Apache::lonnet::metadata($uri,$_.'.part');                            $part{$_}=&Apache::lonnet::metadata($uri,$_.'.part');
     $name{$_}=&Apache::lonnet::metadata($uri,$_.'.name');                            $name{$_}=&Apache::lonnet::metadata($uri,$_.'.name');
     $display{$_}=&Apache::lonnet::metadata($uri,$_.'.display');                            $display{$_}=&Apache::lonnet::metadata($uri,$_.'.display');
     unless ($display{$_}) { $display{$_}=''; }                            unless ($display{$_}) { $display{$_}=''; }
     $display{$_}.=' ('.$name{$_}.')';                            $display{$_}.=' ('.$name{$_}.')';
     $default{$_}=&Apache::lonnet::metadata($uri,$_);                            $default{$_}=&Apache::lonnet::metadata($uri,$_);
     $type{$_}=&Apache::lonnet::metadata($uri,$_.'.type');                            $type{$_}=&Apache::lonnet::metadata($uri,$_.'.type');
     $thistitle=&Apache::lonnet::metadata($uri,$_.'.title');                            $thistitle=&Apache::lonnet::metadata($uri,$_.'.title');
  }                          }
     }                      }
     my $totalparms=scalar keys %name;                      my $totalparms=scalar keys %name;
     if ($totalparms>0) {                      if ($totalparms>0) {
  my $firstrow=1;                          my $firstrow=1;
  $r->print('<tr><td bgcolor='.$defbgone.  
   ' rowspan='.$totalparms.'><tt><font size=-1>'.                          $r->print('<tr><td bgcolor='.$defbgone.
   join(' / ',split(/\//,$uri)).                               ' rowspan='.$totalparms.
   '</font></tt><p><b>'.                               '><tt><font size=-1>'.
   $bighash{'title_'.$rid});                               join(' / ',split(/\//,$uri)).
  if ($thistitle) {                               '</font></tt><p><b>'.
     $r->print(' ('.$thistitle.')');                               "<a href=\"javascript:openWindow('/res/".$uri.
  }                               "', 'metadatafile', '450', '500', 'no', 'yes')\";".
  $r->print('</b></td>');                               " TARGET=_self>$bighash{'title_'.$rid}");
  $r->print('<td bgcolor='.$defbgtwo.  
   ' rowspan='.$totalparms.'>'.$typep{$rid}.'</td>');                          if ($thistitle) {
  $r->print('<td bgcolor='.$defbgone.                              $r->print(' ('.$thistitle.')');
   ' rowspan='.$totalparms.'><tt><font size=-1>'.                          }
   join(' / ',split(/\//,$mapp{$rid})).'</font></tt></td>');                          $r->print('</a></b></td>');
  foreach (sort keys %name) {                          $r->print('<td bgcolor='.$defbgtwo.
     my $result=&parmval($part{$_}.'.'.$name{$_},$rid,$default{$_});                                        ' rowspan='.$totalparms.'>'.$typep{$rid}.
     unless ($firstrow) {                                         '</td>');
  $r->print('<tr>');   
     } else {                          $r->print('<td bgcolor='.$defbgone.
  $firstrow=0;                                        ' rowspan='.$totalparms.
     }                                        '><tt><font size=-1>');
     $r->print("<td bgcolor=".$defbgtwo.  
       ">$part{$_}</td><td bgcolor=".$defbgone.                          $r->print(' / res / ');
       ">$display{$_}</td>");                          $r->print(join(' / ', split(/\//,$mapp{$rid})));
     my $thismarker=$_;  
     $thismarker=~s/^parameter\_//;                           $r->print('</font></tt></td>');
     my $mprefix=$rid.'&'.$thismarker.'&';  
                           foreach (sort keys %name) {
     $r->print('<td bgcolor='.                              unless ($firstrow) {
       (($result==11)?'"#AAFFAA"':'#FFDDDD').'>'.                                  $r->print('<tr>');
       &valout($outpar[11],$type{$_}).'</td>');                              } else {
     $r->print('<td bgcolor='.                                  undef $firstrow;
       (($result==10)?'"#AAFFAA"':'#FFDDDD').'>'.                              }
       &valout($outpar[10],$type{$_}).'</td>');  
                               &print_row($r,$_,\%part,\%name,$rid,\%default,
     $r->print('<td bgcolor='.                                         \%type,\%display,$defbgone,$defbgtwo,
       (($result==9)?'"#AAFFAA"':$defbgone).'>'.                                         $parmlev);
       &plink($type{$_},$display{$_},$outpar[9],$mprefix.'9',                          }
      'parmform.pres','psub').'</td>');                      }
     $r->print('<td bgcolor='.                  }
       (($result==8)?'"#AAFFAA"':$defbgone).'>'.              } # end foreach ids
       &plink($type{$_},$display{$_},$outpar[8],$mprefix.'8',  
      'parmform.pres','psub').'</td>');  
     $r->print('<td bgcolor='.  
       (($result==7)?'"#AAFFAA"':$defbgone).'>'.  
       &plink($type{$_},$display{$_},$outpar[7],$mprefix.'7',  
      'parmform.pres','psub').'</td>');  
   
     if ($csec) {  
  $r->print('<td bgcolor='.  
   (($result==6)?'"#AAFFAA"':$defbgtwo).'>'.  
   &plink($type{$_},$display{$_},$outpar[6],$mprefix.'6',  
  'parmform.pres','psub').'</td>');  
  $r->print('<td bgcolor='.  
   (($result==5)?'"#AAFFAA"':$defbgtwo).'>'.  
   &plink($type{$_},$display{$_},$outpar[5],$mprefix.'5',  
  'parmform.pres','psub').'</td>');  
  $r->print('<td bgcolor='.  
   (($result==4)?'"#AAFFAA"':$defbgtwo).'>'.  
   &plink($type{$_},$display{$_},$outpar[4],$mprefix.'4',  
  'parmform.pres','psub').'</td>');  
     }  
   
     if ($uname) {  
  $r->print('<td bgcolor='.  
   (($result==3)?'"#AAFFAA"':$defbgone).'>'.  
   &plink($type{$_},$display{$_},$outpar[3],$mprefix.'3',  
  'parmform.pres','psub').'</td>');  
  $r->print('<td bgcolor='.  
   (($result==2)?'"#AAFFAA"':$defbgone).'>'.  
   &plink($type{$_},$display{$_},$outpar[2],$mprefix.'2',  
  'parmform.pres','psub').'</td>');  
  $r->print('<td bgcolor='.  
   (($result==1)?'"#AAFFAA"':$defbgone).'>'.  
   &plink($type{$_},$display{$_},$outpar[1],$mprefix.'1',  
  'parmform.pres','psub').'</td>');  
     }  
     $r->print('<td bgcolor=#CCCCFF>'.&valout($outpar[$result],$type{$_}).'</td>');  
     my $sessionval=&Apache::lonnet::EXT('resource.'.$part{$_}.  
  '.'.$name{$_},$mapp{$rid}.'___'.$inmapid.'___'.$uri);  
     if (($type{$_}=~/^date/) && ($sessionval))  
  { $sessionval=localtime($sessionval); }  
     $r->print('<td bgcolor=#999999><font color=#FFFFFF>'.$sessionval.'&nbsp;'.  
       '</font></td>');  
     $r->print("</tr>");  
  }  
     }  
 # -------------------------------------------------- End entry for one resource  # -------------------------------------------------- End entry for one resource
  }              $r->print('</table>');
     }          } # end of  brief/full
     $r->print('</table>');  #--------------------------------------------------- Entry for parm level map
  }          if ($parmlev eq 'map') {
  $r->print('</form></body></html>');              my $defbgone = '"E0E099"';
  untie(%bighash);              my $defbgtwo = '"FFFF99"';
  untie(%parmhash);  
               my %maplist;
   
               if ($pschp eq 'all') {
                   %maplist = %allmaps; 
               } else {
                   %maplist = ($pschp => $mapp{$pschp});
               }
   
   #-------------------------------------------- for each map, gather information
               my $mapid;
       foreach $mapid (sort {$maplist{$a} cmp $maplist{$b}} keys %maplist) {
                   my $maptitle = $maplist{$mapid};
   
   #-----------------------  loop through ids and get all parameter types for map
   #-----------------------------------------          and associated information
                   my %name = ();
                   my %part = ();
                   my %display = ();
                   my %type = ();
                   my %default = ();
                   my $map = 0;
   
   # $r->print("Catmarker: @catmarker<br />\n");
                  
                   foreach (@ids) {
                     ($map)=(/([\d]*?)\./);
                     my $rid = $_;
           
   #                  $r->print("$mapid:$map:   $rid <br /> \n");
   
                     if ($map eq $mapid) {
                       my $uri=&Apache::lonnet::declutter($bighash{'src_'.$rid});
   #                    $r->print("Keys: $keyp{$rid} <br />\n");
   
   #--------------------------------------------------------------------
   # @catmarker contains list of all possible parameters including part #s
   # $fullkeyp contains the full part/id # for the extraction of proper parameters
   # $tempkeyp contains part 0 only (no ids - ie, subparts)
   # When storing information, store as part 0
   # When requesting information, request from full part
   #-------------------------------------------------------------------
                       foreach (split(/\,/,$keyp{$rid})) {
                         my $tempkeyp = $_;
                         my $fullkeyp = $tempkeyp;
                         $tempkeyp =~ s/_[\d_]+_/_0_/;
                         
                         if ((grep $_ eq $fullkeyp, @catmarker) &&(!$name{$tempkeyp})) {
                           $part{$tempkeyp}="0";
                           $name{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.name');
                           $display{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.display');
                           unless ($display{$tempkeyp}) { $display{$tempkeyp}=''; }
                           $display{$tempkeyp}.=' ('.$name{$tempkeyp}.')';
                           $display{$tempkeyp} =~ s/_[\d_]+_/_0_/;
                           $default{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp);
                           $type{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.type');
                         }
                       } # end loop through keys
                     }
                   } # end loop through ids
                                    
   #---------------------------------------------------- print header information
                   $r->print(<<ENDMAPONE);
   <center><h4>
   <font color="red">Set Defaults for All Resources in map
   <i>$maptitle</i><br />
   Specifically for
   ENDMAPONE
                   if ($uname) {
                       my %name=&Apache::lonnet::userenvironment($udom,$uname,
                         ('firstname','middlename','lastname','generation', 'id'));
                       my $person=$name{'firstname'}.' '.$name{'middlename'}.' '
                              .$name{'lastname'}.' '.$name{'generation'};
                       $r->print("User <i>$uname \($person\) </i> in \n");
                   } else {
                       $r->print("<i>all</i> users in \n");
                   }
               
                   if ($csec) {$r->print("Section <i>$csec</i> of \n")};
   
                   $r->print("<i>$coursename</i><br />");
                   $r->print("</font></h4>\n");
   #---------------------------------------------------------------- print table
                   $r->print('<p><table border="2">');
                   $r->print('<tr><th>Parameter Name</th>');
                   $r->print('<th>Default Value</th>');
                   $r->print('<th>Parameter in Effect</th></tr>');
   
           foreach (sort keys %name) {
                       &print_row($r,$_,\%part,\%name,$mapid,\%default,
                              \%type,\%display,$defbgone,$defbgtwo,
                              $parmlev);
   #                    $r->print("<tr><td>resource.$part{$_}.$name{$_},$symbp{$mapid}</td></tr>\n");
                   }
                   $r->print("</table></center>");
               } # end each map
           } # end of $parmlev eq map
   #--------------------------------- Entry for parm level general (Course level)
           if ($parmlev eq 'general') {
               my $defbgone = '"E0E099"';
               my $defbgtwo = '"FFFF99"';
   
   #-------------------------------------------- for each map, gather information
               my $mapid="0.0";
   #-----------------------  loop through ids and get all parameter types for map
   #-----------------------------------------          and associated information
               my %name = ();
               my %part = ();
               my %display = ();
               my %type = ();
               my %default = ();
                  
               foreach (@ids) {
                   my $rid = $_;
           
                   my $uri=&Apache::lonnet::declutter($bighash{'src_'.$rid});
   
   #--------------------------------------------------------------------
   # @catmarker contains list of all possible parameters including part #s
   # $fullkeyp contains the full part/id # for the extraction of proper parameters
   # $tempkeyp contains part 0 only (no ids - ie, subparts)
   # When storing information, store as part 0
   # When requesting information, request from full part
   #-------------------------------------------------------------------
                   foreach (split(/\,/,$keyp{$rid})) {
                     my $tempkeyp = $_;
                     my $fullkeyp = $tempkeyp;
                     $tempkeyp =~ s/_[\d_]+_/_0_/;
                     if ((grep $_ eq $fullkeyp, @catmarker) &&(!$name{$tempkeyp})) {
                       $part{$tempkeyp}="0";
                       $name{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.name');
                       $display{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.display');
                       unless ($display{$tempkeyp}) { $display{$tempkeyp}=''; }
                       $display{$tempkeyp}.=' ('.$name{$tempkeyp}.')';
                       $display{$tempkeyp} =~ s/_[\d_]+_/_0_/;
                       $default{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp);
                       $type{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.type');
                     }
                   } # end loop through keys
               } # end loop through ids
                                    
   #---------------------------------------------------- print header information
               $r->print(<<ENDMAPONE);
   <center><h4>
   <font color="red">Set Defaults for All Resources in Course
   <i>$coursename</i><br />
   ENDMAPONE
               if ($uname) {
                   my %name=&Apache::lonnet::userenvironment($udom,$uname,
                     ('firstname','middlename','lastname','generation', 'id'));
                   my $person=$name{'firstname'}.' '.$name{'middlename'}.' '
                          .$name{'lastname'}.' '.$name{'generation'};
                   $r->print(" User <i>$uname \($person\) </i> \n");
               } else {
                   $r->print("<i>ALL</i> USERS \n");
               }
               
               if ($csec) {$r->print("Section <i>$csec</i>\n")};
               $r->print("</font></h4>\n");
   #---------------------------------------------------------------- print table
               $r->print('<p><table border="2">');
               $r->print('<tr><th>Parameter Name</th>');
               $r->print('<th>Default Value</th>');
               $r->print('<th>Parameter in Effect</th></tr>');
   
       foreach (sort keys %name) {
                   &print_row($r,$_,\%part,\%name,$mapid,\%default,
                          \%type,\%display,$defbgone,$defbgtwo,$parmlev);
   #                    $r->print("<tr><td>resource.$part{$_}.$name{$_},$symbp{$mapid}</td></tr>\n");
               }
               $r->print("</table></center>");
           } # end of $parmlev eq general
     }      }
 }      $r->print('</form></body></html>');
       untie(%bighash);
       untie(%parmhash);
   } # end sub assessparms
   
   
   ##################################################
   ##################################################
   
   =pod
   
   =item crsenv
   
   Show course data and parameters.  This is a large routine that should
   be simplified and shortened... someday.
   
   Inputs: $r
   
   Returns: nothing
   
   =cut
   
   ##################################################
   ##################################################
 sub crsenv {  sub crsenv {
     my $r=shift;      my $r=shift;
     my $setoutput='';      my $setoutput='';
       my $bodytag=&Apache::loncommon::bodytag(
                                'Set Course Environment Parameters');
       my $dom = $ENV{'course.'.$ENV{'request.course.id'}.'.domain'};
       my $crs = $ENV{'course.'.$ENV{'request.course.id'}.'.num'};
 # -------------------------------------------------- Go through list of changes  # -------------------------------------------------- Go through list of changes
     foreach (keys %ENV) {      foreach (keys %ENV) {
  if ($_=~/^form\.(.+)\_setparmval$/) {   if ($_=~/^form\.(.+)\_setparmval$/) {
Line 734  sub crsenv { Line 1344  sub crsenv {
             }              }
             if ($name eq 'url') {              if ($name eq 'url') {
  $value=~s/^\/res\///;   $value=~s/^\/res\///;
                   my $bkuptime=time;
                   my @tmp = &Apache::lonnet::get
                       ('environment',['url'],$dom,$crs);
                 $setoutput.='Backing up previous URL: '.                  $setoutput.='Backing up previous URL: '.
     &Apache::lonnet::reply('put:'.                      &Apache::lonnet::put
    $ENV{'course.'.$ENV{'request.course.id'}.'.domain'}.                          ('environment',
    ':'.$ENV{'course.'.$ENV{'request.course.id'}.'.num'}.                           {'top level map backup '.$bkuptime => $tmp[1] },
    ':environment:'.                           $dom,$crs).
    &Apache::lonnet::escape('top level map backup '.                      '<br>';
    time).'='.  
    &Apache::lonnet::reply('get:'.  
   $ENV{'course.'.$ENV{'request.course.id'}.'.domain'}.  
   ':'.$ENV{'course.'.$ENV{'request.course.id'}.'.num'}.  
   ':environment:url',  
   $ENV{'course.'.$ENV{'request.course.id'}.'.home'}),  
    $ENV{'course.'.$ENV{'request.course.id'}.'.home'}).  
        '<br>';  
   
             }              }
             if ($name) {              if ($name) {
         $setoutput.='Setting <tt>'.$name.'</tt> to <tt>'.                  $setoutput.='Setting <tt>'.$name.'</tt> to <tt>'.
     $value.'</tt>: '.                      $value.'</tt>: '.
  &Apache::lonnet::reply('put:'.                      &Apache::lonnet::put
        $ENV{'course.'.$ENV{'request.course.id'}.'.domain'}.                              ('environment',{$name=>$value},$dom,$crs).
        ':'.$ENV{'course.'.$ENV{'request.course.id'}.'.num'}.                      '<br>';
        ':environment:'.  
        &Apache::lonnet::escape($name).'='.  
        &Apache::lonnet::escape($value),  
        $ENV{'course.'.$ENV{'request.course.id'}.'.home'}).  
    '<br>';  
     }      }
         }          }
     }      }
 # -------------------------------------------------------- Get parameters again  # -------------------------------------------------------- Get parameters again
     my $rep=&Apache::lonnet::reply  
  ('dump:'.$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}.      my %values=&Apache::lonnet::dump('environment',$dom,$crs);
  ':'.$ENV{'course.'.$ENV{'request.course.id'}.'.num'}.  
  ':environment',  
  $ENV{'course.'.$ENV{'request.course.id'}.'.home'});  
     my $output='';      my $output='';
     if ($rep ne 'con_lost') {      if (! exists($values{'con_lost'})) {
  my %values;  
         my %descriptions=          my %descriptions=
     ('url'            => '<b>Top Level Map</b><br><font color=red> Modification may make assessment data inaccessible</font>',      ('url'            => '<b>Top Level Map</b> '.
      'description'    => '<b>Course Description</b>',                                   '<a href="javascript:openbrowser'.
      'courseid'       => '<b>Course ID or number</b><br>(internal, optional)',                                   "('envform','url','sequence')\">".
      'question.email' => '<b>Feedback Addresses for Content Questions</b><br>(<tt>user:domain,user:domain,...</tt>)',                                   'Browse</a><br><font color=red> '.
      'comment.email'  => '<b>Feedback Addresses for Comments</b><br>(<tt>user:domain,user:domain,...</tt>)',                                   'Modification may make assessment data '.
      'policy.email'   => '<b>Feedback Addresses for Course Policy</b><br>(<tt>user:domain,user:domain,...</tt>)',                                   'inaccessible</font>',
      'hideemptyrows'  => '<b>Hide Empty Rows in Spreadsheets</b><br>("<tt>yes</tt>" for default hiding)',               'description'    => '<b>Course Description</b>',
      'pch.roles.denied'=> '<b>Disallow Resource Discussion for Students</b><br>"<tt>st</tt>": student, "<tt>ta</tt>": TA, "<tt>in</tt>": instructor;<br><tt>role,role,...</tt>)'               'courseid'       => '<b>Course ID or number</b><br>'.
     );                                   '(internal, optional)',
                'default_xml_style' => '<b>Default XML Style File</b> '.
  foreach (split(/\&/,$rep)) {                      '<a href="javascript:openbrowser'.
     my ($name,$value)=split(/\=/,$_);                      "('envform','default_xml_style'".
     $name=&Apache::lonnet::unescape($name);                      ",'sty')\">Browse</a><br>",
     $values{$name}=&Apache::lonnet::unescape($value);               'question.email' => '<b>Feedback Addresses for Content '.
     unless ($descriptions{$name}) {                                   'Questions</b><br>(<tt>user:domain,'.
  $descriptions{$name}=$name;                                   'user:domain,...</tt>)',
                'comment.email'  => '<b>Feedback Addresses for Comments</b><br>'.
                                    '(<tt>user:domain,user:domain,...</tt>)',
                'policy.email'   => '<b>Feedback Addresses for Course Policy</b>'.
                                    '<br>(<tt>user:domain,user:domain,...</tt>)',
                'hideemptyrows'  => '<b>Hide Empty Rows in Spreadsheets</b><br>'.
                                    '("<tt>yes</tt>" for default hiding)',
                'pageseparators'  => '<b>Visibly Separate Items on Pages</b><br>'.
                                    '("<tt>yes</tt>" for visible separation)',
                'pch.roles.denied'=> '<b>Disallow Resource Discussion for '.
                                     'Roles</b><br>"<tt>st</tt>": '.
                                     'student, "<tt>ta</tt>": '.
                                     'TA, "<tt>in</tt>": '.
                                     'instructor;<br><tt>role,role,...</tt>) '.
          Apache::loncommon::help_open_topic("Course_Disable_Discussion"),
                'pch.users.denied' => 
                             '<b>Disallow Resource Discussion for Users</b><br>'.
                                    '(<tt>user:domain,user:domain,...</tt>)',
                'spreadsheet_default_classcalc' 
                    => '<b>Default Course Spreadsheet</b> '.
                       '<a href="javascript:openbrowser'.
                       "('envform','spreadsheet_default_classcalc'".
                       ",'spreadsheet')\">Browse</a><br>",
                'spreadsheet_default_studentcalc' 
                    => '<b>Default Student Spreadsheet</b> '.
                       '<a href="javascript:openbrowser'.
                       "('envform','spreadsheet_default_calc'".
                       ",'spreadsheet')\">Browse</a><br>",
                'spreadsheet_default_assesscalc' 
                    => '<b>Default Assessment Spreadsheet</b> '.
                       '<a href="javascript:openbrowser'.
                       "('envform','spreadsheet_default_assesscalc'".
                       ",'spreadsheet')\">Browse</a><br>",
                );
    foreach (keys(%values)) {
       unless ($descriptions{$_}) {
    $descriptions{$_}=$_;
     }      }
  }   }
  foreach (sort keys %descriptions) {   foreach (sort keys %descriptions) {
     $output.='<tr><td>'.$descriptions{$_}.'</td><td><input name="'.              # onchange is javascript to automatically check the 'Set' button.
  $_.'_value" size=40 value="'.              my $onchange = 'onchange="javascript:window.document.forms'.
     $values{$_}.                  '[\'envform\'].elements[\''.$_.'_setparmval\']'.
  '"></td><td><input type=checkbox name="'.$_.                  '.checked=true;"';
     '_setparmval"></td></tr>';      $output.='<tr><td>'.$descriptions{$_}.'</td>'.
  }                  '<td><input name="'.$_.'_value" size=40 '.
  $output.='<tr><td><i>Create New Environment Variable</i><br>'.                  'value="'.$values{$_}.'" '.$onchange.' /></td>'.
     '<input type="text" size=40 name="newp_name"></td><td>'.                  '<td><input type=checkbox name="'.$_.'_setparmval"></td>'.
                 '<input type="text" size=40 name="newp_value"></td><td>'.                  '</tr>'."\n";
     '<input type="checkbox" name="newp_setparmval"></td></tr>';   }
           my $onchange = 'onchange="javascript:window.document.forms'.
               '[\'envform\'].elements[\'newp_setparmval\']'.
               '.checked=true;"';
    $output.='<tr><td><i>Create New Environment Variable</i><br />'.
       '<input type="text" size=40 name="newp_name" '.
                   $onchange.' /></td><td>'.
               '<input type="text" size=40 name="newp_value" '.
                   $onchange.' /></td><td>'.
       '<input type="checkbox" name="newp_setparmval" /></td></tr>';
     }      }
     $r->print(<<ENDENV);      $r->print(<<ENDENV);
 <html>  <html>
   <script type="text/javascript" language="Javascript" >
       var editbrowser;
       function openbrowser(formname,elementname,only,omit) {
           var url = '/res/?';
           if (editbrowser == null) {
               url += 'launch=1&';
           }
           url += 'catalogmode=interactive&';
           url += 'mode=parmset&';
           url += 'form=' + formname + '&';
           if (only != null) {
               url += 'only=' + only + '&';
           } 
           if (omit != null) {
               url += 'omit=' + omit + '&';
           }
           url += 'element=' + elementname + '';
           var title = 'Browser';
           var options = 'scrollbars=1,resizable=1,menubar=0';
           options += ',width=700,height=600';
           editbrowser = open(url,title,options,'1');
           editbrowser.focus();
       }
   </script>
 <head>  <head>
 <title>LON-CAPA Course Environment</title>  <title>LON-CAPA Course Environment</title>
 </head>  </head>
 <body bgcolor="#FFFFFF">  $bodytag
 <h1>Set Course Parameters</h1>  
 <form method="post" action="/adm/parmset" name="envform">  <form method="post" action="/adm/parmset" name="envform">
 <h2>Course: $ENV{'course.'.$ENV{'request.course.id'}.'.description'}</h2>  
 <h3>Course Environment</h3>  
 $setoutput  $setoutput
 <p>  <p>
 <table border=2>  <table border=2>
Line 827  $output Line 1488  $output
 ENDENV  ENDENV
 }  }
   
 # ================================================================ Main Handler  ##################################################
   ##################################################
   
   =pod
   
   =item handler
   
   Main handler.  Calls &assessparms and &crsenv subroutines.
   
   =cut
   
   ##################################################
   ##################################################
 sub handler {  sub handler {
     my $r=shift;      my $r=shift;
   
Line 842  sub handler { Line 1514  sub handler {
   
     if (($ENV{'request.course.id'}) &&       if (($ENV{'request.course.id'}) && 
  (&Apache::lonnet::allowed('opa',$ENV{'request.course.id'}))) {   (&Apache::lonnet::allowed('opa',$ENV{'request.course.id'}))) {
    
           $coursename=$ENV{'course.'.$ENV{'request.course.id'}.'.description'};
   
  unless (($ENV{'form.crsenv'}) || (!$ENV{'request.course.fn'})) {   unless (($ENV{'form.crsenv'}) || (!$ENV{'request.course.fn'})) {
 # --------------------------------------------------------- Bring up assessment  # --------------------------------------------------------- Bring up assessment
Line 862  sub handler { Line 1536  sub handler {
 1;  1;
 __END__  __END__
   
   =pod
 =head1 NAME  
   
 Apache::lonparmset - Handler to set parameters for assessments  
   
 =head1 SYNOPSIS  
   
 Invoked by /etc/httpd/conf/srm.conf:  
   
  <Location /adm/parmset>  
  PerlAccessHandler       Apache::lonacc  
  SetHandler perl-script  
  PerlHandler Apache::lonparmset  
  ErrorDocument     403 /adm/login  
  ErrorDocument     406 /adm/roles  
  ErrorDocument  500 /adm/errorhandler  
  </Location>  
   
 =head1 INTRODUCTION  
   
 This module sets assessment parameters.  
   
 This is part of the LearningOnline Network with CAPA project  
 described at http://www.lon-capa.org.  
   
 =head1 HANDLER SUBROUTINE  
   
 This routine is called by Apache and mod_perl.  
   
 =over 4  
   
 =item *  
   
 need to be in course  
   
 =item *  
   
 bring up assessment screen or course environment  
   
 =back  
   
 =head1 OTHER SUBROUTINES  
   
 =over 4  
   
 =item *  
   
 parmval() : figure out a cascading parameter  
   
 =item *  
   
 valout() : output for value  
   
 =item *  
   
 plink() : produces link anchor  
   
 =item *  
   
 assessparms() : show assess data and parameters  
   
 =item *  
   
 crsenv() : for the course environment  
   
 =back  =back
   

Removed from v.1.43  
changed lines
  Added in v.1.66


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