Annotation of loncom/interface/lonparmset.pm, revision 1.430

1.1       www         1: # The LearningOnline Network with CAPA
                      2: # Handler to set parameters for assessments
                      3: #
1.430   ! schafran    4: # $Id: lonparmset.pm,v 1.429 2009/02/13 17:46:00 raeburn Exp $
1.40      albertel    5: #
                      6: # Copyright Michigan State University Board of Trustees
                      7: #
                      8: # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
                      9: #
                     10: # LON-CAPA is free software; you can redistribute it and/or modify
                     11: # it under the terms of the GNU General Public License as published by
                     12: # the Free Software Foundation; either version 2 of the License, or
                     13: # (at your option) any later version.
                     14: #
                     15: # LON-CAPA is distributed in the hope that it will be useful,
                     16: # but WITHOUT ANY WARRANTY; without even the implied warranty of
                     17: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     18: # GNU General Public License for more details.
                     19: #
                     20: # You should have received a copy of the GNU General Public License
                     21: # along with LON-CAPA; if not, write to the Free Software
                     22: # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
                     23: #
                     24: # /home/httpd/html/adm/gpl.txt
                     25: #
                     26: # http://www.lon-capa.org/
                     27: #
1.59      matthew    28: ###################################################################
                     29: ###################################################################
                     30: 
                     31: =pod
                     32: 
                     33: =head1 NAME
                     34: 
                     35: lonparmset - Handler to set parameters for assessments and course
                     36: 
                     37: =head1 SYNOPSIS
                     38: 
                     39: lonparmset provides an interface to setting course parameters. 
                     40: 
                     41: =head1 DESCRIPTION
                     42: 
                     43: This module sets coursewide and assessment parameters.
                     44: 
                     45: =head1 INTERNAL SUBROUTINES
                     46: 
1.416     jms        47: =over
1.59      matthew    48: 
                     49: =pod
                     50: 
1.416     jms        51: =item parmval()
1.59      matthew    52: 
                     53: Figure out a cascading parameter.
                     54: 
1.71      albertel   55: Inputs:  $what - a parameter spec (incluse part info and name I.E. 0.weight)
1.162     albertel   56:          $id   - a bighash Id number
1.71      albertel   57:          $def  - the resource's default value   'stupid emacs
                     58: 
1.269     raeburn    59: Returns:  A list, the first item is the index into the remaining list of items of parm valuse that is the active one, the list consists of parm values at the 14 possible levels
1.71      albertel   60: 
1.306     albertel   61: 14- General Course
                     62: 13- Map or Folder level in course
1.269     raeburn    63: 12- resource default
                     64: 11- map default
1.306     albertel   65: 10- resource level in course
1.269     raeburn    66: 9 - General for section
                     67: 8 - Map or Folder level for section
                     68: 7 - resource level in section
                     69: 6 - General for group
                     70: 5 - Map or Folder level for group
                     71: 4 - resource level in group
1.71      albertel   72: 3 - General for specific student
1.82      www        73: 2 - Map or Folder level for specific student
1.71      albertel   74: 1 - resource level for specific student
1.2       www        75: 
1.416     jms        76: =item parmval_by_symb()
                     77: 
                     78: =item reset_caches()
                     79: 
                     80: =item cacheparmhash() 
                     81: 
                     82: =item parmhash()
                     83: 
                     84: =item symbcache()
                     85: 
                     86: =item preset_defaults()
                     87: 
                     88: =item date_sanity_info()
                     89: 
                     90: =item storeparm()
                     91: 
                     92: Store a parameter by symb
                     93: 
                     94:     Takes
                     95:     - symb
                     96:     - name of parameter
                     97:     - level
                     98:     - new value
                     99:     - new type
                    100:     - username
                    101:     - userdomain
                    102: 
                    103: =item log_parmset()
                    104: 
                    105: =item storeparm_by_symb_inner()
                    106: 
                    107: =item valout()
                    108: 
                    109: Format a value for output.
                    110: 
                    111: Inputs:  $value, $type, $editable
                    112: 
                    113: Returns: $value, formatted for output.  If $type indicates it is a date,
                    114: localtime($value) is returned.
                    115: $editable will return an icon to click on
                    116: 
                    117: =item plink()
                    118: 
                    119: Produces a link anchor.
                    120: 
                    121: Inputs: $type,$dis,$value,$marker,$return,$call
                    122: 
                    123: Returns: scalar with html code for a link which will envoke the 
                    124: javascript function 'pjump'.
                    125: 
                    126: =item page_js()
                    127: 
                    128: =item startpage()
                    129: 
                    130: =item print_row()
                    131: 
                    132: =item print_td()
                    133: 
                    134: =item print_usergroups()
                    135: 
                    136: =item parm_control_group()
                    137: 
                    138: =item extractResourceInformation() : 
                    139: 
                    140: Given the course data hash, extractResourceInformation extracts lots of information about the course's resources into a variety of hashes.
                    141: 
                    142: Input: See list below:
                    143: 
                    144: =item * B<ids> : An array that will contain all of the ids in the course.
                    145: 
                    146: =item * B<typep> : hash, id->type, where "type" contains the extension of the file, thus, I<problem exam quiz assess survey form>.
                    147: 
                    148: =item * B<keyp> : hash, id->key list, will contain a comma separated list of the meta-data keys available for the given id
                    149: 
                    150: =item * B<allparms> : hash, name of parameter->display value (what is the display value?)
                    151: 
                    152: =item * B<allparts> : hash, part identification->text representation of part, where the text representation is "[Part $part]"
                    153: 
                    154: =item * B<allkeys> : hash, full key to part->display value (what's display value?)
                    155: 
                    156: =item * B<allmaps> : hash, ???
                    157: 
                    158: =item * B<fcat> : ???
                    159: 
                    160: =item * B<defp> : hash, ???
                    161: 
                    162: =item * B<mapp> : ??
                    163: 
                    164: =item * B<symbp> : hash, id->full sym?
                    165: 
                    166: 
                    167: 
                    168: =item isdateparm()
                    169: 
                    170: =item parmmenu()
                    171: 
                    172: =item partmenu()
                    173: 
                    174: =item usermenu()
                    175: 
                    176: =item displaymenu()
                    177: 
                    178: =item mapmenu()
                    179: 
                    180: =item levelmenu()
                    181: 
                    182: =item sectionmenu()
                    183: 
                    184: =item keysplit()
                    185: 
                    186: =item keysinorder()
                    187: 
                    188: =item keysinorder_bytype()
                    189: 
                    190: =item keysindisplayorder()
                    191: 
                    192: =item standardkeyorder()
                    193: 
                    194: =item assessparms() : 
                    195: 
                    196: Show assessment data and parameters.  This is a large routine that should
                    197: be simplified and shortened... someday.
                    198: 
                    199: Inputs: $r
                    200: 
                    201: Returns: nothing
                    202: 
                    203: Variables used (guessed by Jeremy):
                    204: 
                    205: =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.
                    206: 
                    207: =item * B<psprt>: ParameterS PaRTs? a list of the parts of a problem that we are displaying? Used to display only selected parts?
                    208: 
                    209: =item * B<@catmarker> contains list of all possible parameters including part #s
                    210: 
                    211: =item * B<$fullkeyp> contains the full part/id # for the extraction of proper parameters
                    212: 
                    213: =item * B<$tempkeyp> contains part 0 only (no ids - ie, subparts)
                    214:         When storing information, store as part 0
                    215:         When requesting information, request from full part
                    216: 
                    217: =item crsenv()
                    218: 
                    219: Show and set course data and parameters.  This is a large routine that should
                    220: be simplified and shortened... someday.
                    221: 
                    222: Inputs: $r
                    223: 
                    224: Returns: nothing
                    225: 
                    226: =item can_modify_catsettings()
                    227: 
                    228: =item assign_course_categories()
                    229: 
                    230: =item tablestart()
                    231: 
                    232: =item tableend()
                    233: 
                    234: =item extractuser()
                    235: 
                    236: =item parse_listdata_key()
                    237: 
                    238: =item listdata()
                    239: 
                    240: =item date_interval_selector()
                    241: 
                    242: =item get_date_interval_from_form()
                    243: 
                    244: =item default_selector()
                    245: 
                    246: =item string_selector()
                    247: 
                    248: =item dateshift()
                    249: 
                    250: =item newoverview()
                    251: 
                    252: =item secgroup_lister()
                    253: 
                    254: =item overview()
                    255: 
                    256: =item clean_parameters()
                    257: 
                    258: =item date_shift_one()
                    259: 
                    260: =item date_shift_two()
                    261: 
                    262: =item parse_key()
                    263: 
                    264: =item check_cloners() :
                    265: 
                    266: Checks if new users included in list of allowed cloners
                    267: are valid users.  Replaces supplied list with 
                    268: cleaned list containing only users with valid usernames
                    269: and domains.
                    270: 
                    271: Inputs: $clonelist, $oldcloner 
                    272: where $clonelist is ref to array of requested cloners,
                    273: and $oldcloner is ref to array of currently allowed
                    274: cloners.
                    275: 
                    276: Returns: string - comma separated list of requested
                    277: cloners (username:domain) who do not exist in system.
                    278: 
                    279: =item change_clone() :
                    280: 
                    281: Modifies the list of courses a user can clone (stored
                    282: in the user's environment.db file), called when a
                    283: change is made to the list of users allowed to clone
                    284: a course.
                    285: 
                    286: Inputs: $action,$cloner
                    287: where $action is add or drop, and $cloner is identity of 
                    288: user for whom cloning ability is to be changed in course. 
                    289: 
                    290: 
                    291: =item check_cloners()
                    292: 
                    293: =item change_clone()
                    294: 
                    295: =item header()
                    296: 
                    297: Output html header for page
                    298: 
                    299: =item print_main_menu()
                    300: 
                    301: =item output_row()
                    302: 
                    303: Set portfolio metadata
                    304: 
                    305: =item order_meta_fields()
                    306: 
                    307: =item addmetafield()
                    308: 
                    309: =item setrestrictmeta()
                    310: 
                    311: =item get_added_meta_fieldnames()
                    312: 
                    313: =item get_deleted_meta_fieldnames()
                    314: 
                    315: =item defaultsetter()
                    316: 
                    317: =item components()
                    318: 
                    319: =item load_parameter_names()
                    320: 
                    321: =item parm_change_log()
                    322: 
                    323: =item handler() : 
                    324: 
                    325: Main handler.  Calls &assessparms and &crsenv subroutines.
                    326: 
                    327: 
                    328: =back
                    329: 
1.59      matthew   330: =cut
                    331: 
1.416     jms       332: ###################################################################
                    333: ###################################################################
                    334: 
                    335: package Apache::lonparmset;
                    336: 
                    337: use strict;
                    338: use Apache::lonnet;
                    339: use Apache::Constants qw(:common :http REDIRECT);
                    340: use Apache::lonhtmlcommon();
                    341: use Apache::loncommon;
                    342: use GDBM_File;
                    343: use Apache::lonhomework;
                    344: use Apache::lonxml;
                    345: use Apache::lonlocal;
                    346: use Apache::lonnavmaps;
                    347: use Apache::longroup;
                    348: use Apache::lonrss;
                    349: use LONCAPA qw(:DEFAULT :match);
                    350: 
                    351: 
1.2       www       352: sub parmval {
1.275     raeburn   353:     my ($what,$id,$def,$uname,$udom,$csec,$cgroup,$courseopt)=@_;
                    354:     return &parmval_by_symb($what,&symbcache($id),$def,$uname,$udom,$csec,
                    355:                                                            $cgroup,$courseopt);
1.201     www       356: }
                    357: 
                    358: sub parmval_by_symb {
1.275     raeburn   359:     my ($what,$symb,$def,$uname,$udom,$csec,$cgroup,$courseopt)=@_;
1.200     www       360: 
1.352     albertel  361:     my $useropt;
                    362:     if ($uname ne '' && $udom ne '') {
                    363: 	$useropt = &Apache::lonnet::get_userresdata($uname,$udom);
                    364:     }
1.200     www       365: 
1.8       www       366:     my $result='';
1.44      albertel  367:     my @outpar=();
1.2       www       368: # ----------------------------------------------------- Cascading lookup scheme
1.201     www       369:     my $map=(&Apache::lonnet::decode_symb($symb))[0];    
1.305     albertel  370:     $map = &Apache::lonnet::deversion($map);
1.10      www       371: 
1.201     www       372:     my $symbparm=$symb.'.'.$what;
                    373:     my $mapparm=$map.'___(all).'.$what;
1.10      www       374: 
1.269     raeburn   375:     my $grplevel=$env{'request.course.id'}.'.['.$cgroup.'].'.$what;
                    376:     my $grplevelr=$env{'request.course.id'}.'.['.$cgroup.'].'.$symbparm;
                    377:     my $grplevelm=$env{'request.course.id'}.'.['.$cgroup.'].'.$mapparm;
                    378: 
1.190     albertel  379:     my $seclevel=$env{'request.course.id'}.'.['.$csec.'].'.$what;
                    380:     my $seclevelr=$env{'request.course.id'}.'.['.$csec.'].'.$symbparm;
                    381:     my $seclevelm=$env{'request.course.id'}.'.['.$csec.'].'.$mapparm;
                    382: 
                    383:     my $courselevel=$env{'request.course.id'}.'.'.$what;
                    384:     my $courselevelr=$env{'request.course.id'}.'.'.$symbparm;
                    385:     my $courselevelm=$env{'request.course.id'}.'.'.$mapparm;
1.2       www       386: 
1.11      www       387: 
1.182     albertel  388: # --------------------------------------------------------- first, check course
1.11      www       389: 
1.200     www       390:     if (defined($$courseopt{$courselevel})) {
1.269     raeburn   391: 	$outpar[14]=$$courseopt{$courselevel};
                    392: 	$result=14;
1.43      albertel  393:     }
1.11      www       394: 
1.200     www       395:     if (defined($$courseopt{$courselevelm})) {
1.269     raeburn   396: 	$outpar[13]=$$courseopt{$courselevelm};
                    397: 	$result=13;
1.43      albertel  398:     }
1.11      www       399: 
1.182     albertel  400: # ------------------------------------------------------- second, check default
                    401: 
1.269     raeburn   402:     if (defined($def)) { $outpar[12]=$def; $result=12; }
1.182     albertel  403: 
                    404: # ------------------------------------------------------ third, check map parms
                    405: 
1.376     albertel  406:     my $thisparm=&parmhash($symbparm);
1.269     raeburn   407:     if (defined($thisparm)) { $outpar[11]=$thisparm; $result=11; }
1.182     albertel  408: 
1.200     www       409:     if (defined($$courseopt{$courselevelr})) {
1.269     raeburn   410: 	$outpar[10]=$$courseopt{$courselevelr};
                    411: 	$result=10;
1.43      albertel  412:     }
1.11      www       413: 
1.182     albertel  414: # ------------------------------------------------------ fourth, back to course
1.352     albertel  415:     if ($csec ne '') {
1.200     www       416:         if (defined($$courseopt{$seclevel})) {
1.269     raeburn   417: 	    $outpar[9]=$$courseopt{$seclevel};
                    418: 	    $result=9;
1.43      albertel  419: 	}
1.200     www       420:         if (defined($$courseopt{$seclevelm})) {
1.269     raeburn   421: 	    $outpar[8]=$$courseopt{$seclevelm};
                    422: 	    $result=8;
1.43      albertel  423: 	}
                    424: 
1.200     www       425:         if (defined($$courseopt{$seclevelr})) {
1.269     raeburn   426: 	    $outpar[7]=$$courseopt{$seclevelr};
                    427: 	    $result=7;
1.43      albertel  428: 	}
                    429:     }
1.275     raeburn   430: # ------------------------------------------------------ fifth, check course group
1.352     albertel  431:     if ($cgroup ne '') {
1.269     raeburn   432:         if (defined($$courseopt{$grplevel})) {
                    433:             $outpar[6]=$$courseopt{$grplevel};
                    434:             $result=6;
                    435:         }
                    436:         if (defined($$courseopt{$grplevelm})) {
                    437:             $outpar[5]=$$courseopt{$grplevelm};
                    438:             $result=5;
                    439:         }
                    440:         if (defined($$courseopt{$grplevelr})) {
                    441:             $outpar[4]=$$courseopt{$grplevelr};
                    442:             $result=4;
                    443:         }
                    444:     }
1.11      www       445: 
1.182     albertel  446: # ---------------------------------------------------------- fifth, check user
1.11      www       447: 
1.352     albertel  448:     if ($uname ne '') {
1.200     www       449: 	if (defined($$useropt{$courselevel})) {
                    450: 	    $outpar[3]=$$useropt{$courselevel};
1.43      albertel  451: 	    $result=3;
                    452: 	}
1.10      www       453: 
1.200     www       454: 	if (defined($$useropt{$courselevelm})) {
                    455: 	    $outpar[2]=$$useropt{$courselevelm};
1.43      albertel  456: 	    $result=2;
                    457: 	}
1.2       www       458: 
1.200     www       459: 	if (defined($$useropt{$courselevelr})) {
                    460: 	    $outpar[1]=$$useropt{$courselevelr};
1.43      albertel  461: 	    $result=1;
                    462: 	}
                    463:     }
1.44      albertel  464:     return ($result,@outpar);
1.2       www       465: }
                    466: 
1.198     www       467: 
                    468: 
1.376     albertel  469: # --- Caches local to lonparmset
                    470: 
                    471:     
                    472: sub reset_caches {
                    473:     &resetparmhash();
                    474:     &resetsymbcache();
                    475:     &resetrulescache();
1.203     www       476: }
                    477: 
1.376     albertel  478: {
                    479:     my $parmhashid;
                    480:     my %parmhash;
                    481:     sub resetparmhash {
                    482: 	undef($parmhashid);
                    483: 	undef(%parmhash);
                    484:     }
                    485:     
                    486:     sub cacheparmhash {
                    487: 	if ($parmhashid eq  $env{'request.course.fn'}) { return; }
                    488: 	my %parmhashfile;
                    489: 	if (tie(%parmhashfile,'GDBM_File',
                    490: 		$env{'request.course.fn'}.'_parms.db',&GDBM_READER(),0640)) {
                    491: 	    %parmhash=%parmhashfile;
                    492: 	    untie(%parmhashfile);
                    493: 	    $parmhashid=$env{'request.course.fn'};
                    494: 	}
1.201     www       495:     }
1.376     albertel  496:  
                    497:     sub parmhash {
                    498: 	my ($id) = @_;
                    499: 	&cacheparmhash();
                    500: 	return $parmhash{$id};
                    501:     }
                    502:  }
                    503: 
                    504: {   
                    505:     my $symbsid;
                    506:     my %symbs;
                    507:     sub resetsymbcache {
                    508: 	undef($symbsid);
                    509: 	undef(%symbs);
                    510:     }
                    511:     
                    512:     sub symbcache {
                    513: 	my $id=shift;
                    514: 	if ($symbsid ne $env{'request.course.id'}) {
                    515: 	    undef(%symbs);
                    516: 	}
                    517: 	if (!$symbs{$id}) {
                    518: 	    my $navmap = Apache::lonnavmaps::navmap->new();
                    519: 	    if ($id=~/\./) {
                    520: 		my $resource=$navmap->getById($id);
                    521: 		$symbs{$id}=$resource->symb();
                    522: 	    } else {
                    523: 		my $resource=$navmap->getByMapPc($id);
                    524: 		$symbs{$id}=&Apache::lonnet::declutter($resource->src());
                    525: 	    }
                    526: 	    $symbsid=$env{'request.course.id'};
1.201     www       527: 	}
1.376     albertel  528: 	return $symbs{$id};
1.201     www       529:     }
1.376     albertel  530:  }
1.201     www       531: 
1.376     albertel  532: {   
                    533:     my $rulesid;
                    534:     my %rules;
                    535:     sub resetrulescache {
                    536: 	undef($rulesid);
                    537: 	undef(%rules);
                    538:     }
                    539:     
                    540:     sub rulescache {
                    541: 	my $id=shift;
                    542: 	if ($rulesid ne $env{'request.course.id'}
                    543: 	    && !defined($rules{$id})) {
                    544: 	    my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                    545: 	    my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
                    546: 	    %rules=&Apache::lonnet::dump('parmdefactions',$dom,$crs);
                    547: 	    $rulesid=$env{'request.course.id'};
                    548: 	}
                    549: 	return $rules{$id};
1.221     www       550:     }
                    551: }
                    552: 
1.416     jms       553: 
                    554: 
1.229     www       555: sub preset_defaults {
                    556:     my $type=shift;
                    557:     if (&rulescache($type.'_action') eq 'default') {
                    558: # yes, there is something
                    559: 	return (&rulescache($type.'_hours'),
                    560: 		&rulescache($type.'_min'),
                    561: 		&rulescache($type.'_sec'),
                    562: 		&rulescache($type.'_value'));
                    563:     } else {
                    564: # nothing there or something else
                    565: 	return ('','','','','');
                    566:     }
                    567: }
                    568: 
1.416     jms       569: 
                    570: 
1.277     www       571: 
                    572: sub date_sanity_info {
                    573:    my $checkdate=shift;
                    574:    unless ($checkdate) { return ''; }
                    575:    my $result='';
                    576:    my $crsprefix='course.'.$env{'request.course.id'}.'.';
                    577:    if ($env{$crsprefix.'default_enrollment_end_date'}) {
                    578:       if ($checkdate>$env{$crsprefix.'default_enrollment_end_date'}) {
1.413     bisitz    579:          $result.='<div class="LC_warning">'
                    580:                  .&mt('After course enrollment end!')
                    581:                  .'</div>';
1.277     www       582:       }
                    583:    }
                    584:    if ($env{$crsprefix.'default_enrollment_start_date'}) {
                    585:       if ($checkdate<$env{$crsprefix.'default_enrollment_start_date'}) {
1.413     bisitz    586:          $result.='<div class="LC_warning">'
                    587:                  .&mt('Before course enrollment start!')
                    588:                  .'</div>';
1.277     www       589:       }
                    590:    }
1.413     bisitz    591: # Preparation for additional warnings about dates in the past/future.
                    592: # An improved, more context sensitive version is recommended,
                    593: # e.g. warn for due and answer dates which are defined before the corresponding open date, etc.
                    594: #   if ($checkdate<time) {
                    595: #      $result.='<div class="LC_info">'
                    596: #              .'('.&mt('in the past').')'
                    597: #              .'</div>';
                    598: #      }
                    599: #   if ($checkdate>time) {
                    600: #      $result.='<div class="LC_info">'
                    601: #              .'('.&mt('in the future').')'
                    602: #              .'</div>';
                    603: #      }
1.277     www       604:    return $result;
                    605: }
                    606: ##################################################
1.186     www       607: ##################################################
                    608: #
1.197     www       609: # Store a parameter by ID
1.186     www       610: #
                    611: # Takes
                    612: # - resource id
                    613: # - name of parameter
                    614: # - level
                    615: # - new value
                    616: # - new type
1.187     www       617: # - username
                    618: # - userdomain
                    619: 
1.186     www       620: sub storeparm {
1.269     raeburn   621:     my ($sresid,$spnam,$snum,$nval,$ntype,$uname,$udom,$csec,$cgroup)=@_;
1.275     raeburn   622:     &storeparm_by_symb(&symbcache($sresid),$spnam,$snum,$nval,$ntype,$uname,$udom,$csec,'',$cgroup);
1.197     www       623: }
                    624: 
1.226     www       625: my %recstack;
1.197     www       626: sub storeparm_by_symb {
1.275     raeburn   627:     my ($symb,$spnam,$snum,$nval,$ntype,$uname,$udom,$csec,$recflag,$cgroup)=@_;
1.226     www       628:     unless ($recflag) {
                    629: # first time call
                    630: 	%recstack=();
                    631: 	$recflag=1;
                    632:     }
                    633: # store parameter
                    634:     &storeparm_by_symb_inner
1.269     raeburn   635: 	($symb,$spnam,$snum,$nval,$ntype,$uname,$udom,$csec,$cgroup);
1.266     www       636: # don't do anything if parameter was reset
                    637:     unless ($nval) { return; }
1.226     www       638:     my ($prefix,$parm)=($spnam=~/^(.*[\_\.])([^\_\.]+)$/);
                    639: # remember that this was set
                    640:     $recstack{$parm}=1;
                    641: # what does this trigger?
                    642:     foreach my $triggered (split(/\:/,&rulescache($parm.'_triggers'))) {
                    643: # don't backfire
                    644:        unless ((!$triggered) || ($recstack{$triggered})) {
                    645: 	   my $action=&rulescache($triggered.'_action');
                    646: 	   my ($whichaction,$whichparm)=($action=~/^(.*\_)([^\_]+)$/);
                    647: # set triggered parameter on same level
                    648: 	   my $newspnam=$prefix.$triggered;
1.227     www       649: 	   my $newvalue='';
1.228     www       650: 	   my $active=1;
                    651: 	   if ($action=~/^when\_setting/) {
                    652: # are there restrictions?
                    653: 	       if (&rulescache($triggered.'_triggervalue')=~/\w/) {
                    654: 		   $active=0;
                    655: 		   foreach my $possiblevalue (split(/\s*\,\s*/,&rulescache($triggered.'_triggervalue'))) {
                    656: 		       if (lc($possiblevalue) eq lc($nval)) { $active=1; }
                    657: 		   }
                    658: 	       }
                    659: 	       $newvalue=&rulescache($triggered.'_value');
1.227     www       660: 	   } else {
                    661: 	       my $totalsecs=((&rulescache($triggered.'_days')*24+&rulescache($triggered.'_hours'))*60+&rulescache($triggered.'_min'))*60+&rulescache($triggered.'_sec');
1.228     www       662: 	       if ($action=~/^later\_than/) {
                    663: 		   $newvalue=$nval+$totalsecs;
                    664: 	       } else {
                    665: 		   $newvalue=$nval-$totalsecs;
                    666: 	       }
                    667: 	   }
                    668: 	   if ($active) {
                    669: 	       &storeparm_by_symb($symb,$newspnam,$snum,$newvalue,&rulescache($triggered.'_type'),
1.275     raeburn   670: 				   $uname,$udom,$csec,$recflag,$cgroup);
1.227     www       671: 	   }
1.226     www       672:        }
                    673:     }
                    674:     return '';
                    675: }
                    676: 
1.293     www       677: sub log_parmset {
                    678:     return &Apache::lonnet::instructor_log('parameterlog',@_);
1.284     www       679: }
                    680: 
1.226     www       681: sub storeparm_by_symb_inner {
1.197     www       682: # ---------------------------------------------------------- Get symb, map, etc
1.269     raeburn   683:     my ($symb,$spnam,$snum,$nval,$ntype,$uname,$udom,$csec,$cgroup)=@_;
1.197     www       684: # ---------------------------------------------------------- Construct prefixes
1.186     www       685:     $spnam=~s/\_([^\_]+)$/\.$1/;
1.197     www       686:     my $map=(&Apache::lonnet::decode_symb($symb))[0];    
1.305     albertel  687:     $map = &Apache::lonnet::deversion($map);
                    688: 
1.197     www       689:     my $symbparm=$symb.'.'.$spnam;
                    690:     my $mapparm=$map.'___(all).'.$spnam;
                    691: 
1.269     raeburn   692:     my $grplevel=$env{'request.course.id'}.'.['.$cgroup.'].'.$spnam;
                    693:     my $grplevelr=$env{'request.course.id'}.'.['.$cgroup.'].'.$symbparm;
                    694:     my $grplevelm=$env{'request.course.id'}.'.['.$cgroup.'].'.$mapparm;
                    695: 
1.190     albertel  696:     my $seclevel=$env{'request.course.id'}.'.['.$csec.'].'.$spnam;
                    697:     my $seclevelr=$env{'request.course.id'}.'.['.$csec.'].'.$symbparm;
                    698:     my $seclevelm=$env{'request.course.id'}.'.['.$csec.'].'.$mapparm;
1.186     www       699:     
1.190     albertel  700:     my $courselevel=$env{'request.course.id'}.'.'.$spnam;
                    701:     my $courselevelr=$env{'request.course.id'}.'.'.$symbparm;
                    702:     my $courselevelm=$env{'request.course.id'}.'.'.$mapparm;
1.186     www       703:     
                    704:     my $storeunder='';
1.269     raeburn   705:     if (($snum==14) || ($snum==3)) { $storeunder=$courselevel; }
                    706:     if (($snum==13) || ($snum==2)) { $storeunder=$courselevelm; }
                    707:     if (($snum==10) || ($snum==1)) { $storeunder=$courselevelr; }
                    708:     if ($snum==9) { $storeunder=$seclevel; }
                    709:     if ($snum==8) { $storeunder=$seclevelm; }
                    710:     if ($snum==7) { $storeunder=$seclevelr; }
                    711:     if ($snum==6) { $storeunder=$grplevel; }
                    712:     if ($snum==5) { $storeunder=$grplevelm; }
                    713:     if ($snum==4) { $storeunder=$grplevelr; }
                    714: 
1.186     www       715:     
                    716:     my $delete;
                    717:     if ($nval eq '') { $delete=1;}
                    718:     my %storecontent = ($storeunder         => $nval,
                    719: 			$storeunder.'.type' => $ntype);
                    720:     my $reply='';
                    721:     if ($snum>3) {
                    722: # ---------------------------------------------------------------- Store Course
                    723: #
1.200     www       724: 	my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
                    725: 	my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
1.186     www       726: # Expire sheets
                    727: 	&Apache::lonnet::expirespread('','','studentcalc');
1.269     raeburn   728: 	if (($snum==10) || ($snum==7) || ($snum==4)) {
1.197     www       729: 	    &Apache::lonnet::expirespread('','','assesscalc',$symb);
1.269     raeburn   730: 	} elsif (($snum==11) || ($snum==8) || ($snum==5)) {
1.197     www       731: 	    &Apache::lonnet::expirespread('','','assesscalc',$map);
1.186     www       732: 	} else {
                    733: 	    &Apache::lonnet::expirespread('','','assesscalc');
                    734: 	}
                    735: # Store parameter
                    736: 	if ($delete) {
                    737: 	    $reply=&Apache::lonnet::del
1.200     www       738: 		('resourcedata',[keys(%storecontent)],$cdom,$cnum);
1.290     www       739:             &log_parmset(\%storecontent,1);
1.186     www       740: 	} else {
                    741: 	    $reply=&Apache::lonnet::cput
1.200     www       742: 		('resourcedata',\%storecontent,$cdom,$cnum);
1.290     www       743: 	    &log_parmset(\%storecontent);
1.186     www       744: 	}
1.200     www       745: 	&Apache::lonnet::devalidatecourseresdata($cnum,$cdom);
1.186     www       746:     } else {
                    747: # ------------------------------------------------------------------ Store User
                    748: #
                    749: # Expire sheets
                    750: 	&Apache::lonnet::expirespread($uname,$udom,'studentcalc');
                    751: 	if ($snum==1) {
                    752: 	    &Apache::lonnet::expirespread
1.197     www       753: 		($uname,$udom,'assesscalc',$symb);
1.186     www       754: 	} elsif ($snum==2) {
                    755: 	    &Apache::lonnet::expirespread
1.197     www       756: 		($uname,$udom,'assesscalc',$map);
1.186     www       757: 	} else {
                    758: 	    &Apache::lonnet::expirespread($uname,$udom,'assesscalc');
                    759: 	}
                    760: # Store parameter
                    761: 	if ($delete) {
                    762: 	    $reply=&Apache::lonnet::del
                    763: 		('resourcedata',[keys(%storecontent)],$udom,$uname);
1.290     www       764: 	    &log_parmset(\%storecontent,1,$uname,$udom);
1.186     www       765: 	} else {
                    766: 	    $reply=&Apache::lonnet::cput
                    767: 		('resourcedata',\%storecontent,$udom,$uname);
1.290     www       768: 	    &log_parmset(\%storecontent,0,$uname,$udom);
1.186     www       769: 	}
1.191     albertel  770: 	&Apache::lonnet::devalidateuserresdata($uname,$udom);
1.186     www       771:     }
                    772:     
                    773:     if ($reply=~/^error\:(.*)/) {
1.314     albertel  774: 	return "<span class=\"LC_error\">Write Error: $1</span>";
1.186     www       775:     }
                    776:     return '';
                    777: }
                    778: 
1.9       www       779: 
                    780: sub valout {
1.320     www       781:     my ($value,$type,$editable)=@_;
1.59      matthew   782:     my $result = '';
                    783:     # Values of zero are valid.
                    784:     if (! $value && $value ne '0') {
1.320     www       785: 	if ($editable) {
1.324     www       786: 	    $result = '<span class="LC_clickhere">*</span>';
1.320     www       787: 	} else {
                    788: 	    $result='&nbsp;';
                    789: 	}
1.59      matthew   790:     } else {
1.66      www       791:         if ($type eq 'date_interval') {
                    792:             my ($sec,$min,$hour,$mday,$mon,$year)=gmtime($value);
1.413     bisitz    793:             my @timer;
1.66      www       794:             $year=$year-70;
                    795:             $mday--;
                    796:             if ($year) {
1.413     bisitz    797: #               $result.=&mt('[quant,_1,yr]',$year).' ';
                    798:                 push(@timer,&mt('[quant,_1,yr]',$year));
1.66      www       799:             }
                    800:             if ($mon) {
1.413     bisitz    801: #               $result.=&mt('[quant,_1,mth]',$mon).' ';
                    802:                 push(@timer,&mt('[quant,_1,mth]',$mon));
1.66      www       803:             }
                    804:             if ($mday) {
1.413     bisitz    805: #               $result.=&mt('[quant,_1,day]',$mday).' ';
                    806:                 push(@timer,&mt('[quant,_1,day]',$mday));
1.66      www       807:             }
                    808:             if ($hour) {
1.413     bisitz    809: #               $result.=&mt('[quant,_1,hr]',$hour).' ';
                    810:                 push(@timer,&mt('[quant,_1,hr]',$hour));
1.66      www       811:             }
                    812:             if ($min) {
1.413     bisitz    813: #               $result.=&mt('[quant,_1,min]',$min).' ';
                    814:                 push(@timer,&mt('[quant,_1,min]',$min));
1.66      www       815:             }
                    816:             if ($sec) {
1.413     bisitz    817: #               $result.=&mt('[quant,_1,sec]',$sec).' ';
                    818:                 push(@timer,&mt('[quant,_1,sec]',$sec));
1.66      www       819:             }
1.413     bisitz    820: #           $result=~s/\s+$//;
                    821:             if (!@timer) { # Special case: all entries 0 -> display "0 secs" intead of empty field to keep this field editable
                    822:                 push(@timer,&mt('[quant,_1,sec]',0));
                    823:             }
                    824:             $result.=join(", ",@timer);
1.213     www       825:         } elsif (&isdateparm($type)) {
1.361     albertel  826:             $result = &Apache::lonlocal::locallocaltime($value).
                    827: 		&date_sanity_info($value);
1.59      matthew   828:         } else {
                    829:             $result = $value;
1.378     albertel  830: 	    $result = &HTML::Entities::encode($result,'"<>&');
1.59      matthew   831:         }
                    832:     }
                    833:     return $result;
1.9       www       834: }
                    835: 
1.59      matthew   836: 
1.5       www       837: sub plink {
                    838:     my ($type,$dis,$value,$marker,$return,$call)=@_;
1.23      www       839:     my $winvalue=$value;
                    840:     unless ($winvalue) {
1.213     www       841: 	if (&isdateparm($type)) {
1.190     albertel  842:             $winvalue=$env{'form.recent_'.$type};
1.23      www       843:         } else {
1.190     albertel  844:             $winvalue=$env{'form.recent_'.(split(/\_/,$type))[0]};
1.23      www       845:         }
                    846:     }
1.229     www       847:     my ($parmname)=((split(/\&/,$marker))[1]=~/\_([^\_]+)$/);
                    848:     my ($hour,$min,$sec,$val)=&preset_defaults($parmname);
                    849:     unless (defined($winvalue)) { $winvalue=$val; }
1.378     albertel  850:     my $valout = &valout($value,$type,1);
1.429     raeburn   851:     my $unencmarker = $marker;
1.378     albertel  852:     foreach my $item (\$type, \$dis, \$winvalue, \$marker, \$return, \$call,
                    853: 		      \$hour, \$min, \$sec) {
                    854: 	$$item = &HTML::Entities::encode($$item,'"<>&');
                    855: 	$$item =~ s/\'/\\\'/g;
                    856:     }
1.429     raeburn   857:     return '<table width="100%"><tr valign="top" align="right"><td><a name="'.$unencmarker.'" /></td></tr><tr><td align="center">'.
1.43      albertel  858: 	'<a href="javascript:pjump('."'".$type."','".$dis."','".$winvalue."','"
1.229     www       859: 	    .$marker."','".$return."','".$call."','".$hour."','".$min."','".$sec."'".');">'.
1.378     albertel  860: 	    $valout.'</a></td></tr></table>';
1.5       www       861: }
                    862: 
1.280     albertel  863: sub page_js {
                    864: 
1.81      www       865:     my $selscript=&Apache::loncommon::studentbrowser_javascript();
1.88      matthew   866:     my $pjump_def = &Apache::lonhtmlcommon::pjump_javascript_definition();
1.280     albertel  867: 
                    868:     return(<<ENDJS);
                    869: <script type="text/javascript">
1.44      albertel  870: 
                    871:     function pclose() {
                    872:         parmwin=window.open("/adm/rat/empty.html","LONCAPAparms",
                    873:                  "height=350,width=350,scrollbars=no,menubar=no");
                    874:         parmwin.close();
                    875:     }
                    876: 
1.88      matthew   877:     $pjump_def
1.44      albertel  878: 
                    879:     function psub() {
                    880:         pclose();
                    881:         if (document.parmform.pres_marker.value!='') {
                    882:             document.parmform.action+='#'+document.parmform.pres_marker.value;
                    883:             var typedef=new Array();
                    884:             typedef=document.parmform.pres_type.value.split('_');
                    885:            if (document.parmform.pres_type.value!='') {
                    886:             if (typedef[0]=='date') {
                    887:                 eval('document.parmform.recent_'+
                    888:                      document.parmform.pres_type.value+
                    889: 		     '.value=document.parmform.pres_value.value;');
                    890:             } else {
                    891:                 eval('document.parmform.recent_'+typedef[0]+
                    892: 		     '.value=document.parmform.pres_value.value;');
                    893:             }
                    894: 	   }
                    895:             document.parmform.submit();
                    896:         } else {
                    897:             document.parmform.pres_value.value='';
                    898:             document.parmform.pres_marker.value='';
                    899:         }
                    900:     }
                    901: 
1.57      albertel  902:     function openWindow(url, wdwName, w, h, toolbar,scrollbar) {
                    903:         var options = "width=" + w + ",height=" + h + ",";
                    904:         options += "resizable=yes,scrollbars="+scrollbar+",status=no,";
                    905:         options += "menubar=no,toolbar="+toolbar+",location=no,directories=no";
                    906:         var newWin = window.open(url, wdwName, options);
                    907:         newWin.focus();
                    908:     }
1.44      albertel  909: </script>
1.81      www       910: $selscript
1.280     albertel  911: ENDJS
                    912: 
                    913: }
                    914: sub startpage {
                    915:     my ($r) = @_;
1.281     albertel  916: 
1.282     albertel  917:     my %loaditems = ('onunload' => "pclose()",
1.283     albertel  918: 		     'onload'   => "group_or_section('cgroup')",);
1.280     albertel  919: 
1.414     droeschl  920:     if ((($env{'form.command'} eq 'set') && ($env{'form.url'})
                    921: 	     && (!$env{'form.dis'})) || ($env{'form.symb'})) {
                    922: 	&Apache::lonhtmlcommon::add_breadcrumb({help=>'Problem_Parameters',
                    923: 	    text=>"Problem Parameters"});
                    924:     } else {
                    925: 	&Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=settable',
                    926: 	   text=>"Table Mode",
                    927: 	   help => 'Course_Setting_Parameters'});
                    928:     }
1.281     albertel  929:     my $start_page = 
                    930: 	&Apache::loncommon::start_page('Set/Modify Course Parameters',
                    931: 				       &page_js(),
1.282     albertel  932: 				       {'add_entries' => \%loaditems,});
1.280     albertel  933:     my $breadcrumbs = 
1.321     www       934: 	&Apache::lonhtmlcommon::breadcrumbs('Table Mode Parameter Setting','Table_Mode');
1.280     albertel  935:     $r->print(<<ENDHEAD);
1.281     albertel  936: $start_page
1.193     albertel  937: $breadcrumbs
                    938: <form method="post" action="/adm/parmset?action=settable" name="parmform">
1.419     bisitz    939: <input type="hidden" value="" name="pres_value" />
                    940: <input type="hidden" value="" name="pres_type" />
                    941: <input type="hidden" value="" name="pres_marker" />
                    942: <input type="hidden" value="1" name="prevvisit" />
1.44      albertel  943: ENDHEAD
                    944: }
                    945: 
1.209     www       946: 
1.44      albertel  947: sub print_row {
1.201     www       948:     my ($r,$which,$part,$name,$symbp,$rid,$default,$defaulttype,$display,$defbgone,
1.275     raeburn   949: 	$defbgtwo,$defbgthree,$parmlev,$uname,$udom,$csec,$cgroup,$usersgroups)=@_;
                    950:     my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
                    951:     my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                    952:     my $courseopt=&Apache::lonnet::get_courseresdata($cnum,$cdom);
1.66      www       953: # get the values for the parameter in cascading order
                    954: # empty levels will remain empty
1.44      albertel  955:     my ($result,@outpar)=&parmval($$part{$which}.'.'.$$name{$which},
1.275     raeburn   956: 	  $rid,$$default{$which},$uname,$udom,$csec,$cgroup,$courseopt);
1.66      www       957: # get the type for the parameters
                    958: # problem: these may not be set for all levels
                    959:     my ($typeresult,@typeoutpar)=&parmval($$part{$which}.'.'.
1.275     raeburn   960:                                           $$name{$which}.'.type',$rid,
                    961: 		 $$defaulttype{$which},$uname,$udom,$csec,$cgroup,$courseopt);
1.66      www       962: # cascade down manually
1.182     albertel  963:     my $cascadetype=$$defaulttype{$which};
1.269     raeburn   964:     for (my $i=14;$i>0;$i--) {
1.66      www       965: 	 if ($typeoutpar[$i]) { 
                    966:             $cascadetype=$typeoutpar[$i];
                    967: 	} else {
                    968:             $typeoutpar[$i]=$cascadetype;
                    969:         }
                    970:     }
1.57      albertel  971:     my $parm=$$display{$which};
                    972: 
1.203     www       973:     if ($parmlev eq 'full') {
1.419     bisitz    974:         $r->print('<td style="background-color:'.$defbgtwo.';" align="center">'
1.57      albertel  975:                   .$$part{$which}.'</td>');
                    976:     } else {    
                    977:         $parm=~s|\[.*\]\s||g;
1.426     bisitz    978:         $parm=&mt($parm);
1.57      albertel  979:     }
1.231     www       980:     my $automatic=&rulescache(($which=~/\_([^\_]+)$/)[0].'_triggers');
                    981:     if ($automatic) {
1.314     albertel  982: 	$parm.='<span class="LC_warning"><br />'.&mt('Automatically sets').' '.join(', ',split(/\:/,$automatic)).'</span>';
1.231     www       983:     }
1.427     bisitz    984:     $r->print('<td>'.$parm.'</td>');
1.57      albertel  985:    
1.44      albertel  986:     my $thismarker=$which;
                    987:     $thismarker=~s/^parameter\_//;
                    988:     my $mprefix=$rid.'&'.$thismarker.'&';
1.275     raeburn   989:     my $effective_parm = &valout($outpar[$result],$typeoutpar[$result]);
                    990:     my ($othergrp,$grp_parm,$controlgrp);
1.44      albertel  991: 
1.57      albertel  992:     if ($parmlev eq 'general') {
                    993: 
                    994:         if ($uname) {
1.66      www       995:             &print_td($r,3,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.269     raeburn   996:         } elsif ($cgroup) {
                    997:             &print_td($r,6,$defbgthree,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57      albertel  998:         } elsif ($csec) {
1.269     raeburn   999:             &print_td($r,9,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display); 
1.57      albertel 1000:         } else {
1.269     raeburn  1001:             &print_td($r,14,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display); 
1.57      albertel 1002:         }
                   1003:     } elsif ($parmlev eq 'map') {
                   1004: 
                   1005:         if ($uname) {
1.66      www      1006:             &print_td($r,2,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.269     raeburn  1007:         } elsif ($cgroup) {
                   1008:             &print_td($r,5,$defbgthree,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57      albertel 1009:         } elsif ($csec) {
1.269     raeburn  1010:             &print_td($r,8,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57      albertel 1011:         } else {
1.269     raeburn  1012:             &print_td($r,13,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57      albertel 1013:         }
                   1014:     } else {
1.275     raeburn  1015:         if ($uname) {
                   1016:             if (@{$usersgroups} > 1) {
                   1017:                 my ($coursereply,$grp_parm,$controlgrp);
                   1018:                 ($coursereply,$othergrp,$grp_parm,$controlgrp) =
                   1019:                     &print_usergroups($r,$$part{$which}.'.'.$$name{$which},
                   1020:                        $rid,$cgroup,$defbgone,$usersgroups,$result,$courseopt);
                   1021:                 if ($coursereply && $result > 3) {
                   1022:                     if (defined($controlgrp)) {
                   1023:                         if ($cgroup ne $controlgrp) {
                   1024:                             $effective_parm = $grp_parm;
                   1025:                             $result = 0;
                   1026:                         }
                   1027:                     }
                   1028:                 }
                   1029:             }
                   1030:         }
1.57      albertel 1031: 
1.269     raeburn  1032:         &print_td($r,14,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57      albertel 1033: 
1.269     raeburn  1034: 	&print_td($r,13,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                   1035: 	&print_td($r,12,'#FFDDDD',$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                   1036: 	&print_td($r,11,'#FFDDDD',$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.203     www      1037: 	&print_td($r,10,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                   1038: 	
                   1039: 	if ($csec) {
1.269     raeburn  1040: 	    &print_td($r,9,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                   1041: 	    &print_td($r,8,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                   1042: 	    &print_td($r,7,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.203     www      1043: 	}
1.269     raeburn  1044: 
                   1045:         if ($cgroup) {
                   1046:             &print_td($r,6,$defbgthree,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                   1047:             &print_td($r,5,$defbgthree,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                   1048:             &print_td($r,4,$defbgthree,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                   1049:         }
1.275     raeburn  1050:      
1.203     www      1051: 	if ($uname) {
1.275     raeburn  1052:             if ($othergrp) {
                   1053:                 $r->print($othergrp);
                   1054:             }
1.203     www      1055: 	    &print_td($r,3,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                   1056: 	    &print_td($r,2,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                   1057: 	    &print_td($r,1,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
                   1058: 	}
1.57      albertel 1059: 
                   1060:     } # end of $parmlev if/else
1.419     bisitz   1061:     $r->print('<td style="background-color:#CCCCFF;" align="center">'.$effective_parm.'</td>');
1.136     albertel 1062: 
1.203     www      1063:     if ($parmlev eq 'full') {
1.136     albertel 1064:         my $sessionval=&Apache::lonnet::EXT('resource.'.$$part{$which}.
1.201     www      1065:                                         '.'.$$name{$which},$$symbp{$rid});
1.136     albertel 1066:         my $sessionvaltype=$typeoutpar[$result];
                   1067:         if (!defined($sessionvaltype)) { $sessionvaltype=$$defaulttype{$which}; }
1.419     bisitz   1068:         $r->print('<td style="background-color:#999999;" align="center"><font color="#FFFFFF">'.
1.66      www      1069:                   &valout($sessionval,$sessionvaltype).'&nbsp;'.
1.57      albertel 1070:                   '</font></td>');
1.136     albertel 1071:     }
1.44      albertel 1072:     $r->print('</tr>');
1.57      albertel 1073:     $r->print("\n");
1.44      albertel 1074: }
1.59      matthew  1075: 
1.44      albertel 1076: sub print_td {
1.66      www      1077:     my ($r,$which,$defbg,$result,$outpar,$mprefix,$value,$typeoutpar,$display)=@_;
1.419     bisitz   1078:     $r->print('<td style="background-color:'.(($result==$which)?'#AAFFAA':$defbg).
                   1079:               ';" align="center">');
1.269     raeburn  1080:     if ($which<11 || $which > 12) {
1.114     www      1081: 	$r->print(&plink($$typeoutpar[$which],
                   1082: 			 $$display{$value},$$outpar[$which],
                   1083: 			 $mprefix."$which",'parmform.pres','psub'));
                   1084:     } else {
                   1085: 	$r->print(&valout($$outpar[$which],$$typeoutpar[$which]));
                   1086:     }
                   1087:     $r->print('</td>'."\n");
1.57      albertel 1088: }
                   1089: 
1.275     raeburn  1090: sub print_usergroups {
                   1091:     my ($r,$what,$rid,$cgroup,$defbg,$usersgroups,$result,$courseopt) = @_;
                   1092:     my $courseid = $env{'request.course.id'};
                   1093:     my $output;
                   1094:     my $symb = &symbcache($rid);
                   1095:     my $symbparm=$symb.'.'.$what;
                   1096:     my $map=(&Apache::lonnet::decode_symb($symb))[0];
                   1097:     my $mapparm=$map.'___(all).'.$what;
                   1098:     my ($coursereply,$resultitem,$resultgroup,$resultlevel,$resulttype) =
                   1099:           &parm_control_group($courseid,$usersgroups,$symbparm,$mapparm,$what,
                   1100:                                                                    $courseopt);
                   1101:     my $bgcolor = $defbg;
                   1102:     my $grp_parm;
                   1103:     if (($coursereply) && ($cgroup ne $resultgroup)) { 
                   1104:         if ($result > 3) {
1.419     bisitz   1105:             $bgcolor = '#AAFFAA';
1.275     raeburn  1106:             $grp_parm = &valout($coursereply,$resulttype);
                   1107:         }
                   1108:         $grp_parm = &valout($coursereply,$resulttype);
1.419     bisitz   1109:         $output = '<td style="background-color:'.$bgcolor.';" align="center">';
1.275     raeburn  1110:         if ($resultgroup && $resultlevel) {
                   1111:             $output .= '<small><b>'.$resultgroup.'</b> ('.$resultlevel.'): </small>'.$grp_parm;
                   1112:         } else {
                   1113:             $output .= '&nbsp;';
                   1114:         }
                   1115:         $output .= '</td>';
                   1116:     } else {
1.419     bisitz   1117:         $output .= '<td style="background-color:'.$bgcolor.';">&nbsp;</td>';
1.275     raeburn  1118:     }
                   1119:     return ($coursereply,$output,$grp_parm,$resultgroup);
                   1120: }
                   1121: 
                   1122: sub parm_control_group {
                   1123:     my ($courseid,$usersgroups,$symbparm,$mapparm,$what,$courseopt) = @_;
                   1124:     my ($coursereply,$resultitem,$resultgroup,$resultlevel,$resulttype);
                   1125:     my $grpfound = 0;
                   1126:     my @levels = ($symbparm,$mapparm,$what);
                   1127:     my @levelnames = ('resource','map/folder','general');
                   1128:     foreach my $group (@{$usersgroups}) {
                   1129:         if ($grpfound) { last; }
                   1130:         for (my $i=0; $i<@levels; $i++) {
                   1131:             my $item = $courseid.'.['.$group.'].'.$levels[$i];
                   1132:             if (defined($$courseopt{$item})) {
                   1133:                 $coursereply = $$courseopt{$item};
                   1134:                 $resultitem = $item;
                   1135:                 $resultgroup = $group;
                   1136:                 $resultlevel = $levelnames[$i];
                   1137:                 $resulttype = $$courseopt{$item.'.type'};
                   1138:                 $grpfound = 1;
                   1139:                 last;
                   1140:             }
                   1141:         }
                   1142:     }
                   1143:     return($coursereply,$resultitem,$resultgroup,$resultlevel,$resulttype);
                   1144: }
1.201     www      1145: 
1.63      bowersj2 1146: 
                   1147: 
                   1148: sub extractResourceInformation {
                   1149:     my $ids = shift;
                   1150:     my $typep = shift;
                   1151:     my $keyp = shift;
                   1152:     my $allparms = shift;
                   1153:     my $allparts = shift;
                   1154:     my $allmaps = shift;
                   1155:     my $mapp = shift;
                   1156:     my $symbp = shift;
1.82      www      1157:     my $maptitles=shift;
1.196     www      1158:     my $uris=shift;
1.210     www      1159:     my $keyorder=shift;
1.211     www      1160:     my $defkeytype=shift;
1.196     www      1161: 
1.210     www      1162:     my $keyordercnt=100;
1.63      bowersj2 1163: 
1.196     www      1164:     my $navmap = Apache::lonnavmaps::navmap->new();
                   1165:     my @allres=$navmap->retrieveResources(undef,undef,1,undef,1);
                   1166:     foreach my $resource (@allres) {
                   1167: 	my $id=$resource->id();
                   1168:         my ($mapid,$resid)=split(/\./,$id);
                   1169: 	if ($mapid eq '0') { next; }
                   1170: 	$$ids[$#$ids+1]=$id;
                   1171: 	my $srcf=$resource->src();
                   1172: 	$srcf=~/\.(\w+)$/;
                   1173: 	$$typep{$id}=$1;
                   1174: 	$$keyp{$id}='';
                   1175:         $$uris{$id}=$srcf;
1.363     albertel 1176: 	foreach my $key (split(/\,/,&Apache::lonnet::metadata($srcf,'allpossiblekeys'))) {
                   1177: 	    next if ($key!~/^parameter_/);
                   1178: 
1.209     www      1179: # Hidden parameters
1.363     albertel 1180: 	    next if (&Apache::lonnet::metadata($srcf,$key.'.hidden') eq 'parm');
1.209     www      1181: #
                   1182: # allparms is a hash of parameter names
                   1183: #
1.363     albertel 1184: 	    my $name=&Apache::lonnet::metadata($srcf,$key.'.name');
1.375     albertel 1185: 	    if (!exists($$allparms{$name}) || $$allparms{$name} =~ m/^\s*$/ ) {
1.363     albertel 1186: 		my $display= &Apache::lonnet::metadata($srcf,$key.'.display');
1.196     www      1187: 		my $parmdis = $display;
1.412     bisitz   1188: 		$parmdis =~ s/\s*\[Part.*$//g;
1.363     albertel 1189: 		$$allparms{$name}=$parmdis;
                   1190: 		if (ref($defkeytype)) {
                   1191: 		    $$defkeytype{$name}=
                   1192: 			&Apache::lonnet::metadata($srcf,$key.'.type');
                   1193: 		}
                   1194: 	    }
                   1195: 
1.209     www      1196: #
                   1197: # allparts is a hash of all parts
                   1198: #
1.363     albertel 1199: 	    my $part= &Apache::lonnet::metadata($srcf,$key.'.part');
1.410     bisitz   1200: 	    $$allparts{$part} = &mt('Part: [_1]',$part);
1.209     www      1201: #
                   1202: # Remember all keys going with this resource
                   1203: #
1.363     albertel 1204: 	    if ($$keyp{$id}) {
                   1205: 		$$keyp{$id}.=','.$key;
                   1206: 	    } else {
                   1207: 		$$keyp{$id}=$key;
                   1208: 	    }
1.210     www      1209: #
                   1210: # Put in order
                   1211: # 
1.363     albertel 1212: 	    unless ($$keyorder{$key}) {
                   1213: 		$$keyorder{$key}=$keyordercnt;
                   1214: 		$keyordercnt++;
                   1215: 	    }
                   1216: 	}
1.210     www      1217: 
1.363     albertel 1218: 	
                   1219: 	if (!exists($$mapp{$mapid})) {
                   1220: 	    $$mapp{$id}=
                   1221: 		&Apache::lonnet::declutter($resource->enclosing_map_src());
                   1222: 	    $$mapp{$mapid}=$$mapp{$id};
                   1223: 	    $$allmaps{$mapid}=$$mapp{$id};
                   1224: 	    if ($mapid eq '1') {
1.401     bisitz   1225: 		$$maptitles{$mapid}=&mt('Main Course Documents');
1.363     albertel 1226: 	    } else {
                   1227: 		$$maptitles{$mapid}=
                   1228: 		    &Apache::lonnet::gettitle($$mapp{$id});    
1.63      bowersj2 1229: 	    }
1.363     albertel 1230: 	    $$maptitles{$$mapp{$id}}=$$maptitles{$mapid};
                   1231: 	    $$symbp{$mapid}=$$mapp{$id}.'___(all)';
1.196     www      1232: 	} else {
1.363     albertel 1233: 	    $$mapp{$id} = $$mapp{$mapid};
1.196     www      1234: 	}
                   1235: 	$$symbp{$id}=&Apache::lonnet::encode_symb($$mapp{$id},$resid,$srcf);
1.63      bowersj2 1236:     }
                   1237: }
                   1238: 
1.208     www      1239: 
                   1240: 
1.213     www      1241: sub isdateparm {
                   1242:     my $type=shift;
                   1243:     return (($type=~/^date/) && (!($type eq 'date_interval')));
                   1244: }
                   1245: 
1.208     www      1246: sub parmmenu {
1.211     www      1247:     my ($r,$allparms,$pscat,$keyorder)=@_;
1.208     www      1248:     my $tempkey;
                   1249:     $r->print(<<ENDSCRIPT);
                   1250: <script type="text/javascript">
                   1251:     function checkall(value, checkName) {
                   1252: 	for (i=0; i<document.forms.parmform.elements.length; i++) {
                   1253:             ele = document.forms.parmform.elements[i];
                   1254:             if (ele.name == checkName) {
                   1255:                 document.forms.parmform.elements[i].checked=value;
                   1256:             }
                   1257:         }
                   1258:     }
1.210     www      1259: 
                   1260:     function checkthis(thisvalue, checkName) {
                   1261: 	for (i=0; i<document.forms.parmform.elements.length; i++) {
                   1262:             ele = document.forms.parmform.elements[i];
                   1263:             if (ele.name == checkName) {
                   1264: 		if (ele.value == thisvalue) {
                   1265: 		    document.forms.parmform.elements[i].checked=true;
                   1266: 		}
                   1267:             }
                   1268:         }
                   1269:     }
                   1270: 
                   1271:     function checkdates() {
                   1272: 	checkthis('duedate','pscat');
                   1273:  	checkthis('opendate','pscat');
                   1274: 	checkthis('answerdate','pscat');
1.218     www      1275:     }
                   1276: 
                   1277:     function checkdisset() {
                   1278: 	checkthis('discussend','pscat');
                   1279:  	checkthis('discusshide','pscat');
                   1280:     }
                   1281: 
                   1282:     function checkcontdates() {
                   1283: 	checkthis('contentopen','pscat');
                   1284:  	checkthis('contentclose','pscat');
                   1285:     }
                   1286:  
1.210     www      1287: 
                   1288:     function checkvisi() {
                   1289: 	checkthis('hiddenresource','pscat');
                   1290:  	checkthis('encrypturl','pscat');
                   1291: 	checkthis('problemstatus','pscat');
                   1292: 	checkthis('contentopen','pscat');
                   1293: 	checkthis('opendate','pscat');
                   1294:     }
                   1295: 
                   1296:     function checkparts() {
                   1297: 	checkthis('hiddenparts','pscat');
                   1298: 	checkthis('display','pscat');
                   1299: 	checkthis('ordered','pscat');
                   1300:     }
                   1301: 
                   1302:     function checkstandard() {
                   1303:         checkall(false,'pscat');
                   1304: 	checkdates();
                   1305: 	checkthis('weight','pscat');
                   1306: 	checkthis('maxtries','pscat');
                   1307:     }
                   1308: 
1.208     www      1309: </script>
                   1310: ENDSCRIPT
1.209     www      1311:     $r->print();
1.422     bisitz   1312:     $r->print("\n".'<table id="LC_parm_overview_parm_menu"><tr>');
1.208     www      1313:     my $cnt=0;
1.211     www      1314:     foreach $tempkey (&keysindisplayorder($allparms,$keyorder)) {
1.419     bisitz   1315: 	$r->print("\n".'<td><label><input type="checkbox" name="pscat" ');
1.208     www      1316: 	$r->print('value="'.$tempkey.'"');
                   1317: 	if ($$pscat[0] eq "all" || grep $_ eq $tempkey, @{$pscat}) {
1.422     bisitz   1318: 	    $r->print(' checked="checked"');
1.208     www      1319: 	}
1.428     raeburn  1320:         my $displaykey;
                   1321:         if ($$allparms{$tempkey}=~/\S/) {
                   1322:             $displaykey = $$allparms{$tempkey};
                   1323:         } else {
                   1324:             $displaykey = $tempkey;
                   1325:         }
                   1326:         $displaykey =~ s/(\[|\])/~$1/g;
                   1327:         $r->print(' />'.&mt($displaykey).'</label></td>');
1.209     www      1328:  	$cnt++;
                   1329:         if ($cnt==3) {
                   1330: 	    $r->print("</tr>\n<tr>");
                   1331: 	    $cnt=0;
                   1332: 	}
1.208     www      1333:     }
1.410     bisitz   1334:     $r->print('</tr>'
1.422     bisitz   1335:              .'<tr id="LC_parm_overview_parm_menu_selectors">'
1.410     bisitz   1336:              .'<td valign="top">'
                   1337:              .'<fieldset><legend><b>'.&mt('Parameter Selection').'</b></legend>'
                   1338:              .'<span class="LC_nobreak">'
                   1339:              .'&bull; <a href="javascript:checkall(true, \'pscat\')">'.&mt('Select All').'</a>'
                   1340:              .'</span>'
                   1341:              .'<br />'
                   1342:              .'<span class="LC_nobreak">'
                   1343:              .'&bull; <a href="javascript:checkstandard()">'.&mt('Select Common Only').'</a>'
                   1344:              .'</span>'
                   1345:              .'<br />'
                   1346:              .'<span class="LC_nobreak">'
                   1347:              .'&bull; <a href="javascript:checkall(false, \'pscat\')">'.&mt('Unselect All').'</a>'
                   1348:              .'</span>'
                   1349:              .'</fieldset>'
                   1350:              .'</td>'
                   1351:              .'<td colspan="2" valign="top">'
                   1352:              .'<fieldset><legend><b>'.&mt('Add Selection for...').'</b></legend>'
                   1353:              .'<span class="LC_nobreak">'
                   1354:              .'&bull; <a href="javascript:checkdates()">'.&mt('Problem Dates').'</a>'
                   1355:              .'</span>'
                   1356:              .'<span class="LC_nobreak">'
                   1357:              .' &bull; <a href="javascript:checkcontdates()">'.&mt('Content Dates').'</a>'
                   1358:              .'</span>'
                   1359: #            .'<br />'
                   1360:              .'<span class="LC_nobreak">'
                   1361:              .' &bull; <a href="javascript:checkdisset()">'.&mt('Discussion Settings').'</a>'
                   1362:              .'</span>'
                   1363:              .'<span class="LC_nobreak">'
                   1364:              .' &bull; <a href="javascript:checkvisi()">'.&mt('Visibilities').'</a>'
                   1365:              .'</span>'
                   1366: #            .'<br />'
                   1367:              .'<span class="LC_nobreak">'
                   1368:              .' &bull; <a href="javascript:checkparts()">'.&mt('Part Parameters').'</a>'
                   1369:              .'</span>'
                   1370:              .'</fieldset>'
                   1371:              .'</td>'
                   1372:              .'</tr></table>'
                   1373:     );
1.208     www      1374: }
                   1375: 
1.209     www      1376: sub partmenu {
                   1377:     my ($r,$allparts,$psprt)=@_;
1.421     bisitz   1378:     $r->print('<select multiple="multiple" name="psprt" size="8">');
1.208     www      1379:     $r->print('<option value="all"');
1.401     bisitz   1380:     $r->print(' selected="selected"') unless (@{$psprt});
1.208     www      1381:     $r->print('>'.&mt('All Parts').'</option>');
                   1382:     my %temphash=();
                   1383:     foreach (@{$psprt}) { $temphash{$_}=1; }
1.234     albertel 1384:     foreach my $tempkey (sort {
                   1385: 	if ($a==$b) { return ($a cmp $b) } else { return ($a <=> $b); }
                   1386:     } keys(%{$allparts})) {
1.208     www      1387: 	unless ($tempkey =~ /\./) {
                   1388: 	    $r->print('<option value="'.$tempkey.'"');
                   1389: 	    if ($$psprt[0] eq "all" ||  $temphash{$tempkey}) {
1.401     bisitz   1390: 		$r->print(' selected="selected"');
1.208     www      1391: 	    }
                   1392: 	    $r->print('>'.$$allparts{$tempkey}.'</option>');
                   1393: 	}
                   1394:     }
1.209     www      1395:     $r->print('</select>');
                   1396: }
                   1397: 
                   1398: sub usermenu {
1.275     raeburn  1399:     my ($r,$uname,$id,$udom,$csec,$cgroup,$parmlev,$usersgroups)=@_;
1.209     www      1400:     my $chooseopt=&Apache::loncommon::select_dom_form($udom,'udom').' '.
                   1401:         &Apache::loncommon::selectstudent_link('parmform','uname','udom');
                   1402:     my $selscript=&Apache::loncommon::studentbrowser_javascript();
1.412     bisitz   1403: 
1.209     www      1404:     my $sections='';
1.300     albertel 1405:     my %sectionhash = &Apache::loncommon::get_sections();
                   1406: 
1.269     raeburn  1407:     my $groups;
1.307     raeburn  1408:     my %grouphash = &Apache::longroup::coursegroups();
1.299     albertel 1409: 
1.412     bisitz   1410:     my $g_s_header='';
                   1411:     my $g_s_footer='';
                   1412: 
1.300     albertel 1413:     if (%sectionhash) {
1.412     bisitz   1414:         $sections=&mt('Section:').' <select name="csec"';
1.299     albertel 1415:         if (%grouphash && $parmlev ne 'full') {
1.269     raeburn  1416:             $sections .= qq| onchange="group_or_section('csec')" |;
                   1417:         }
                   1418:         $sections .= '>';
1.275     raeburn  1419: 	foreach my $section ('',sort keys %sectionhash) {
                   1420: 	    $sections.='<option value="'.$section.'" '.
                   1421: 		($section eq $csec?'selected="selected"':'').'>'.$section.
                   1422:                                                               '</option>';
1.209     www      1423:         }
                   1424:         $sections.='</select>';
1.269     raeburn  1425:     }
1.412     bisitz   1426: 
1.300     albertel 1427:     if (%sectionhash && %grouphash && $parmlev ne 'full') {
1.412     bisitz   1428:         $sections .= '&nbsp;'.&mt('or').'&nbsp;';
1.269     raeburn  1429:         $sections .= qq|
                   1430: <script type="text/javascript">
                   1431: function group_or_section(caller) {
                   1432:    if (caller == "cgroup") {
                   1433:        if (document.parmform.cgroup.selectedIndex != 0) {
                   1434:            document.parmform.csec.selectedIndex = 0;
                   1435:        }
                   1436:    } else {
                   1437:        if (document.parmform.csec.selectedIndex != 0) {
                   1438:            document.parmform.cgroup.selectedIndex = 0;
                   1439:        }
                   1440:    }
                   1441: }
                   1442: </script>
                   1443: |;
                   1444:     } else {
                   1445:         $sections .= qq|
                   1446: <script type="text/javascript">
                   1447: function group_or_section(caller) {
                   1448:     return;
                   1449: }
                   1450: </script>
                   1451: |;
                   1452:     } 
1.299     albertel 1453: 
                   1454:     if (%grouphash) {
1.412     bisitz   1455:         $groups=&mt('Group:').' <select name="cgroup"';
1.300     albertel 1456:         if (%sectionhash && $env{'form.action'} eq 'settable') {
1.269     raeburn  1457:             $groups .= qq| onchange="group_or_section('cgroup')" |;
                   1458:         }
                   1459:         $groups .= '>';
1.275     raeburn  1460:         foreach my $grp ('',sort keys %grouphash) {
                   1461:             $groups.='<option value="'.$grp.'" ';
                   1462:             if ($grp eq $cgroup) {
                   1463:                 unless ((defined($uname)) && ($grp eq '')) {
                   1464:                     $groups .=  'selected="selected" ';
                   1465:                 }
                   1466:             } elsif (!defined($cgroup)) {
                   1467:                 if (@{$usersgroups} == 1) {
                   1468:                     if ($grp eq $$usersgroups[0]) {
                   1469:                         $groups .=  'selected="selected" ';
                   1470:                     }
                   1471:                 }
                   1472:             }
                   1473:             $groups .= '>'.$grp.'</option>';
1.269     raeburn  1474:         }
                   1475:         $groups.='</select>';
                   1476:     }
1.412     bisitz   1477: 
                   1478:     if (%sectionhash || %grouphash) {
                   1479:         $g_s_header='<fieldset><legend>'.&mt('Group/Section').'</legend><div>';
                   1480:         $g_s_footer='</div></fieldset>';
                   1481:     }
                   1482: 
                   1483:     $r->print('<b>'
                   1484:              .$g_s_header
                   1485:              .$sections
                   1486:              .$groups
                   1487:              .$g_s_footer
                   1488:              .'<fieldset><legend>'.&mt('User').'</legend><div>'
                   1489:              .&mt('For User [_1] or Student/Employee ID [_2] at Domain [_3]'
                   1490:                  ,'<input type="text" value="'.$uname.'" size="12" name="uname" />'
                   1491:                  ,'<input type="text" value="'.$id.'" size="12" name="id" /> '
                   1492:                  ,$chooseopt)
                   1493:              .'</div></fieldset>'
                   1494:              .'</b>'
                   1495:     );
1.209     www      1496: }
                   1497: 
                   1498: sub displaymenu {
1.211     www      1499:     my ($r,$allparms,$allparts,$pscat,$psprt,$keyorder)=@_;
1.209     www      1500:     $r->print('<table border="1"><tr><th>'.&mt('Select Parameters to View').'</th><th>'.
                   1501: 	     &mt('Select Parts to View').'</th></tr><tr><td>');  
1.211     www      1502:     &parmmenu($r,$allparms,$pscat,$keyorder);
1.412     bisitz   1503:     $r->print('</td><td valign="top" align="center">');
1.209     www      1504:     &partmenu($r,$allparts,$psprt);
                   1505:     $r->print('</td></tr></table>');
                   1506: }
                   1507: 
                   1508: sub mapmenu {
                   1509:     my ($r,$allmaps,$pschp,$maptitles)=@_;
1.231     www      1510:     $r->print('<b>'.&mt('Select Enclosing Map or Folder').'</b> ');
1.209     www      1511:     $r->print('<select name="pschp">');
                   1512:     $r->print('<option value="all">'.&mt('All Maps or Folders').'</option>');
                   1513:     foreach (sort {$$allmaps{$a} cmp $$allmaps{$b}} keys %{$allmaps}) {
1.208     www      1514: 	$r->print('<option value="'.$_.'"');
1.401     bisitz   1515: 	if (($pschp eq $_)) { $r->print(' selected="selected"'); }
1.209     www      1516: 	$r->print('>'.$$maptitles{$_}.($$allmaps{$_}!~/^uploaded/?' ['.$$allmaps{$_}.']':'').'</option>');
                   1517:     }
                   1518:     $r->print("</select>");
                   1519: }
                   1520: 
                   1521: sub levelmenu {
                   1522:     my ($r,$alllevs,$parmlev)=@_;
1.231     www      1523:     $r->print('<b>'.&mt('Select Parameter Level').
                   1524: 	      &Apache::loncommon::help_open_topic('Course_Parameter_Levels').'</b> ');
1.209     www      1525:     $r->print('<select name="parmlev">');
                   1526:     foreach (reverse sort keys %{$alllevs}) {
                   1527: 	$r->print('<option value="'.$$alllevs{$_}.'"');
                   1528: 	if ($parmlev eq $$alllevs{$_}) {
1.401     bisitz   1529: 	    $r->print(' selected="selected"'); 
1.209     www      1530: 	}
1.401     bisitz   1531: 	$r->print('>'.&mt($_).'</option>');
1.208     www      1532:     }
1.209     www      1533:     $r->print("</select>");
1.208     www      1534: }
                   1535: 
1.211     www      1536: 
                   1537: sub sectionmenu {
                   1538:     my ($r,$selectedsections)=@_;
1.300     albertel 1539:     my %sectionhash = &Apache::loncommon::get_sections();
                   1540:     return if (!%sectionhash);
                   1541: 
1.421     bisitz   1542:     $r->print('<select name="Section" multiple="multiple" size="8">');
1.300     albertel 1543:     foreach my $s ('all',sort keys %sectionhash) {
                   1544: 	$r->print('    <option value="'.$s.'"');
                   1545: 	foreach (@{$selectedsections}) {
                   1546: 	    if ($s eq $_) {
1.401     bisitz   1547: 		$r->print(' selected="selected"');
1.300     albertel 1548: 		last;
1.212     www      1549: 	    }
                   1550: 	}
1.300     albertel 1551: 	$r->print('>'.$s."</option>\n");
                   1552:     }
                   1553:     $r->print("</select>\n");
1.269     raeburn  1554: }
                   1555: 
                   1556: sub groupmenu {
                   1557:     my ($r,$selectedgroups)=@_;
1.307     raeburn  1558:     my %grouphash = &Apache::longroup::coursegroups();
1.299     albertel 1559:     return if (!%grouphash);
                   1560: 
1.421     bisitz   1561:     $r->print('<select name="Group" multiple="multiple" size="8">');
1.299     albertel 1562:     foreach my $group (sort(keys(%grouphash))) {
                   1563: 	$r->print('    <option value="'.$group.'"');
                   1564: 	foreach (@{$selectedgroups}) {
                   1565: 	    if ($group eq $_) {
1.401     bisitz   1566: 		$r->print(' selected="selected"');
1.299     albertel 1567: 		last;
                   1568: 	    }
                   1569: 	}
                   1570: 	$r->print('>'.$group."</option>\n");
1.211     www      1571:     }
1.299     albertel 1572:     $r->print("</select>\n");
1.211     www      1573: }
                   1574: 
1.269     raeburn  1575: 
1.210     www      1576: sub keysplit {
                   1577:     my $keyp=shift;
                   1578:     return (split(/\,/,$keyp));
                   1579: }
                   1580: 
                   1581: sub keysinorder {
                   1582:     my ($name,$keyorder)=@_;
                   1583:     return sort {
                   1584: 	$$keyorder{$a} <=> $$keyorder{$b};
                   1585:     } (keys %{$name});
                   1586: }
                   1587: 
1.236     albertel 1588: sub keysinorder_bytype {
                   1589:     my ($name,$keyorder)=@_;
                   1590:     return sort {
                   1591: 	my $ta=(split('_',$a))[-1];
                   1592: 	my $tb=(split('_',$b))[-1];
                   1593: 	if ($$keyorder{'parameter_0_'.$ta} == $$keyorder{'parameter_0_'.$tb}) {
                   1594: 	    return ($a cmp $b);
                   1595: 	}
                   1596: 	$$keyorder{'parameter_0_'.$ta} <=> $$keyorder{'parameter_0_'.$tb};
                   1597:     } (keys %{$name});
                   1598: }
                   1599: 
1.211     www      1600: sub keysindisplayorder {
                   1601:     my ($name,$keyorder)=@_;
                   1602:     return sort {
                   1603: 	$$keyorder{'parameter_0_'.$a} <=> $$keyorder{'parameter_0_'.$b};
                   1604:     } (keys %{$name});
                   1605: }
                   1606: 
1.214     www      1607: sub sortmenu {
                   1608:     my ($r,$sortorder)=@_;
1.236     albertel 1609:     $r->print('<br /><label><input type="radio" name="sortorder" value="realmstudent"');
1.214     www      1610:     if ($sortorder eq 'realmstudent') {
1.422     bisitz   1611:        $r->print(' checked="checked"');
1.214     www      1612:     }
                   1613:     $r->print(' />'.&mt('Sort by realm first, then student (group/section)'));
1.236     albertel 1614:     $r->print('</label><br /><label><input type="radio" name="sortorder" value="studentrealm"');
1.214     www      1615:     if ($sortorder eq 'studentrealm') {
1.422     bisitz   1616:        $r->print(' checked="checked"');
1.214     www      1617:     }
1.236     albertel 1618:     $r->print(' />'.&mt('Sort by student (group/section) first, then realm').
                   1619: 	      '</label>');
1.214     www      1620: }
                   1621: 
1.211     www      1622: sub standardkeyorder {
                   1623:     return ('parameter_0_opendate' => 1,
                   1624: 	    'parameter_0_duedate' => 2,
                   1625: 	    'parameter_0_answerdate' => 3,
                   1626: 	    'parameter_0_interval' => 4,
                   1627: 	    'parameter_0_weight' => 5,
                   1628: 	    'parameter_0_maxtries' => 6,
                   1629: 	    'parameter_0_hinttries' => 7,
                   1630: 	    'parameter_0_contentopen' => 8,
                   1631: 	    'parameter_0_contentclose' => 9,
                   1632: 	    'parameter_0_type' => 10,
                   1633: 	    'parameter_0_problemstatus' => 11,
                   1634: 	    'parameter_0_hiddenresource' => 12,
                   1635: 	    'parameter_0_hiddenparts' => 13,
                   1636: 	    'parameter_0_display' => 14,
                   1637: 	    'parameter_0_ordered' => 15,
                   1638: 	    'parameter_0_tol' => 16,
                   1639: 	    'parameter_0_sig' => 17,
1.218     www      1640: 	    'parameter_0_turnoffunit' => 18,
                   1641:             'parameter_0_discussend' => 19,
                   1642:             'parameter_0_discusshide' => 20);
1.211     www      1643: }
                   1644: 
1.59      matthew  1645: 
1.30      www      1646: sub assessparms {
1.1       www      1647: 
1.43      albertel 1648:     my $r=shift;
1.201     www      1649: 
                   1650:     my @ids=();
                   1651:     my %symbp=();
                   1652:     my %mapp=();
                   1653:     my %typep=();
                   1654:     my %keyp=();
                   1655:     my %uris=();
                   1656:     my %maptitles=();
                   1657: 
1.2       www      1658: # -------------------------------------------------------- Variable declaration
1.209     www      1659: 
1.129     www      1660:     my %allmaps=();
                   1661:     my %alllevs=();
1.57      albertel 1662: 
1.187     www      1663:     my $uname;
                   1664:     my $udom;
                   1665:     my $uhome;
                   1666:     my $csec;
1.269     raeburn  1667:     my $cgroup;
1.275     raeburn  1668:     my @usersgroups = ();
1.187     www      1669:  
1.190     albertel 1670:     my $coursename=$env{'course.'.$env{'request.course.id'}.'.description'};
1.187     www      1671: 
1.57      albertel 1672:     $alllevs{'Resource Level'}='full';
1.215     www      1673:     $alllevs{'Map/Folder Level'}='map';
1.57      albertel 1674:     $alllevs{'Course Level'}='general';
                   1675: 
                   1676:     my %allparms;
                   1677:     my %allparts;
1.210     www      1678: #
                   1679: # Order in which these parameters will be displayed
                   1680: #
1.211     www      1681:     my %keyorder=&standardkeyorder();
                   1682: 
1.43      albertel 1683:     @ids=();
                   1684:     %symbp=();
                   1685:     %typep=();
                   1686: 
                   1687:     my $message='';
                   1688: 
1.190     albertel 1689:     $csec=$env{'form.csec'};
1.269     raeburn  1690:     $cgroup=$env{'form.cgroup'};
1.188     www      1691: 
1.190     albertel 1692:     if      ($udom=$env{'form.udom'}) {
                   1693:     } elsif ($udom=$env{'request.role.domain'}) {
                   1694:     } elsif ($udom=$env{'user.domain'}) {
1.172     albertel 1695:     } else {
                   1696: 	$udom=$r->dir_config('lonDefDomain');
                   1697:     }
1.43      albertel 1698: 
1.134     albertel 1699:     my @pscat=&Apache::loncommon::get_env_multiple('form.pscat');
1.190     albertel 1700:     my $pschp=$env{'form.pschp'};
1.134     albertel 1701:     my @psprt=&Apache::loncommon::get_env_multiple('form.psprt');
1.76      www      1702:     if (!@psprt) { $psprt[0]='0'; }
1.57      albertel 1703: 
1.43      albertel 1704:     my $pssymb='';
1.57      albertel 1705:     my $parmlev='';
                   1706:  
1.190     albertel 1707:     unless ($env{'form.parmlev'}) {
1.57      albertel 1708:         $parmlev = 'map';
                   1709:     } else {
1.190     albertel 1710:         $parmlev = $env{'form.parmlev'};
1.57      albertel 1711:     }
1.26      www      1712: 
1.29      www      1713: # ----------------------------------------------- Was this started from grades?
                   1714: 
1.190     albertel 1715:     if (($env{'form.command'} eq 'set') && ($env{'form.url'})
                   1716: 	&& (!$env{'form.dis'})) {
                   1717: 	my $url=$env{'form.url'};
1.194     albertel 1718: 	$url=~s-^http://($ENV{'SERVER_NAME'}|$ENV{'HTTP_HOST'})--;
1.43      albertel 1719: 	$pssymb=&Apache::lonnet::symbread($url);
1.92      albertel 1720: 	if (!@pscat) { @pscat=('all'); }
1.43      albertel 1721: 	$pschp='';
1.57      albertel 1722:         $parmlev = 'full';
1.190     albertel 1723:     } elsif ($env{'form.symb'}) {
                   1724: 	$pssymb=$env{'form.symb'};
1.92      albertel 1725: 	if (!@pscat) { @pscat=('all'); }
1.43      albertel 1726: 	$pschp='';
1.57      albertel 1727:         $parmlev = 'full';
1.43      albertel 1728:     } else {
1.190     albertel 1729: 	$env{'form.url'}='';
1.43      albertel 1730:     }
                   1731: 
1.190     albertel 1732:     my $id=$env{'form.id'};
1.43      albertel 1733:     if (($id) && ($udom)) {
                   1734: 	$uname=(&Apache::lonnet::idget($udom,$id))[1];
                   1735: 	if ($uname) {
                   1736: 	    $id='';
                   1737: 	} else {
                   1738: 	    $message=
1.314     albertel 1739: 		'<span class="LC_error">'.&mt("Unknown ID")." '$id' ".
                   1740: 		&mt('at domain')." '$udom'</span>";
1.43      albertel 1741: 	}
                   1742:     } else {
1.190     albertel 1743: 	$uname=$env{'form.uname'};
1.43      albertel 1744:     }
                   1745:     unless ($udom) { $uname=''; }
                   1746:     $uhome='';
                   1747:     if ($uname) {
                   1748: 	$uhome=&Apache::lonnet::homeserver($uname,$udom);
                   1749:         if ($uhome eq 'no_host') {
                   1750: 	    $message=
1.314     albertel 1751: 		'<span class="LC_error">'.&mt("Unknown user")." '$uname' ".
                   1752: 		&mt("at domain")." '$udom'</span>";
1.43      albertel 1753: 	    $uname='';
1.12      www      1754:         } else {
1.103     albertel 1755: 	    $csec=&Apache::lonnet::getsection($udom,$uname,
1.190     albertel 1756: 					      $env{'request.course.id'});
1.269     raeburn  1757:             
1.43      albertel 1758: 	    if ($csec eq '-1') {
1.314     albertel 1759: 		$message='<span class="LC_error">'.
1.133     www      1760: 		    &mt("User")." '$uname' ".&mt("at domain")." '$udom' ".
1.314     albertel 1761: 		    &mt("not in this course")."</span>";
1.43      albertel 1762: 		$uname='';
1.190     albertel 1763: 		$csec=$env{'form.csec'};
1.269     raeburn  1764:                 $cgroup=$env{'form.cgroup'};
1.43      albertel 1765: 	    } else {
                   1766: 		my %name=&Apache::lonnet::userenvironment($udom,$uname,
                   1767: 		      ('firstname','middlename','lastname','generation','id'));
1.133     www      1768: 		$message="\n<p>\n".&mt("Full Name").": ".
1.43      albertel 1769: 		    $name{'firstname'}.' '.$name{'middlename'}.' '
                   1770: 			.$name{'lastname'}.' '.$name{'generation'}.
1.336     albertel 1771: 			    "<br />\n".&mt('ID').": ".$name{'id'}.'<p>';
1.43      albertel 1772: 	    }
1.297     raeburn  1773:             @usersgroups = &Apache::lonnet::get_users_groups(
1.275     raeburn  1774:                                        $udom,$uname,$env{'request.course.id'});
1.297     raeburn  1775:             if (@usersgroups > 0) {
1.306     albertel 1776:                 unless (grep(/^\Q$cgroup\E$/,@usersgroups)) {
1.275     raeburn  1777:                     $cgroup = $usersgroups[0];
1.297     raeburn  1778:                 }
1.269     raeburn  1779:             }
1.12      www      1780:         }
1.43      albertel 1781:     }
1.2       www      1782: 
1.43      albertel 1783:     unless ($csec) { $csec=''; }
1.269     raeburn  1784:     unless ($cgroup) { $cgroup=''; }
1.12      www      1785: 
1.14      www      1786: # --------------------------------------------------------- Get all assessments
1.210     www      1787:     &extractResourceInformation(\@ids, \%typep,\%keyp, \%allparms, \%allparts, \%allmaps, 
                   1788: 				\%mapp, \%symbp,\%maptitles,\%uris,
                   1789: 				\%keyorder);
1.63      bowersj2 1790: 
1.57      albertel 1791:     $mapp{'0.0'} = '';
                   1792:     $symbp{'0.0'} = '';
1.99      albertel 1793: 
1.14      www      1794: # ---------------------------------------------------------- Anything to store?
1.190     albertel 1795:     if ($env{'form.pres_marker'}) {
1.205     www      1796:         my @markers=split(/\&\&\&/,$env{'form.pres_marker'});
                   1797:         my @values=split(/\&\&\&/,$env{'form.pres_value'});
                   1798:         my @types=split(/\&\&\&/,$env{'form.pres_type'});
                   1799: 	for (my $i=0;$i<=$#markers;$i++) {
                   1800: 	    $message.=&storeparm(split(/\&/,$markers[$i]),
                   1801: 				 $values[$i],
                   1802: 				 $types[$i],
1.269     raeburn  1803: 				 $uname,$udom,$csec,$cgroup);
1.205     www      1804: 	}
1.68      www      1805: # ---------------------------------------------------------------- Done storing
1.130     www      1806: 	$message.='<h3>'.&mt('Changes can take up to 10 minutes before being active for all students.').&Apache::loncommon::help_open_topic('Caching').'</h3>';
1.68      www      1807:     }
1.57      albertel 1808: #----------------------------------------------- if all selected, fill in array
1.209     www      1809:     if ($pscat[0] eq "all") {@pscat = (keys %allparms);}
                   1810:     if (!@pscat) { @pscat=('duedate','opendate','answerdate','weight','maxtries') }; 
1.57      albertel 1811:     if ($psprt[0] eq "all" || !@psprt) {@psprt = (keys %allparts);}
1.2       www      1812: # ------------------------------------------------------------------ Start page
1.63      bowersj2 1813: 
1.209     www      1814:     &startpage($r);
1.57      albertel 1815: 
1.44      albertel 1816:     foreach ('tolerance','date_default','date_start','date_end',
                   1817: 	     'date_interval','int','float','string') {
                   1818: 	$r->print('<input type="hidden" value="'.
1.378     albertel 1819: 		  &HTML::Entities::encode($env{'form.recent_'.$_},'"&<>').
                   1820: 		  '" name="recent_'.$_.'" />');
1.44      albertel 1821:     }
1.57      albertel 1822:                         
1.44      albertel 1823:     if (!$pssymb) {
1.209     www      1824:         $r->print('<table border="1"><tr><td>');
                   1825:         &levelmenu($r,\%alllevs,$parmlev);
1.424     bisitz   1826:         $r->print('</td>');
1.128     albertel 1827: 	if ($parmlev ne 'general') {
1.209     www      1828:             $r->print('<td>');
                   1829: 	    &mapmenu($r,\%allmaps,$pschp,\%maptitles);
                   1830: 	    $r->print('</td>');
1.128     albertel 1831: 	}
1.424     bisitz   1832:         $r->print('</tr></table>');
1.211     www      1833: 	&displaymenu($r,\%allparms,\%allparts,\@pscat,\@psprt,\%keyorder);
1.44      albertel 1834:     } else {
1.125     www      1835:         my ($map,$id,$resource)=&Apache::lonnet::decode_symb($pssymb);
1.312     albertel 1836: 	my $title = &Apache::lonnet::gettitle($pssymb);
                   1837:         $r->print(&mt('Specific Resource: [_1] ([_2])',$title,$resource).
                   1838:                   '<input type="hidden" value="'.$pssymb.'" name="symb" />'.
1.238     www      1839: 		  '<br /><label><b>'.&mt('Show all parts').': <input type="checkbox" name="psprt" value="all"'.
                   1840: 		  ($env{'form.psprt'}?' checked="checked"':'').' /></b></label><br />');
1.57      albertel 1841:     }
1.275     raeburn  1842:     &usermenu($r,$uname,$id,$udom,$csec,$cgroup,$parmlev,\@usersgroups);    
1.57      albertel 1843: 
1.210     www      1844:     $r->print('<p>'.$message.'</p>');
                   1845: 
1.209     www      1846:     $r->print('<br /><input type="submit" name="dis" value="'.&mt("Update Parameter Display").'" />');
1.57      albertel 1847: 
                   1848:     my @temp_pscat;
                   1849:     map {
                   1850:         my $cat = $_;
                   1851:         push(@temp_pscat, map { $_.'.'.$cat } @psprt);
                   1852:     } @pscat;
                   1853: 
                   1854:     @pscat = @temp_pscat;
                   1855: 
1.209     www      1856:     if (($env{'form.prevvisit'}) || ($pschp) || ($pssymb)) {
1.10      www      1857: # ----------------------------------------------------------------- Start Table
1.57      albertel 1858:         my @catmarker=map { tr|.|_|; 'parameter_'.$_; } @pscat;
1.190     albertel 1859:         my $csuname=$env{'user.name'};
                   1860:         my $csudom=$env{'user.domain'};
1.57      albertel 1861: 
1.203     www      1862:         if ($parmlev eq 'full') {
1.57      albertel 1863:            my $coursespan=$csec?8:5;
1.275     raeburn  1864:            my $userspan=3;
1.269     raeburn  1865:            if ($cgroup ne '') {
                   1866:               $coursespan += 3;
                   1867:            } 
                   1868:       
1.419     bisitz   1869:            $r->print('<p><table border="2">');
                   1870:            $r->print('<tr><td colspan="5"></td>');
                   1871:            $r->print('<th colspan="'.($coursespan).'">'.&mt('Any User').'</th>');
1.57      albertel 1872:            if ($uname) {
1.275     raeburn  1873:                if (@usersgroups > 1) {
                   1874:                    $userspan ++;
                   1875:                }
                   1876:                $r->print('<th colspan="'.$userspan.'" rowspan="2">');
1.130     www      1877:                $r->print(&mt("User")." $uname ".&mt('at Domain')." $udom</th>");
1.57      albertel 1878:            }
1.133     www      1879: 	   my %lt=&Apache::lonlocal::texthash(
                   1880: 				  'pie'    => "Parameter in Effect",
                   1881: 				  'csv'    => "Current Session Value",
                   1882:                                   'at'     => 'at',
                   1883:                                   'rl'     => "Resource Level",
                   1884: 				  'ic'     => 'in Course',
                   1885: 				  'aut'    => "Assessment URL and Title",
1.143     albertel 1886: 				  'type'   => 'Type',
1.133     www      1887: 				  'emof'   => "Enclosing Map or Folder",
1.143     albertel 1888: 				  'part'   => 'Part',
1.133     www      1889:                                   'pn'     => 'Parameter Name',
                   1890: 				  'def'    => 'default',
                   1891: 				  'femof'  => 'from Enclosing Map or Folder',
                   1892: 				  'gen'    => 'general',
                   1893: 				  'foremf' => 'for Enclosing Map or Folder',
                   1894: 				  'fr'     => 'for Resource'
                   1895: 					      );
1.57      albertel 1896:            $r->print(<<ENDTABLETWO);
1.419     bisitz   1897: <th rowspan="3">$lt{'pie'}</th>
                   1898: <th rowspan="3">$lt{'csv'}<br />($csuname $lt{'at'} $csudom)</th>
                   1899: </tr><tr><td colspan="5"></td><th colspan="2">$lt{'ic'}</th><th colspan="2">$lt{'rl'}</th>
                   1900: <th colspan="1">$lt{'ic'}</th>
1.182     albertel 1901: 
1.10      www      1902: ENDTABLETWO
1.57      albertel 1903:            if ($csec) {
1.419     bisitz   1904:                 $r->print('<th colspan="3">'.
1.269     raeburn  1905: 			  &mt("in Section")." $csec</th>");
                   1906:            }
                   1907:            if ($cgroup) {
1.419     bisitz   1908:                 $r->print('<th colspan="3">'.
1.269     raeburn  1909:                           &mt("in Group")." $cgroup</th>");
1.57      albertel 1910:            }
                   1911:            $r->print(<<ENDTABLEHEADFOUR);
1.133     www      1912: </tr><tr><th>$lt{'aut'}</th><th>$lt{'type'}</th>
                   1913: <th>$lt{'emof'}</th><th>$lt{'part'}</th><th>$lt{'pn'}</th>
1.192     albertel 1914: <th>$lt{'gen'}</th><th>$lt{'foremf'}</th>
                   1915: <th>$lt{'def'}</th><th>$lt{'femof'}</th><th>$lt{'fr'}</th>
1.10      www      1916: ENDTABLEHEADFOUR
1.57      albertel 1917: 
                   1918:            if ($csec) {
1.130     www      1919:                $r->print('<th>'.&mt('general').'</th><th>'.&mt('for Enclosing Map or Folder').'</th><th>'.&mt('for Resource').'</th>');
1.57      albertel 1920:            }
                   1921: 
1.269     raeburn  1922:            if ($cgroup) {
                   1923:                $r->print('<th>'.&mt('general').'</th><th>'.&mt('for Enclosing Map or Folder').'</th><th>'.&mt('for Resource').'</th>');
                   1924:            }
                   1925: 
1.57      albertel 1926:            if ($uname) {
1.275     raeburn  1927:                if (@usersgroups > 1) {
                   1928:                    $r->print('<th>'.&mt('Control by other group?').'</th>');
                   1929:                }
1.130     www      1930:                $r->print('<th>'.&mt('general').'</th><th>'.&mt('for Enclosing Map or Folder').'</th><th>'.&mt('for Resource').'</th>');
1.57      albertel 1931:            }
                   1932: 
                   1933:            $r->print('</tr>');
                   1934: 
                   1935:            my $defbgone='';
                   1936:            my $defbgtwo='';
1.269     raeburn  1937:            my $defbgthree = '';
1.57      albertel 1938: 
                   1939:            foreach (@ids) {
                   1940: 
                   1941:                 my $rid=$_;
                   1942:                 my ($inmapid)=($rid=~/\.(\d+)$/);
                   1943: 
1.152     albertel 1944:                 if ((!$pssymb && 
                   1945: 		     (($pschp eq 'all') || ($allmaps{$pschp} eq $mapp{$rid})))
                   1946: 		    ||
                   1947: 		    ($pssymb && $pssymb eq $symbp{$rid})) {
1.4       www      1948: # ------------------------------------------------------ Entry for one resource
1.419     bisitz   1949:                     if ($defbgone eq '#E0E099') {
                   1950:                         $defbgone='#E0E0DD';
1.57      albertel 1951:                     } else {
1.419     bisitz   1952:                         $defbgone='#E0E099';
1.57      albertel 1953:                     }
1.419     bisitz   1954:                     if ($defbgtwo eq '#FFFF99') {
                   1955:                         $defbgtwo='#FFFFDD';
1.57      albertel 1956:                     } else {
1.419     bisitz   1957:                         $defbgtwo='#FFFF99';
1.57      albertel 1958:                     }
1.419     bisitz   1959:                     if ($defbgthree eq '#FFBB99') {
                   1960:                         $defbgthree='#FFBBDD';
1.269     raeburn  1961:                     } else {
1.419     bisitz   1962:                         $defbgthree='#FFBB99';
1.269     raeburn  1963:                     }
                   1964: 
1.57      albertel 1965:                     my $thistitle='';
                   1966:                     my %name=   ();
                   1967:                     undef %name;
                   1968:                     my %part=   ();
                   1969:                     my %display=();
                   1970:                     my %type=   ();
                   1971:                     my %default=();
1.196     www      1972:                     my $uri=&Apache::lonnet::declutter($uris{$rid});
1.57      albertel 1973: 
1.210     www      1974:                     foreach (&keysplit($keyp{$rid})) {
1.57      albertel 1975:                         my $tempkeyp = $_;
                   1976:                         if (grep $_ eq $tempkeyp, @catmarker) {
                   1977:                           $part{$_}=&Apache::lonnet::metadata($uri,$_.'.part');
                   1978:                           $name{$_}=&Apache::lonnet::metadata($uri,$_.'.name');
                   1979:                           $display{$_}=&Apache::lonnet::metadata($uri,$_.'.display');
                   1980:                           unless ($display{$_}) { $display{$_}=''; }
                   1981:                           $display{$_}.=' ('.$name{$_}.')';
                   1982:                           $default{$_}=&Apache::lonnet::metadata($uri,$_);
                   1983:                           $type{$_}=&Apache::lonnet::metadata($uri,$_.'.type');
                   1984:                           $thistitle=&Apache::lonnet::metadata($uri,$_.'.title');
                   1985:                         }
                   1986:                     }
                   1987:                     my $totalparms=scalar keys %name;
                   1988:                     if ($totalparms>0) {
                   1989:                         my $firstrow=1;
1.274     albertel 1990: 			my $title=&Apache::lonnet::gettitle($symbp{$rid});
1.419     bisitz   1991:                         $r->print('<tr><td style="background-color:'.$defbgone.';"'.
1.57      albertel 1992:                              ' rowspan='.$totalparms.
1.419     bisitz   1993:                              '><tt><font size="-1">'.
1.57      albertel 1994:                              join(' / ',split(/\//,$uri)).
                   1995:                              '</font></tt><p><b>'.
1.154     albertel 1996:                              "<a href=\"javascript:openWindow('".
1.274     albertel 1997: 				  &Apache::lonnet::clutter($uri).'?symb='.
1.308     www      1998: 				  &escape($symbp{$rid}).
1.336     albertel 1999:                              "', 'metadatafile', '450', '500', 'no', 'yes');\"".
                   2000:                              " target=\"_self\">$title");
1.57      albertel 2001: 
                   2002:                         if ($thistitle) {
                   2003:                             $r->print(' ('.$thistitle.')');
                   2004:                         }
                   2005:                         $r->print('</a></b></td>');
1.419     bisitz   2006:                         $r->print('<td style="background-color:'.$defbgtwo.';"'.
1.57      albertel 2007:                                       ' rowspan='.$totalparms.'>'.$typep{$rid}.
                   2008:                                       '</td>');
                   2009: 
1.419     bisitz   2010:                         $r->print('<td style="background-color:'.$defbgone.';"'.
1.57      albertel 2011:                                       ' rowspan='.$totalparms.
1.238     www      2012:                                       '>'.$maptitles{$mapp{$rid}}.'</td>');
1.57      albertel 2013: 
1.236     albertel 2014:                         foreach (&keysinorder_bytype(\%name,\%keyorder)) {
1.57      albertel 2015:                             unless ($firstrow) {
                   2016:                                 $r->print('<tr>');
                   2017:                             } else {
                   2018:                                 undef $firstrow;
                   2019:                             }
1.201     www      2020:                             &print_row($r,$_,\%part,\%name,\%symbp,$rid,\%default,
1.57      albertel 2021:                                        \%type,\%display,$defbgone,$defbgtwo,
1.269     raeburn  2022:                                        $defbgthree,$parmlev,$uname,$udom,$csec,
1.275     raeburn  2023:                                                             $cgroup,\@usersgroups);
1.57      albertel 2024:                         }
                   2025:                     }
                   2026:                 }
                   2027:             } # end foreach ids
1.43      albertel 2028: # -------------------------------------------------- End entry for one resource
1.57      albertel 2029:             $r->print('</table>');
1.203     www      2030:         } # end of  full
1.57      albertel 2031: #--------------------------------------------------- Entry for parm level map
                   2032:         if ($parmlev eq 'map') {
1.419     bisitz   2033:             my $defbgone = '#E0E099';
                   2034:             my $defbgtwo = '#FFFF99';
                   2035:             my $defbgthree = '#FFBB99';
1.57      albertel 2036: 
                   2037:             my %maplist;
                   2038: 
                   2039:             if ($pschp eq 'all') {
                   2040:                 %maplist = %allmaps; 
                   2041:             } else {
                   2042:                 %maplist = ($pschp => $mapp{$pschp});
                   2043:             }
                   2044: 
                   2045: #-------------------------------------------- for each map, gather information
                   2046:             my $mapid;
1.60      albertel 2047: 	    foreach $mapid (sort {$maplist{$a} cmp $maplist{$b}} keys %maplist) {
                   2048:                 my $maptitle = $maplist{$mapid};
1.57      albertel 2049: 
                   2050: #-----------------------  loop through ids and get all parameter types for map
                   2051: #-----------------------------------------          and associated information
                   2052:                 my %name = ();
                   2053:                 my %part = ();
                   2054:                 my %display = ();
                   2055:                 my %type = ();
                   2056:                 my %default = ();
                   2057:                 my $map = 0;
                   2058: 
                   2059: #		$r->print("Catmarker: @catmarker<br />\n");
                   2060:                
                   2061:                 foreach (@ids) {
                   2062:                   ($map)=(/([\d]*?)\./);
                   2063:                   my $rid = $_;
                   2064:         
                   2065: #                  $r->print("$mapid:$map:   $rid <br /> \n");
                   2066: 
                   2067:                   if ($map eq $mapid) {
1.196     www      2068:                     my $uri=&Apache::lonnet::declutter($uris{$rid});
1.57      albertel 2069: #                    $r->print("Keys: $keyp{$rid} <br />\n");
                   2070: 
                   2071: #--------------------------------------------------------------------
                   2072: # @catmarker contains list of all possible parameters including part #s
                   2073: # $fullkeyp contains the full part/id # for the extraction of proper parameters
                   2074: # $tempkeyp contains part 0 only (no ids - ie, subparts)
                   2075: # When storing information, store as part 0
                   2076: # When requesting information, request from full part
                   2077: #-------------------------------------------------------------------
1.210     www      2078:                     foreach (&keysplit($keyp{$rid})) {
1.57      albertel 2079:                       my $tempkeyp = $_;
                   2080:                       my $fullkeyp = $tempkeyp;
1.73      albertel 2081:                       $tempkeyp =~ s/_\w+_/_0_/;
1.57      albertel 2082:                       
                   2083:                       if ((grep $_ eq $fullkeyp, @catmarker) &&(!$name{$tempkeyp})) {
                   2084:                         $part{$tempkeyp}="0";
                   2085:                         $name{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.name');
                   2086:                         $display{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.display');
                   2087:                         unless ($display{$tempkeyp}) { $display{$tempkeyp}=''; }
                   2088:                         $display{$tempkeyp}.=' ('.$name{$tempkeyp}.')';
1.73      albertel 2089:                         $display{$tempkeyp} =~ s/_\w+_/_0_/;
1.57      albertel 2090:                         $default{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp);
                   2091:                         $type{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.type');
                   2092:                       }
                   2093:                     } # end loop through keys
                   2094:                   }
                   2095:                 } # end loop through ids
                   2096:                                  
                   2097: #---------------------------------------------------- print header information
1.133     www      2098:                 my $foldermap=&mt($maptitle=~/^uploaded/?'Folder':'Map');
1.82      www      2099:                 my $showtitle=$maptitles{$maptitle}.($maptitle!~/^uploaded/?' ['.$maptitle.']':'');
1.401     bisitz   2100:                 my $tmp="";
1.57      albertel 2101:                 if ($uname) {
1.267     albertel 2102: 		    my $person=&Apache::loncommon::plainname($uname,$udom);
1.401     bisitz   2103:                     $tmp.=&mt("User")." <font color=\"red\"><i>$uname \($person\) </i></font> ".
                   2104:                         &mt('in')." \n";
1.57      albertel 2105:                 } else {
1.401     bisitz   2106:                     $tmp.="<font color=\"red\"><i>".&mt('all').'</i></font> '.&mt('users in')." \n";
1.57      albertel 2107:                 }
1.269     raeburn  2108:                 if ($cgroup) {
1.401     bisitz   2109:                     $tmp.=&mt("Group")." <font color=\"red\"><i>$cgroup".
                   2110:                               "</i></font> ".&mt('of')." \n";
1.269     raeburn  2111:                     $csec = '';
                   2112:                 } elsif ($csec) {
1.401     bisitz   2113:                     $tmp.=&mt("Section")." <font color=\"red\"><i>$csec".
                   2114:                               "</i></font> ".&mt('of')." \n";
1.269     raeburn  2115:                 }
1.401     bisitz   2116:                 $r->print('<div align="center"><h4>'
                   2117:                          .&mt('Set Defaults for All Resources in [_1]Specifically for [_2][_3]'
1.404     bisitz   2118:                              ,$foldermap.'<br /><font color="red"><i>'.$showtitle.'</i></font><br />'
1.401     bisitz   2119:                              ,$tmp
                   2120:                              ,'<font color="red"><i>'.$coursename.'</i></font>'
                   2121:                              )
                   2122:                          ."<br /></h4>\n"
1.422     bisitz   2123:                 );
1.57      albertel 2124: #---------------------------------------------------------------- print table
1.419     bisitz   2125:                 $r->print('<p>'.&Apache::loncommon::start_data_table()
                   2126:                          .&Apache::loncommon::start_data_table_header_row()
                   2127:                          .'<th>'.&mt('Parameter Name').'</th>'
                   2128:                          .'<th>'.&mt('Default Value').'</th>'
                   2129:                          .'<th>'.&mt('Parameter in Effect').'</th>'
                   2130:                          .&Apache::loncommon::end_data_table_header_row()
                   2131:                 );
1.57      albertel 2132: 
1.210     www      2133: 	        foreach (&keysinorder(\%name,\%keyorder)) {
1.419     bisitz   2134:                     $r->print(&Apache::loncommon::start_data_table_row());
1.201     www      2135:                     &print_row($r,$_,\%part,\%name,\%symbp,$mapid,\%default,
1.269     raeburn  2136:                            \%type,\%display,$defbgone,$defbgtwo,$defbgthree,
                   2137:                            $parmlev,$uname,$udom,$csec,$cgroup);
1.57      albertel 2138:                 }
1.422     bisitz   2139:                 $r->print(&Apache::loncommon::end_data_table().'</p>'
                   2140:                          .'</div>'
                   2141:                 );
1.57      albertel 2142:             } # end each map
                   2143:         } # end of $parmlev eq map
                   2144: #--------------------------------- Entry for parm level general (Course level)
                   2145:         if ($parmlev eq 'general') {
1.419     bisitz   2146:             my $defbgone = '#E0E099';
                   2147:             my $defbgtwo = '#FFFF99';
                   2148:             my $defbgthree = '#FFBB99';
1.57      albertel 2149: 
                   2150: #-------------------------------------------- for each map, gather information
                   2151:             my $mapid="0.0";
                   2152: #-----------------------  loop through ids and get all parameter types for map
                   2153: #-----------------------------------------          and associated information
                   2154:             my %name = ();
                   2155:             my %part = ();
                   2156:             my %display = ();
                   2157:             my %type = ();
                   2158:             my %default = ();
                   2159:                
                   2160:             foreach (@ids) {
                   2161:                 my $rid = $_;
                   2162:         
1.196     www      2163:                 my $uri=&Apache::lonnet::declutter($uris{$rid});
1.57      albertel 2164: 
                   2165: #--------------------------------------------------------------------
                   2166: # @catmarker contains list of all possible parameters including part #s
                   2167: # $fullkeyp contains the full part/id # for the extraction of proper parameters
                   2168: # $tempkeyp contains part 0 only (no ids - ie, subparts)
                   2169: # When storing information, store as part 0
                   2170: # When requesting information, request from full part
                   2171: #-------------------------------------------------------------------
1.210     www      2172:                 foreach (&keysplit($keyp{$rid})) {
1.57      albertel 2173:                   my $tempkeyp = $_;
                   2174:                   my $fullkeyp = $tempkeyp;
1.73      albertel 2175:                   $tempkeyp =~ s/_\w+_/_0_/;
1.57      albertel 2176:                   if ((grep $_ eq $fullkeyp, @catmarker) &&(!$name{$tempkeyp})) {
                   2177:                     $part{$tempkeyp}="0";
                   2178:                     $name{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.name');
                   2179:                     $display{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.display');
                   2180:                     unless ($display{$tempkeyp}) { $display{$tempkeyp}=''; }
                   2181:                     $display{$tempkeyp}.=' ('.$name{$tempkeyp}.')';
1.73      albertel 2182:                     $display{$tempkeyp} =~ s/_\w+_/_0_/;
1.57      albertel 2183:                     $default{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp);
                   2184:                     $type{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.type');
                   2185:                   }
                   2186:                 } # end loop through keys
                   2187:             } # end loop through ids
                   2188:                                  
                   2189: #---------------------------------------------------- print header information
1.133     www      2190: 	    my $setdef=&mt("Set Defaults for All Resources in Course");
1.57      albertel 2191:             $r->print(<<ENDMAPONE);
1.419     bisitz   2192: <center>
                   2193: <h4>$setdef
1.135     albertel 2194: <font color="red"><i>$coursename</i></font><br />
1.57      albertel 2195: ENDMAPONE
                   2196:             if ($uname) {
1.267     albertel 2197: 		my $person=&Apache::loncommon::plainname($uname,$udom);
1.135     albertel 2198:                 $r->print(" ".&mt("User")."<font color=\"red\"> <i>$uname \($person\) </i></font> \n");
1.57      albertel 2199:             } else {
1.135     albertel 2200:                 $r->print("<i><font color=\"red\"> ".&mt("ALL")."</i> ".&mt("USERS")."</font> \n");
1.57      albertel 2201:             }
                   2202:             
1.135     albertel 2203:             if ($csec) {$r->print(&mt("Section")."<font color=\"red\"> <i>$csec</i></font>\n")};
1.306     albertel 2204:             if ($cgroup) {$r->print(&mt("Group")."<font color=\"red\"> <i>$cgroup</i></font>\n")};
1.135     albertel 2205:             $r->print("</h4>\n");
1.57      albertel 2206: #---------------------------------------------------------------- print table
1.419     bisitz   2207:             $r->print('<p>'.&Apache::loncommon::start_data_table()
                   2208:                      .&Apache::loncommon::start_data_table_header_row()
                   2209:                      .'<th>'.&mt('Parameter Name').'</th>'
                   2210:                      .'<th>'.&mt('Default Value').'</th>'
                   2211:                      .'<th>'.&mt('Parameter in Effect').'</th>'
                   2212:                      .&Apache::loncommon::end_data_table_header_row()
                   2213:             );
1.57      albertel 2214: 
1.210     www      2215: 	    foreach (&keysinorder(\%name,\%keyorder)) {
1.419     bisitz   2216:                 $r->print(&Apache::loncommon::start_data_table_row());
1.201     www      2217:                 &print_row($r,$_,\%part,\%name,\%symbp,$mapid,\%default,
1.269     raeburn  2218:                        \%type,\%display,$defbgone,$defbgtwo,$defbgthree,
                   2219:                                    $parmlev,$uname,$udom,$csec,$cgroup);
1.57      albertel 2220:             }
1.419     bisitz   2221:             $r->print(&Apache::loncommon::end_data_table()
                   2222:                      .'</p>'
                   2223:                      .'</center>'
                   2224:             );
1.57      albertel 2225:         } # end of $parmlev eq general
1.43      albertel 2226:     }
1.280     albertel 2227:     $r->print('</form>'.&Apache::loncommon::end_page());
1.57      albertel 2228: } # end sub assessparms
1.30      www      2229: 
1.59      matthew  2230: 
                   2231: 
1.30      www      2232: sub crsenv {
                   2233:     my $r=shift;
                   2234:     my $setoutput='';
1.280     albertel 2235: 
1.414     droeschl 2236:     &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=crsenv',
                   2237: 	text=>"Course Environment"});
1.298     albertel 2238:     my $breadcrumbs = 
                   2239: 	&Apache::lonhtmlcommon::breadcrumbs('Edit Course Environment');
1.190     albertel 2240:     my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                   2241:     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
1.105     matthew  2242: 
1.392     raeburn  2243:     my (%crsinfo,$chome);
                   2244: 
1.105     matthew  2245:     #
                   2246:     # Go through list of changes
1.190     albertel 2247:     foreach (keys %env) {
1.105     matthew  2248:         next if ($_!~/^form\.(.+)\_setparmval$/);
                   2249:         my $name  = $1;
1.190     albertel 2250:         my $value = $env{'form.'.$name.'_value'};
1.105     matthew  2251:         if ($name eq 'newp') {
1.190     albertel 2252:             $name = $env{'form.newp_name'};
1.105     matthew  2253:         }
                   2254:         if ($name eq 'url') {
                   2255:             $value=~s/^\/res\///;
                   2256:             my $bkuptime=time;
                   2257:             my @tmp = &Apache::lonnet::get
                   2258:                 ('environment',['url'],$dom,$crs);
1.130     www      2259:             $setoutput.=&mt('Backing up previous URL').': '.
1.105     matthew  2260:                 &Apache::lonnet::put
                   2261:                 ('environment',
                   2262:                  {'top level map backup '.$bkuptime => $tmp[1] },
                   2263:                  $dom,$crs).
1.336     albertel 2264:                      '<br />';
1.105     matthew  2265:         }
                   2266:         #
                   2267:         # Deal with modified default spreadsheets
                   2268:         if ($name =~ /^spreadsheet_default_(classcalc|
                   2269:                                             studentcalc|
                   2270:                                             assesscalc)$/x) {
                   2271:             my $sheettype = $1; 
                   2272:             if ($sheettype eq 'classcalc') {
                   2273:                 # no need to do anything since viewing the sheet will
                   2274:                 # cause it to be updated. 
                   2275:             } elsif ($sheettype eq 'studentcalc') {
                   2276:                 # expire all the student spreadsheets
                   2277:                 &Apache::lonnet::expirespread('','','studentcalc');
                   2278:             } else {
                   2279:                 # expire all the assessment spreadsheets 
                   2280:                 #    this includes non-default spreadsheets, but better to
                   2281:                 #    be safe than sorry.
                   2282:                 &Apache::lonnet::expirespread('','','assesscalc');
                   2283:                 # expire all the student spreadsheets
                   2284:                 &Apache::lonnet::expirespread('','','studentcalc');
1.30      www      2285:             }
1.105     matthew  2286:         }
                   2287:         #
1.107     matthew  2288:         # Deal with the enrollment dates
                   2289:         if ($name =~ /^default_enrollment_(start|end)_date$/) {
                   2290:             $value=&Apache::lonhtmlcommon::get_date_from_form($name.'_value');
                   2291:         }
1.364     albertel 2292: 	#
                   2293:         # Deal with the emails
                   2294:         if ($name =~ /\.email$/) {
1.371     albertel 2295: 	    foreach my $specifier (split(',',$value)) {
                   2296: 		my ($user,$sections_or_groups)=
                   2297: 		    ($specifier=~/^([^\(]+)\(([^\)]+)\)/);
                   2298: 		if (!$sections_or_groups) {
                   2299: 		    $user = $specifier;
                   2300: 		}
                   2301: 		my ($name,$domain) = split(':',$user);
                   2302: 		if (!defined($user) || !defined($domain)) {
                   2303: 		    $setoutput.= '<br /> <span class="LC_error">'.
1.425     schafran 2304: 			&mt("Invalid e-mail address specified, address must be of the form username:domain what was specified was ([_1])",$user).
1.371     albertel 2305: 			'</span>';
                   2306: 		    undef($value);
                   2307: 		} elsif (&Apache::lonnet::homeserver($user,$domain) eq 'no_host') {
                   2308: 		    $setoutput.= '<br /> <span class="LC_error">'.
1.425     schafran 2309: 			&mt("Invalid e-mail address specified, user [_1] is unknown.",$name).
1.371     albertel 2310: 			'</span>';
                   2311: 		    undef($value);
                   2312: 		}
1.364     albertel 2313: 	    }
                   2314:         }
1.178     raeburn  2315:         # Get existing cloners
                   2316:         my @oldcloner = ();
                   2317:         if ($name eq 'cloners') {
                   2318:             my %clonenames=&Apache::lonnet::dump('environment',$dom,$crs,'cloners');
                   2319:             if ($clonenames{'cloners'} =~ /,/) {
                   2320:                 @oldcloner = split/,/,$clonenames{'cloners'};
                   2321:             } else {
                   2322:                 $oldcloner[0] = $clonenames{'cloners'};
                   2323:             }
                   2324:         }
1.107     matthew  2325:         #
1.105     matthew  2326:         # Let the user know we made the changes
1.153     albertel 2327:         if ($name && defined($value)) {
1.379     raeburn  2328:             my %failed_cloners;
1.178     raeburn  2329:             if ($name eq 'cloners') {
1.239     raeburn  2330:                 $value =~ s/\s//g;
1.178     raeburn  2331:                 $value =~ s/^,//;
                   2332:                 $value =~ s/,$//;
1.239     raeburn  2333:                 # check requested clones are valid users.
1.379     raeburn  2334:                 %failed_cloners = &check_cloners(\$value,\@oldcloner);
1.178     raeburn  2335:             }
1.105     matthew  2336:             my $put_result = &Apache::lonnet::put('environment',
                   2337:                                                   {$name=>$value},$dom,$crs);
                   2338:             if ($put_result eq 'ok') {
1.392     raeburn  2339:                 $setoutput.=&mt('Set').' <b>'.$name.'</b> '.&mt('to').' <b>';
                   2340:                 if ($name =~ /^default_enrollment_(start|end)_date$/) {
                   2341:                     $setoutput .= &Apache::lonlocal::locallocaltime($value);
1.406     raeburn  2342:                 } elsif ($name eq 'categories') {
                   2343:                     $setoutput .= $env{'form.categories_display'};
1.392     raeburn  2344:                 } else {
                   2345:                     $setoutput .= $value;
                   2346:                 }
                   2347:                 $setoutput .= '</b>.<br />';
1.178     raeburn  2348:                 if ($name eq 'cloners') {
                   2349:                     &change_clone($value,\@oldcloner);
                   2350:                 }
1.382     raeburn  2351:                 # Update environment and nohist_courseids.db
1.402     raeburn  2352:                 if (($name eq 'description') || ($name eq 'cloners') || 
1.403     raeburn  2353:                     ($name eq 'hidefromcat') || ($name eq 'categories')) {
1.392     raeburn  2354:                     if ($chome eq '') {
                   2355:                         %crsinfo =
                   2356:                             &Apache::lonnet::courseiddump($dom,'.',1,'.','.',
1.403     raeburn  2357:                                                  $crs,undef,undef,'.');
1.392     raeburn  2358:                         $chome = &Apache::lonnet::homeserver($crs,$dom);
                   2359:                     }
                   2360:                 }
1.179     raeburn  2361:                 if ($name eq 'description' && defined($value)) {
1.393     raeburn  2362:                     &Apache::lonnet::appenv({'course.'.$env{'request.course.id'}.'.description' => $value});
1.382     raeburn  2363:                     if (ref($crsinfo{$env{'request.course.id'}}) eq 'HASH') {
                   2364:                         $crsinfo{$env{'request.course.id'}}{'description'} = $value; 
1.392     raeburn  2365:                         my $putresult =
                   2366:                             &Apache::lonnet::courseidput($dom,\%crsinfo,
                   2367:                                                          $chome,'notime');
                   2368:                     }
                   2369:                 }
1.403     raeburn  2370:                 if (($name eq 'cloners') || ($name eq 'hidefromcat') || ($name eq 'categories')) {
1.402     raeburn  2371:                     if (ref($crsinfo{$env{'request.course.id'}}) eq 'HASH') {
1.403     raeburn  2372:                         &Apache::lonnet::appenv({'course.'.$env{'request.course.id'}.'.'.$name => $value});
                   2373:                         $crsinfo{$env{'request.course.id'}}{$name} = $value;
1.402     raeburn  2374:                         my $putresult =
                   2375:                             &Apache::lonnet::courseidput($dom,\%crsinfo,
                   2376:                                                          $chome,'notime');
                   2377:                     }
                   2378:                 }
1.105     matthew  2379:             } else {
1.130     www      2380:                 $setoutput.=&mt('Unable to set').' <b>'.$name.'</b> '.&mt('to').
                   2381: 		    ' <b>'.$value.'</b> '.&mt('due to').' '.$put_result.'.<br />';
1.30      www      2382:             }
1.379     raeburn  2383:             if (($name eq 'cloners') && (keys(%failed_cloners) > 0)) {
                   2384:                 $setoutput.= &mt('Unable to include').': ';
                   2385:                 my @fails;
                   2386:                 my $num = 0;
                   2387:                 if (defined($failed_cloners{'format'})) {
                   2388:                     $fails[$num] .= '<b>'.$failed_cloners{'format'}.
                   2389:                                   '</b>, '.&mt('reason').' - '.
                   2390:                                   &mt('Invalid format');
                   2391:                     $num ++;
                   2392:                 }
                   2393:                 if (defined($failed_cloners{'domain'})) {
                   2394:                     $fails[$num] .= '<b>'.$failed_cloners{'domain'}.
                   2395:                                   '</b>, '.&mt('reason').' - '.
                   2396:                                   &mt('Domain does not exist');
                   2397:                     $num ++;
                   2398:                 }
                   2399:                 if (defined($failed_cloners{'newuser'})) {
                   2400:                     $fails[$num] .= '<b>'.$failed_cloners{'newuser'}.                                   '</b>, '.&mt('reason').' - '.
                   2401:                         &mt('LON-CAPA user(s) do(es) not exist.').
                   2402:                         '.<br />'.&mt('Please ').
                   2403:                         ' <a href="/adm/createuser">'.
                   2404:                         &mt('add the user(s)').'</a>, '.
                   2405:                         &mt('and then return to the ').
                   2406:                         '<a href="/adm/parmset?action=crsenv">'.
                   2407:                         &mt('Course Parameters page').'</a> '.
                   2408:                         &mt('to add the new user(s) to the list of possible cloners');
                   2409:                 }
                   2410:                 $setoutput .= join(';&nbsp;&nbsp;',@fails).'.<br />';
1.239     raeburn  2411:             }
1.30      www      2412:         }
1.38      harris41 2413:     }
1.315     albertel 2414: 
                   2415:     my $start_table     =&Apache::loncommon::start_data_table();
                   2416:     my $start_header_row=&Apache::loncommon::start_data_table_header_row();
                   2417:     my $end_header_row  =&Apache::loncommon::end_data_table_header_row();
1.108     www      2418: # ------------------------- Re-init course environment entries for this session
                   2419: 
1.302     albertel 2420:     &Apache::lonnet::coursedescription($env{'request.course.id'},
1.296     albertel 2421: 				       {'freshen_cache' => 1});
1.105     matthew  2422: 
1.30      www      2423: # -------------------------------------------------------- Get parameters again
1.45      matthew  2424: 
                   2425:     my %values=&Apache::lonnet::dump('environment',$dom,$crs);
1.140     sakharuk 2426:     my $SelectStyleFile=&mt('Select Style File');
1.141     sakharuk 2427:     my $SelectSpreadsheetFile=&mt('Select Spreadsheet File');
1.30      www      2428:     my $output='';
1.403     raeburn  2429:     my $can_categorize;
1.45      matthew  2430:     if (! exists($values{'con_lost'})) {
1.30      www      2431:         my %descriptions=
1.395     bisitz   2432: 	    ('url'            => '<b>'.&mt('Top Level Map').'</b><br />'.
1.46      matthew  2433:                                  '<a href="javascript:openbrowser'.
1.47      matthew  2434:                                  "('envform','url','sequence')\">".
1.314     albertel 2435:                                  &mt('Select Map').'</a><br /><span class="LC_warning"> '.
1.395     bisitz   2436:                                  &mt('Modification may make assessment data inaccessible!').
1.314     albertel 2437:                                  '</span>',
1.140     sakharuk 2438:              'description'    => '<b>'.&mt('Course Description').'</b>',
1.158     sakharuk 2439:              'courseid'       => '<b>'.&mt('Course ID or number').
1.140     sakharuk 2440:                                  '</b><br />'.
1.395     bisitz   2441:                                  '('.&mt('internal, optional').')',
                   2442:              'cloners'        => '<b>'.&mt('Users allowed to clone course').'</b><br />'
                   2443:                                 .'("<tt>'.&mt('user:domain,user:domain,*:domain').'</tt>")<br />'
                   2444:                                 .&mt('Users with active Course Coordinator role in this course are permitted to clone and need not be included.').'<br />'
                   2445:                                 .&mt('Use [_1] to allow course to be cloned by anyone in the specified domain.','"<tt>*:domain</tt>"').'<br />'
                   2446:                                 .&mt('Use [_1] to allow unrestricted cloning in all domains.','"<tt>*</tt>"'),
1.150     www      2447:              'grading'        => '<b>'.&mt('Grading').'</b><br />'.
1.395     bisitz   2448:                                  &mt('[_1], [_2], or [_3]','"<tt>standard</tt>"','"<tt>external</tt>"','"<tt>spreadsheet</tt>"').&Apache::loncommon::help_open_topic('GradingOptions'),
                   2449: 	     'task_grading'   => '<b>'.&mt('Bridge Task Grading').'</b><br />'
                   2450:                                 .&mt('Instructors and TAs in sections, when grading bridge tasks, should be allowed to grade other sections.').'<br />'
                   2451:                                 .'('.&mt('[_1]: they are allowed (this is the default). [_2]: no, they can only grade their own section.','"<tt>any</tt>"','"<tt>section</tt>"').')',
                   2452:              'default_xml_style' => '<b>'.&mt('Default XML Style File').'</b><br />'.
1.52      www      2453:                     '<a href="javascript:openbrowser'.
                   2454:                     "('envform','default_xml_style'".
1.336     albertel 2455:                     ",'sty')\">$SelectStyleFile</a><br />",
1.395     bisitz   2456:              'question.email' => '<b>'.&mt('Feedback Addresses for Resource Content Question').'</b><br />'
                   2457:                                 .'("<tt>'.&mt('user:domain,user:domain(section;section;...;*;...),...').'</tt>")',
                   2458:              'question.email.text' => '<b>'.&mt('Custom Text for Resource Content Question Option in Feedback').'</b>',
                   2459:              'comment.email'  => '<b>'.&mt('Feedback Addresses for Course Content Comments').'</b><br />'
                   2460:                                 .'("<tt>'.&mt('user:domain,user:domain(section;section;...;*;...),...').'</tt>")',
                   2461:              'comment.email.text' => '<b>'.&mt('Custom Text for Course Content Option in Feedback').'</b>',
                   2462:              'policy.email'   => '<b>'.&mt('Feedback Addresses for Course Policy').'</b><br />'
                   2463:                                  .'("<tt>'.&mt('user:domain,user:domain(section;section;...;*;...),...').'</tt>")',
                   2464:              'policy.email.text' => '<b>'.&mt('Custom Text for Course Policy Option in Feedback').'</b>',
                   2465:              'hideemptyrows'  => '<b>'.&mt('Hide Empty Rows in Spreadsheets').'</b><br />'
                   2466:                                 .'('.&mt('[_1] for default hiding','"<tt>yes</tt>"').')',
                   2467:              'pageseparators'  => '<b>'.&mt('Visibly Separate Items on Pages').'</b><br />'
                   2468:                                  .'('.&mt('[_1] for visible separation.','"<tt>yes</tt>"').' '
                   2469:                                  .&mt('Changes will not show until next login.').')',
                   2470:              'student_classlist_view' => '<b>'.&mt('Allow students to view classlist.').'</b><br />'
                   2471:                                         .'('.&mt('[_1]: students can view all sections. [_2]: students can only view their own section. blank or [_3] prevents student view.','"<tt>all</tt>"','"<tt>section</tt>"','"<tt>disabled</tt>"').')',
                   2472:              'student_classlist_portfiles' => '<b>'.&mt('Include link to accessible portfolio files').'</b><br />'
1.420     bisitz   2473:                                              .'('.&mt("[_1] for link to each a listing of each student's files.",'"<tt>yes</tt>"').')',
1.395     bisitz   2474:              'student_classlist_opt_in' => '<b>'.&mt("Student's agreement needed for listing in student-viewable roster").'</b><br />'
                   2475:                                            .'('.&mt('[_1] to require students to opt-in to listing in the roster (on the roster page).','"<tt>yes</tt>"').')',
                   2476:              'plc.roles.denied'=> '<b>'.&mt('Disallow live chatroom use for Roles').'</b><br />'
                   2477:                                  .'('.&mt('[_1]: student, [_2]: TA, [_3]: instructor','"<tt>st</tt>"','"<tt>ta</tt>"','"<tt>in</tt>"').')<br />'
                   2478:                                  .'("<tt>'.&mt('role,role,...').'</tt>") '
                   2479: 	                         .Apache::loncommon::help_open_topic("Course_Disable_Discussion"),
1.118     matthew  2480:              'plc.users.denied' => 
1.141     sakharuk 2481:                           '<b>'.&mt('Disallow live chatroom use for Users').'</b><br />'.
1.395     bisitz   2482:                                   '("<tt>'.&mt('user:domain,user:domain,...').'</tt>")',
1.118     matthew  2483: 
1.395     bisitz   2484:              'pch.roles.denied'=> '<b>'.&mt('Disallow Resource Discussion for Roles').'</b><br />'
                   2485:                                  .'('.&mt('[_1]: student, [_2]: TA, [_3]: instructor','"<tt>st</tt>"','"<tt>ta</tt>"','"<tt>in</tt>"')
                   2486:                                  .'("<tt>'.&mt('role,role,...').'</tt>") '
                   2487:                                  .Apache::loncommon::help_open_topic("Course_Disable_Discussion"),
1.53      www      2488:              'pch.users.denied' => 
1.141     sakharuk 2489:                           '<b>'.&mt('Disallow Resource Discussion for Users').'</b><br />'.
1.395     bisitz   2490:                                  '("<tt>'.&mt('user:domain,user:domain,...').'</tt>")',
1.49      matthew  2491:              'spreadsheet_default_classcalc' 
1.141     sakharuk 2492:                  => '<b>'.&mt('Default Course Spreadsheet').'</b> '.
1.50      matthew  2493:                     '<a href="javascript:openbrowser'.
                   2494:                     "('envform','spreadsheet_default_classcalc'".
1.141     sakharuk 2495:                     ",'spreadsheet')\">$SelectSpreadsheetFile</a><br />",
1.49      matthew  2496:              'spreadsheet_default_studentcalc' 
1.395     bisitz   2497:                  => '<b>'.&mt('Default Student Spreadsheet').'</b><br />'.
1.50      matthew  2498:                     '<a href="javascript:openbrowser'.
                   2499:                     "('envform','spreadsheet_default_calc'".
1.141     sakharuk 2500:                     ",'spreadsheet')\">$SelectSpreadsheetFile</a><br />",
1.49      matthew  2501:              'spreadsheet_default_assesscalc' 
1.141     sakharuk 2502:                  => '<b>'.&mt('Default Assessment Spreadsheet').'</b> '.
1.50      matthew  2503:                     '<a href="javascript:openbrowser'.
                   2504:                     "('envform','spreadsheet_default_assesscalc'".
1.141     sakharuk 2505:                     ",'spreadsheet')\">$SelectSpreadsheetFile</a><br />",
1.75      albertel 2506: 	     'allow_limited_html_in_feedback'
1.141     sakharuk 2507: 	         => '<b>'.&mt('Allow limited HTML in discussion posts').'</b><br />'.
1.395     bisitz   2508: 	            '('.&mt('Set value to [_1] to allow.','"<tt>yes</tt>"').')',
1.170     raeburn  2509:              'allow_discussion_post_editing'
1.395     bisitz   2510:                  => '<b>'.&mt('Allow users with specified roles to edit/delete their own discussion posts').'</b><br />'
                   2511:                    .'('.&mt('[_1]: student, [_2]: TA, [_3]: instructor','"<tt>st</tt>"','"<tt>ta</tt>"','"<tt>in</tt>"').')<br />'
                   2512:                    .'('.&mt('Set value to [_1] to allow all roles.','"<tt>yes</tt>"').')'
                   2513:                    .'("<tt>'.&mt('role:section,role:section,...').'</tt>")<br />'
                   2514:                    .'('.&mt('Example: "<tt>st:001,st:002,in,cc</tt>" would permit students in sections 001 and 002 and instructors in any section, and course coordinators to edit their own posts.').')',
1.89      albertel 2515: 	     'rndseed'
1.395     bisitz   2516: 	         => '<b>'.&mt('Randomization algorithm used').'</b><br />'
                   2517:                    .'<span class="LC_error">'
                   2518:                    .&mt('Modifying this will make problems have different numbers and answers!')
                   2519:                    .'</span>',
1.151     albertel 2520: 	     'receiptalg'
                   2521: 	         => '<b>'.&mt('Receipt algorithm used').'</b> <br />'.
                   2522:                     &mt('This controls how receipt numbers are generated.'),
1.164     sakharuk 2523:              'suppress_tries'
1.272     albertel 2524:                  => '<b>'.&mt('Suppress number of tries in printing').'</b><br />'.
1.395     bisitz   2525:                     ' ('.&mt('[_1] to suppress, anything else to not suppress','"<tt>yes</tt>"').')',
1.113     sakharuk 2526:              'problem_stream_switch'
1.141     sakharuk 2527:                  => '<b>'.&mt('Allow problems to be split over pages').'</b><br />'.
1.395     bisitz   2528:                     ' ('.&mt('[_1] if allowed, anything else if not','"<tt>yes</tt>"').')',
1.161     sakharuk 2529:              'default_paper_size' 
                   2530:                  => '<b>'.&mt('Default paper type').'</b><br />'.
                   2531:                     ' ('.&mt('supported types').': Letter [8 1/2x11 in], Legal [8 1/2x14 in],'. 
                   2532:                     ' Tabloid [11x17 in], Executive [7 1/2x10 in], A2 [420x594 mm],'. 
                   2533:                     ' A3 [297x420 mm], A4 [210x297 mm], A5 [148x210 mm], A6 [105x148 mm])',
1.319     foxr     2534: 	     'print_header_format'
1.395     bisitz   2535: 	         => ' <b>'.&mt('Print header format').'</b><br />'
                   2536:                    .&mt('Substitutions:<br />[_1]: student name, [_2]: course id, [_3]: assignment note. Numbers after the <tt>%</tt> limit the field size.','"<tt>%n</tt>"','"<tt>%c</tt>"','"<tt>%a</tt>"'),
1.217     albertel 2537:              'default_enrollment_start_date' => '<b>'.&mt('Default beginning date for student access.').'</b>',
                   2538:              'default_enrollment_end_date'   => '<b>'.&mt('Default ending date for student access.').'</b>',
1.395     bisitz   2539:              'nothideprivileged'   => '<b>'.&mt('Privileged users that should not be hidden on staff listings').'</b><br />'
                   2540:                                      .'("<tt>'.&mt('user:domain,user:domain,*:domain').'</tt>")',
1.140     sakharuk 2541:              'languages' => '<b>'.&mt('Languages used').'</b>',
1.115     www      2542:              'disable_receipt_display'
1.141     sakharuk 2543:                  => '<b>'.&mt('Disable display of problem receipts').'</b><br />'.
1.158     sakharuk 2544:                     ' ('.&mt('"[_1]" to disable, anything else if not','<tt>yes</tt>').')',
1.313     albertel 2545: 	     'task_messages'
1.395     bisitz   2546: 	         => '<b>'.&mt('Send message to student when clicking Done on Tasks').'</b><br /> ('.&mt('[_1] to send a message only to student, [_2] to send message to student and add record to user information page for instructors. Leave blank to disable.','"<tt>only_student</tt>"','"<tt>student_and_user_notes_screen</tt>"').')',
1.163     albertel 2547: 	     'disablesigfigs'
                   2548: 	         => '<b>'.&mt('Disable checking of Significant Figures').'</b><br />'.
                   2549:                     ' ('.&mt('"[_1]" to disable, anything else if not','<tt>yes</tt>').')',
1.251     albertel 2550: 	     'disableexampointprint'
                   2551: 	         => '<b>'.&mt('Disable automatically printing point values onto exams.').'</b><br />'.
                   2552:                     ' ('.&mt('"[_1]" to disable, anything else if not','<tt>yes</tt>').')',
1.278     www      2553:              'externalsyllabus'
1.279     www      2554:                  => '<b>'.&mt('URL of Syllabus (not using internal handler)').'</b>',
1.149     albertel 2555: 	     'tthoptions'
1.367     albertel 2556: 	         => '<b>'.&mt('Default set of options to pass to tth/m when converting tex').'</b>',
                   2557: 
                   2558: 	     'texengine'
1.395     bisitz   2559: 	         => '<b>'.&mt('Force all students in the course to use a specific math rendering engine.').'</b><br />'
1.420     bisitz   2560:                    .'('.&mt("[_1], [_2] (Convert to Images), [_3] (TeX to HTML), or blank for student's preference",'"<tt>jsMath</tt>"','"<tt>mimetex</tt>"','"<tt>tth</tt>"').')',
1.397     www      2561:              'timezone'
1.400     raeburn  2562:                  => '<b>'.&mt('Timezone in which the course takes place').'</b>',
1.392     raeburn  2563: 
1.400     raeburn  2564:              'suppress_embed_prompt'
                   2565:                  => '<b>'.&mt('Suppress prompt to upload items referenced in a web page being uploaded to portfolio, when current role is student.').'</b><br />'.
1.402     raeburn  2566:                     ' ('.&mt('[_1] to suppress, anything else to not suppress','"<tt>yes</tt>"').')',
1.403     raeburn  2567:              'hidefromcat'
1.402     raeburn  2568:                  => '<b>'.&mt('Exclude from course catalog').'</b><br />'.
                   2569:                     ' ('.&mt('[_1] to exclude, anything else to include - included if assigned an institutional code, or manually catagorized','"<tt>yes</tt>"').')',
1.403     raeburn  2570:              'categories'
                   2571:                  => '<b>'.&mt('Categorize course').'</b> <a href="javascript:catsbrowser()">'.
                   2572:                     &mt('Display Categories').'</a>',
1.409     raeburn  2573:              'datelocale' 
                   2574:                  => '<b>'.&mt('Locale used for course calendar').'</b>',
1.402     raeburn  2575:              );
                   2576:         my @Display_Order = ('url','description','courseid','cloners');
1.403     raeburn  2577:         (my $can_toggle_cat,$can_categorize) = &can_modify_catsettings($dom);
                   2578:         if ($can_toggle_cat) {
1.402     raeburn  2579:             push(@Display_Order,'hidefromcat');
                   2580:         }
1.403     raeburn  2581:         if ($can_categorize) {
                   2582:             push(@Display_Order,'categories');
                   2583:         }
1.402     raeburn  2584:         push (@Display_Order,('grading',
1.278     www      2585:                              'externalsyllabus',
1.107     matthew  2586:                              'default_xml_style','pageseparators',
1.402     raeburn  2587:                              'question.email','question.email.text','comment.email',
                   2588:                              'comment.email.text','policy.email','policy.email.text',
1.169     matthew  2589:                              'student_classlist_view',
1.372     raeburn  2590:                              'student_classlist_opt_in',
                   2591:                              'student_classlist_portfiles',
1.118     matthew  2592:                              'plc.roles.denied','plc.users.denied',
1.107     matthew  2593:                              'pch.roles.denied','pch.users.denied',
                   2594:                              'allow_limited_html_in_feedback',
1.170     raeburn  2595:                              'allow_discussion_post_editing',
1.108     www      2596:                              'languages',
1.397     www      2597:                              'timezone',
1.409     raeburn  2598:                              'datelocale',
1.150     www      2599: 			     'nothideprivileged',
1.107     matthew  2600:                              'rndseed',
1.151     albertel 2601:                              'receiptalg',
1.107     matthew  2602:                              'problem_stream_switch',
1.164     sakharuk 2603: 			     'suppress_tries',
1.400     raeburn  2604:                              'suppress_embed_prompt',
1.161     sakharuk 2605:                              'default_paper_size',
1.319     foxr     2606: 			     'print_header_format',
1.115     www      2607:                              'disable_receipt_display',
1.107     matthew  2608:                              'spreadsheet_default_classcalc',
                   2609:                              'spreadsheet_default_studentcalc',
                   2610:                              'spreadsheet_default_assesscalc', 
                   2611:                              'hideemptyrows',
                   2612:                              'default_enrollment_start_date',
                   2613:                              'default_enrollment_end_date',
1.163     albertel 2614: 			     'tthoptions',
1.367     albertel 2615: 			     'texengine',
1.251     albertel 2616: 			     'disablesigfigs',
1.313     albertel 2617: 			     'disableexampointprint',
1.402     raeburn  2618: 			     'task_messages','task_grading'));
1.107     matthew  2619: 	foreach my $parameter (sort(keys(%values))) {
1.405     raeburn  2620:             unless (($parameter =~ m/^internal\./)||($parameter =~ m/^metadata\./) ||
                   2621:                     ($parameter =~ m/^selfenroll_/) || ($parameter =~ /_selfenroll$/)
                   2622:                     || ($parameter eq 'type')) {
1.142     raeburn  2623:                 if (! $descriptions{$parameter}) {
                   2624:                     $descriptions{$parameter}=$parameter;
                   2625:                     push(@Display_Order,$parameter);
                   2626:                 }
                   2627:             }
1.43      albertel 2628: 	}
1.315     albertel 2629: 	
1.107     matthew  2630:         foreach my $parameter (@Display_Order) {
                   2631:             my $description = $descriptions{$parameter};
1.51      matthew  2632:             # onchange is javascript to automatically check the 'Set' button.
1.69      www      2633:             my $onchange = 'onFocus="javascript:window.document.forms'.
1.107     matthew  2634:                 "['envform'].elements['".$parameter."_setparmval']".
1.51      matthew  2635:                 '.checked=true;"';
1.315     albertel 2636:             $output .= &Apache::loncommon::start_data_table_row().
                   2637: 		'<td>'.$description.'</td>';
1.107     matthew  2638:             if ($parameter =~ /^default_enrollment_(start|end)_date$/) {
                   2639:                 $output .= '<td>'.
                   2640:                     &Apache::lonhtmlcommon::date_setter('envform',
                   2641:                                                         $parameter.'_value',
                   2642:                                                         $values{$parameter},
                   2643:                                                         $onchange).
                   2644:                                                         '</td>';
1.398     www      2645:             } elsif ($parameter eq 'timezone') {
1.399     raeburn  2646:                 my $includeempty = 1;
                   2647:                 my $timezone = &Apache::lonlocal::gettimezone();
1.398     www      2648:                 $output .= '<td>'.
                   2649:                     &Apache::loncommon::select_timezone($parameter.'_value',
1.399     raeburn  2650:                                                         $timezone,
                   2651:                                                         $onchange,$includeempty).'</td>';
1.409     raeburn  2652:             } elsif ($parameter eq 'datelocale') {
                   2653:                 my $includeempty = 1;
                   2654:                 my $locale_obj = &Apache::lonlocal::getdatelocale();
                   2655:                 my $currdatelocale;
                   2656:                 if (ref($locale_obj)) {
                   2657:                     $currdatelocale = $locale_obj->id();
                   2658:                 }
                   2659:                 $output .= '<td>'.
                   2660:                     &Apache::loncommon::select_datelocale($parameter.'_value',
                   2661:                                                           $currdatelocale,
                   2662:                                                           $onchange,$includeempty).'</td>'; 
1.406     raeburn  2663:             } elsif ($parameter eq 'categories') {
                   2664:                 my $catdisplay;
                   2665:                 if ($values{'categories'} ne '') {
                   2666:                     my @curritems = split(/\&/,$values{'categories'});
                   2667:                     foreach my $item (@curritems) {
                   2668:                         my ($name,$parent,$pos) = split(/:/,$item);
                   2669:                         $catdisplay .= &unescape($name).'&';
                   2670:                     }
                   2671:                     $catdisplay =~ s/\&$//;
                   2672:                 } 
                   2673:                 $output .= '<td>'.
                   2674:                            '<input type="hidden" name="categories_value" value="'.
                   2675:                            $values{'categories'}.'" />'.
                   2676:                            '<input type="textbox" name="categories_display" value="'.
                   2677:                            $catdisplay.'" readonly="readonly" size="40" /></td>';
1.107     matthew  2678:             } else {
                   2679:                 $output .= '<td>'.
                   2680:                     &Apache::lonhtmlcommon::textbox($parameter.'_value',
                   2681:                                                     $values{$parameter},
                   2682:                                                     40,$onchange).'</td>';
                   2683:             }
                   2684:             $output .= '<td>'.
                   2685:                 &Apache::lonhtmlcommon::checkbox($parameter.'_setparmval').
                   2686:                 '</td>';
1.315     albertel 2687:             $output .= &Apache::loncommon::end_data_table_row()."\n";
1.51      matthew  2688: 	}
1.69      www      2689:         my $onchange = 'onFocus="javascript:window.document.forms'.
1.51      matthew  2690:             '[\'envform\'].elements[\'newp_setparmval\']'.
                   2691:             '.checked=true;"';
1.315     albertel 2692: 	$output.=&Apache::loncommon::start_data_table_row().
                   2693: 	    '<td><i>'.&mt('Create New Environment Variable').'</i><br />'.
1.419     bisitz   2694: 	    '<input type="text" size="40" name="newp_name" '.
1.51      matthew  2695:                 $onchange.' /></td><td>'.
1.419     bisitz   2696:             '<input type="text" size="40" name="newp_value" '.
1.51      matthew  2697:                 $onchange.' /></td><td>'.
1.315     albertel 2698: 	    '<input type="checkbox" name="newp_setparmval" /></td>'.
                   2699: 	    &Apache::loncommon::end_data_table_row()."\n";
1.43      albertel 2700:     }
1.157     sakharuk 2701:     my %lt=&Apache::lonlocal::texthash(
                   2702: 		    'par'   => 'Parameter',
                   2703: 		    'val'   => 'Value',
1.395     bisitz   2704: 		    'set'   => 'Set?',
                   2705: 		    'sav'   => 'Save'
1.157     sakharuk 2706: 				       );
                   2707: 
1.140     sakharuk 2708:     my $Parameter=&mt('Parameter');
                   2709:     my $Value=&mt('Value');
1.141     sakharuk 2710:     my $Set=&mt('Set');
1.403     raeburn  2711:     my ($jscript,$categorize_js);
                   2712:     my $browse_js = &Apache::loncommon::browser_and_searcher_javascript('parmset');
                   2713:     if ($can_categorize) {
                   2714:         $categorize_js = <<ENDSCRIPT;
                   2715: function catsbrowser() {
                   2716:     var catswin = null;
                   2717:     var url = '/adm/parmset?action=categorizecourse';
                   2718:     if (!catswin || catswin.closed) {
                   2719:         catswin=window.open(url,'categorieswin','height=480,width=600,resizable=yes,scrollbars=yes,location=no,menubar=no,toolbar=no');
                   2720:     } else {
                   2721:         catswin.focus();
                   2722:     }
                   2723: } 
                   2724: ENDSCRIPT
                   2725:     }
                   2726:     $jscript = '<script type="text/javascript" language="Javascript">'."\n".
                   2727:                $browse_js."\n".$categorize_js."\n".'</script>';
1.280     albertel 2728:     my $start_page = 
1.323     albertel 2729: 	&Apache::loncommon::start_page('Set Course Environment',
1.403     raeburn  2730: 				       $jscript);
1.280     albertel 2731:     my $end_page = 
                   2732: 	&Apache::loncommon::end_page();
1.315     albertel 2733:     my $end_table=&Apache::loncommon::end_data_table();
1.280     albertel 2734:     $r->print(<<ENDENV);
                   2735: $start_page
1.193     albertel 2736: $breadcrumbs
                   2737: <form method="post" action="/adm/parmset?action=crsenv" name="envform">
1.30      www      2738: $setoutput
1.395     bisitz   2739: <div><input type="submit" name="crsenv" value="$lt{'sav'}" /></div>
1.315     albertel 2740: $start_table
                   2741: $start_header_row
1.395     bisitz   2742: <th>$lt{'par'}</th><th>$lt{'val'}</th><th>$lt{'set'}</th>
1.315     albertel 2743: $end_header_row
1.30      www      2744: $output
1.315     albertel 2745: $end_table
1.395     bisitz   2746: <input type="submit" name="crsenv" value="$lt{'sav'}" />
1.30      www      2747: </form>
1.280     albertel 2748: $end_page
                   2749: ENDENV
1.30      www      2750: }
1.402     raeburn  2751: 
1.403     raeburn  2752: sub can_modify_catsettings {
1.402     raeburn  2753:     my ($dom) = @_;
                   2754:     my %domconf = &Apache::lonnet::get_dom('configuration',['coursecategories'],$dom);
1.403     raeburn  2755:     my ($can_toggle_cat,$can_categorize);
1.402     raeburn  2756:     if (ref($domconf{'coursecategories'}) eq 'HASH') {
                   2757:         if ($domconf{'coursecategories'}{'togglecats'} eq 'crs') {
                   2758:             $can_toggle_cat = 1;
                   2759:         }
1.403     raeburn  2760:         if ($domconf{'coursecategories'}{'categorize'} eq 'crs') {
                   2761:             $can_categorize = 1;
                   2762:         }
                   2763:     }
                   2764:     return ($can_toggle_cat,$can_categorize);
                   2765: }
                   2766: 
                   2767: sub assign_course_categories {
                   2768:     my ($r) = @_;
                   2769:     my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                   2770:     my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
                   2771:     my $hascats = 0;
                   2772:     my $cathash;
                   2773:     my %domconf = &Apache::lonnet::get_dom('configuration',['coursecategories'],$cdom);
                   2774:     if (ref($domconf{'coursecategories'}) eq 'HASH') {
                   2775:         $cathash = $domconf{'coursecategories'}{'cats'};
                   2776:         if (ref($cathash) eq 'HASH') {
                   2777:             $hascats = 1;   
                   2778:         }
1.402     raeburn  2779:     }
1.403     raeburn  2780:     my $catwin_js;
                   2781:     if ($hascats) {
                   2782:         my $alert = &mt('Use \"Save\" in the main window to save course categories');
                   2783:         $catwin_js = <<ENDSCRIPT;
                   2784: <script type="text/javascript">
                   2785: 
                   2786: function updateCategories() {
                   2787:     var newcategories = '';
1.406     raeburn  2788:     var unescapedcats = '';
1.403     raeburn  2789:     if (document.chgcats.usecategory.length) {
                   2790:         for (var i=0; i<document.chgcats.usecategory.length; i++) {
                   2791:             if (document.chgcats.usecategory[i].checked == true) {
                   2792:                 newcategories = newcategories + document.chgcats.usecategory[i].value + '&';
1.406     raeburn  2793:                 unescapedcats = unescapedcats + document.chgcats.catname[i].value + ' & ';
1.403     raeburn  2794:             }
                   2795:         }
                   2796:         if (newcategories.length > 0) {
                   2797:             newcategories = newcategories.slice(0,-1);
                   2798:         }
1.406     raeburn  2799:         if (unescapedcats.length > 0) {
1.408     raeburn  2800:             unescapedcats = unescapedcats.slice(0,-3);
1.406     raeburn  2801:         }
1.403     raeburn  2802:     } else {
                   2803:          if (document.chgcats.usecategory.checked == true) {
                   2804:              newcategories = document.chgcats.usecategory.value;
1.406     raeburn  2805:              unescapedcats = document.chgcats.catname.value;
1.403     raeburn  2806:          }
                   2807:     }
                   2808:     opener.document.envform.categories_value.value = newcategories;
1.406     raeburn  2809:     opener.document.envform.categories_display.value = unescapedcats;
1.403     raeburn  2810:     opener.document.envform.categories_setparmval.checked = true;
                   2811:     alert("$alert");
                   2812:     self.close();
                   2813:     return;
                   2814: }
                   2815: 
                   2816: </script>
                   2817: ENDSCRIPT
                   2818:     } else {
                   2819:         my $onload; 
                   2820:     }
                   2821:     my $start_page =
                   2822:         &Apache::loncommon::start_page('Course Categories',$catwin_js,
                   2823:                                        {'only_body'      => 1,});
                   2824:     my $end_page = &Apache::loncommon::end_page();
                   2825:     my $categoriesform = '<h3>'.&mt('Categorize Course').'</h3>';
                   2826:     if ($hascats) {
                   2827:         my %currsettings =
                   2828:             &Apache::lonnet::get('environment',['hidefromcat','categories'],$cdom,$cnum);
                   2829:         $categoriesform .= &mt('Assign one or more categories to this course.').'<br /><br />'.
                   2830:                                '<form name="chgcats" action="/adm/parmset" method="post">'."\n"
                   2831:                                .&Apache::loncommon::assign_categories_table($cathash,
                   2832:                                                        $currsettings{'categories'})."\n"
                   2833:                                .'<br /><input type="button" name="changes" value="'
                   2834:                                .&mt('Copy to main window').'" '
                   2835:                                .'onclick="javascript:updateCategories()" /></form><br />';
                   2836:     } else {
                   2837:         $categoriesform .= &mt('No categories defined for this domain');
                   2838:     }
                   2839:     $r->print($start_page.$categoriesform.$end_page);
                   2840:     return;
1.402     raeburn  2841: }
                   2842: 
1.120     www      2843: ##################################################
1.207     www      2844: # Overview mode
                   2845: ##################################################
1.124     www      2846: my $tableopen;
                   2847: 
                   2848: sub tablestart {
                   2849:     if ($tableopen) {
                   2850: 	return '';
                   2851:     } else {
                   2852: 	$tableopen=1;
1.295     albertel 2853: 	return &Apache::loncommon::start_data_table().'<tr><th>'.&mt('Parameter').'</th><th>'.
1.130     www      2854: 	    &mt('Delete').'</th><th>'.&mt('Set to ...').'</th></tr>';
1.124     www      2855:     }
                   2856: }
                   2857: 
                   2858: sub tableend {
                   2859:     if ($tableopen) {
                   2860: 	$tableopen=0;
1.295     albertel 2861: 	return &Apache::loncommon::end_data_table();
1.124     www      2862:     } else {
                   2863: 	return'';
                   2864:     }
                   2865: }
                   2866: 
1.207     www      2867: sub readdata {
                   2868:     my ($crs,$dom)=@_;
                   2869: # Read coursedata
                   2870:     my $resourcedata=&Apache::lonnet::get_courseresdata($crs,$dom);
                   2871: # Read userdata
                   2872: 
                   2873:     my $classlist=&Apache::loncoursedata::get_classlist();
                   2874:     foreach (keys %$classlist) {
1.350     albertel 2875:         if ($_=~/^($match_username)\:($match_domain)$/) {
1.207     www      2876: 	    my ($tuname,$tudom)=($1,$2);
                   2877: 	    my $useropt=&Apache::lonnet::get_userresdata($tuname,$tudom);
                   2878:             foreach my $userkey (keys %{$useropt}) {
                   2879: 		if ($userkey=~/^$env{'request.course.id'}/) {
                   2880:                     my $newkey=$userkey;
                   2881: 		    $newkey=~s/^($env{'request.course.id'}\.)/$1\[useropt\:$tuname\:$tudom\]\./;
                   2882: 		    $$resourcedata{$newkey}=$$useropt{$userkey};
                   2883: 		}
                   2884: 	    }
                   2885: 	}
                   2886:     }
                   2887:     return $resourcedata;
                   2888: }
                   2889: 
                   2890: 
1.124     www      2891: # Setting
1.208     www      2892: 
                   2893: sub storedata {
                   2894:     my ($r,$crs,$dom)=@_;
1.207     www      2895: # Set userlevel immediately
                   2896: # Do an intermediate store of course level
                   2897:     my $olddata=&readdata($crs,$dom);
1.124     www      2898:     my %newdata=();
                   2899:     undef %newdata;
                   2900:     my @deldata=();
                   2901:     undef @deldata;
1.190     albertel 2902:     foreach (keys %env) {
1.124     www      2903: 	if ($_=~/^form\.([a-z]+)\_(.+)$/) {
                   2904: 	    my $cmd=$1;
                   2905: 	    my $thiskey=$2;
1.207     www      2906: 	    my ($tuname,$tudom)=&extractuser($thiskey);
                   2907: 	    my $tkey=$thiskey;
                   2908:             if ($tuname) {
                   2909: 		$tkey=~s/\.\[useropt\:$tuname\:$tudom\]\./\./;
                   2910: 	    }
1.385     albertel 2911: 	    if ($cmd eq 'set' || $cmd eq 'datepointer' || $cmd eq 'dateinterval') {
1.384     albertel 2912: 		my ($data, $typeof, $text);
                   2913: 		if ($cmd eq 'set') {
                   2914: 		    $data=$env{$_};
                   2915: 		    $typeof=$env{'form.typeof_'.$thiskey};
                   2916: 		    $text = &mt('Saved modified parameter for');
                   2917: 		} elsif ($cmd eq 'datepointer') {
                   2918: 		    $data=&Apache::lonhtmlcommon::get_date_from_form($env{$_});
                   2919: 		    $typeof=$env{'form.typeof_'.$thiskey};
                   2920: 		    $text = &mt('Saved modified date for');
1.385     albertel 2921: 		} elsif ($cmd eq 'dateinterval') {
                   2922: 		    $data=&get_date_interval_from_form($thiskey);
                   2923: 		    $typeof=$env{'form.typeof_'.$thiskey};
                   2924: 		    $text = &mt('Saved modified date for');
1.384     albertel 2925: 		}
                   2926: 		if (defined($data) and $$olddata{$thiskey} ne $data) { 
1.207     www      2927: 		    if ($tuname) {
1.212     www      2928: 			if (&Apache::lonnet::put('resourcedata',{$tkey=>$data,
                   2929: 								 $tkey.'.type' => $typeof},
                   2930: 						 $tudom,$tuname) eq 'ok') {
1.290     www      2931: 			    &log_parmset({$tkey=>$data,$tkey.'.type' => $typeof},0,$tuname,$tudom);
1.384     albertel 2932: 			    $r->print('<br />'.$text.' '.
1.207     www      2933: 				      &Apache::loncommon::plainname($tuname,$tudom));
                   2934: 			} else {
1.314     albertel 2935: 			    $r->print('<div class="LC_error">'.
1.365     albertel 2936: 				      &mt('Error saving parameters').'</div>');
1.207     www      2937: 			}
                   2938: 			&Apache::lonnet::devalidateuserresdata($tuname,$tudom);
                   2939: 		    } else {
                   2940: 			$newdata{$thiskey}=$data;
1.212     www      2941:  			$newdata{$thiskey.'.type'}=$typeof; 
                   2942:                    } 
1.207     www      2943: 		}
1.124     www      2944: 	    } elsif ($cmd eq 'del') {
1.207     www      2945: 		if ($tuname) {
                   2946: 		    if (&Apache::lonnet::del('resourcedata',[$tkey],$tudom,$tuname) eq 'ok') {
1.290     www      2947: 			    &log_parmset({$tkey=>''},1,$tuname,$tudom);
1.207     www      2948: 			$r->print('<br />'.&mt('Deleted parameter for').' '.&Apache::loncommon::plainname($tuname,$tudom));
                   2949: 		    } else {
1.314     albertel 2950: 			$r->print('<div class="LC_error">'.
                   2951: 				  &mt('Error deleting parameters').'</div>');
1.207     www      2952: 		    }
                   2953: 		    &Apache::lonnet::devalidateuserresdata($tuname,$tudom);
                   2954: 		} else {
1.333     albertel 2955: 		    push (@deldata,$thiskey,$thiskey.'.type');
1.207     www      2956: 		}
1.124     www      2957: 	    }
                   2958: 	}
                   2959:     }
1.207     www      2960: # Store all course level
1.144     www      2961:     my $delentries=$#deldata+1;
                   2962:     my @newdatakeys=keys %newdata;
                   2963:     my $putentries=$#newdatakeys+1;
                   2964:     if ($delentries) {
                   2965: 	if (&Apache::lonnet::del('resourcedata',\@deldata,$dom,$crs) eq 'ok') {
1.290     www      2966: 	    my %loghash=map { $_ => '' } @deldata;
                   2967: 	    &log_parmset(\%loghash,1);
1.144     www      2968: 	    $r->print('<h2>'.&mt('Deleted [_1] parameter(s)</h2>',$delentries));
                   2969: 	} else {
1.314     albertel 2970: 	    $r->print('<div class="LC_error">'.
                   2971: 		      &mt('Error deleting parameters').'</div>');
1.144     www      2972: 	}
1.205     www      2973: 	&Apache::lonnet::devalidatecourseresdata($crs,$dom);
1.144     www      2974:     }
                   2975:     if ($putentries) {
                   2976: 	if (&Apache::lonnet::put('resourcedata',\%newdata,$dom,$crs) eq 'ok') {
1.290     www      2977: 			    &log_parmset(\%newdata,0);
1.365     albertel 2978: 	    $r->print('<h3>'.&mt('Saved [_1] parameter(s)',$putentries/2).'</h3>');
1.144     www      2979: 	} else {
1.314     albertel 2980: 	    $r->print('<div class="LC_error">'.
1.365     albertel 2981: 		      &mt('Error saving parameters').'</div>');
1.144     www      2982: 	}
1.205     www      2983: 	&Apache::lonnet::devalidatecourseresdata($crs,$dom);
1.144     www      2984:     }
1.208     www      2985: }
1.207     www      2986: 
1.208     www      2987: sub extractuser {
                   2988:     my $key=shift;
1.350     albertel 2989:     return ($key=~/^$env{'request.course.id'}.\[useropt\:($match_username)\:($match_domain)\]\./);
1.208     www      2990: }
1.206     www      2991: 
1.381     albertel 2992: sub parse_listdata_key {
                   2993:     my ($key,$listdata) = @_;
                   2994:     # split into student/section affected, and
                   2995:     # the realm (folder/resource part and parameter
                   2996:     my ($student,$realm) = 
                   2997: 	($key=~/^\Q$env{'request.course.id'}\E\.\[([^\.]+)\]\.(.+)$/);
                   2998:     # if course wide student would be undefined
                   2999:     if (!defined($student)) {
                   3000: 	($realm)=($key=~/^\Q$env{'request.course.id'}\E\.(.+)$/);
                   3001:     }
                   3002:     # strip off the .type if it's not the Question type parameter
                   3003:     if ($realm=~/\.type$/ && !exists($listdata->{$key.'.type'})) {
                   3004: 	$realm=~s/\.type//;
                   3005:     }
                   3006:     # split into resource+part and parameter name
1.388     albertel 3007:     my ($res,    $parm) = ($realm=~/^(.*)\.(.*)$/);
                   3008:        ($res, my $part) = ($res  =~/^(.*)\.(.*)$/);
1.381     albertel 3009:     return ($student,$res,$part,$parm);
                   3010: }
                   3011: 
1.208     www      3012: sub listdata {
1.214     www      3013:     my ($r,$resourcedata,$listdata,$sortorder)=@_;
1.207     www      3014: # Start list output
1.206     www      3015: 
1.122     www      3016:     my $oldsection='';
                   3017:     my $oldrealm='';
                   3018:     my $oldpart='';
1.123     www      3019:     my $pointer=0;
1.124     www      3020:     $tableopen=0;
1.145     www      3021:     my $foundkeys=0;
1.248     albertel 3022:     my %keyorder=&standardkeyorder();
1.381     albertel 3023: 
1.214     www      3024:     foreach my $thiskey (sort {
1.381     albertel 3025: 	my ($astudent,$ares,$apart,$aparm) = &parse_listdata_key($a,$listdata);
                   3026: 	my ($bstudent,$bres,$bpart,$bparm) = &parse_listdata_key($b,$listdata);
                   3027: 
                   3028: 	# get the numerical order for the param
                   3029: 	$aparm=$keyorder{'parameter_0_'.$aparm};
                   3030: 	$bparm=$keyorder{'parameter_0_'.$bparm};
                   3031: 
                   3032: 	my $result=0;
                   3033: 
1.214     www      3034: 	if ($sortorder eq 'realmstudent') {
1.381     albertel 3035:             if ($ares     ne $bres    ) {
                   3036: 		$result = ($ares     cmp $bres);
                   3037:             } elsif ($astudent ne $bstudent) { 
                   3038: 		$result = ($astudent cmp $bstudent);
                   3039: 	    } elsif ($apart    ne $bpart   ) {
                   3040: 		$result = ($apart    cmp $bpart);
1.237     albertel 3041: 	    }
1.381     albertel 3042: 	} else {
                   3043: 	    if      ($astudent ne $bstudent) { 
                   3044: 		$result = ($astudent cmp $bstudent);
                   3045: 	    } elsif ($ares     ne $bres    ) {
                   3046: 		$result = ($ares     cmp $bres);
                   3047: 	    } elsif ($apart    ne $bpart   ) {
                   3048: 		$result = ($apart    cmp $bpart);
1.247     albertel 3049: 	    }
1.381     albertel 3050: 	}
                   3051: 	    
                   3052: 	if (!$result) {
                   3053:             if (defined($aparm) && defined($bparm)) {
                   3054: 		$result = ($aparm <=> $bparm);
                   3055:             } elsif (defined($aparm)) {
                   3056: 		$result = -1;
                   3057:             } elsif (defined($bparm)) {
                   3058: 		$result = 1;
1.248     albertel 3059: 	    }
1.214     www      3060: 	}
1.381     albertel 3061: 
                   3062: 	$result;
1.214     www      3063:     } keys %{$listdata}) {
1.381     albertel 3064: 
1.211     www      3065: 	if ($$listdata{$thiskey.'.type'}) {
                   3066:             my $thistype=$$listdata{$thiskey.'.type'};
                   3067:             if ($$resourcedata{$thiskey.'.type'}) {
                   3068: 		$thistype=$$resourcedata{$thiskey.'.type'};
                   3069: 	    }
1.207     www      3070: 	    my ($middle,$part,$name)=
                   3071: 		($thiskey=~/^$env{'request.course.id'}\.(?:(.+)\.)*([\w\s]+)\.(\w+)$/);
1.130     www      3072: 	    my $section=&mt('All Students');
1.207     www      3073: 	    if ($middle=~/^\[(.*)\]/) {
1.206     www      3074: 		my $issection=$1;
1.350     albertel 3075: 		if ($issection=~/^useropt\:($match_username)\:($match_domain)/) {
1.206     www      3076: 		    $section=&mt('User').": ".&Apache::loncommon::plainname($1,$2);
                   3077: 		} else {
                   3078: 		    $section=&mt('Group/Section').': '.$issection;
                   3079: 		}
1.207     www      3080: 		$middle=~s/^\[(.*)\]//;
1.122     www      3081: 	    }
1.207     www      3082: 	    $middle=~s/\.+$//;
                   3083: 	    $middle=~s/^\.+//;
1.316     albertel 3084: 	    my $realm='<span class="LC_parm_scope_all">'.&mt('All Resources').'</span>';
1.122     www      3085: 	    if ($middle=~/^(.+)\_\_\_\(all\)$/) {
1.316     albertel 3086: 		$realm='<span class="LC_parm_scope_folder">'.&mt('Folder/Map').': '.&Apache::lonnet::gettitle($1).' <br /><span class="LC_parm_folder">('.$1.')</span></span>';
1.122     www      3087: 	    } elsif ($middle) {
1.174     albertel 3088: 		my ($map,$id,$url)=&Apache::lonnet::decode_symb($middle);
1.316     albertel 3089: 		$realm='<span class="LC_parm_scope_resource">'.&mt('Resource').': '.&Apache::lonnet::gettitle($middle).' <br /><span class="LC_parm_symb">('.$url.' in '.$map.' id: '.$id.')</span></span>';
1.122     www      3090: 	    }
1.214     www      3091: 	    if ($sortorder eq 'realmstudent') {
                   3092: 		if ($realm ne $oldrealm) {
                   3093: 		    $r->print(&tableend()."\n<hr /><h1>$realm</h1>");
                   3094: 		    $oldrealm=$realm;
                   3095: 		    $oldsection='';
                   3096: 		}
                   3097: 		if ($section ne $oldsection) {
                   3098: 		    $r->print(&tableend()."\n<h2>$section</h2>");
                   3099: 		    $oldsection=$section;
                   3100: 		    $oldpart='';
                   3101: 		}
                   3102: 	    } else {
                   3103: 		if ($section ne $oldsection) {
                   3104: 		    $r->print(&tableend()."\n<hr /><h1>$section</h1>");
                   3105: 		    $oldsection=$section;
                   3106: 		    $oldrealm='';
                   3107: 		}
                   3108: 		if ($realm ne $oldrealm) {
                   3109: 		    $r->print(&tableend()."\n<h2>$realm</h2>");
                   3110: 		    $oldrealm=$realm;
                   3111: 		    $oldpart='';
                   3112: 		}
1.122     www      3113: 	    }
                   3114: 	    if ($part ne $oldpart) {
1.124     www      3115: 		$r->print(&tableend().
1.422     bisitz   3116: 			  "\n".'<span class="LC_parm_part">'.&mt('Part').": $part</span>");
1.122     www      3117: 		$oldpart=$part;
                   3118: 	    }
1.123     www      3119: #
                   3120: # Ready to print
                   3121: #
1.295     albertel 3122: 	    $r->print(&tablestart().
                   3123: 		      &Apache::loncommon::start_data_table_row().
                   3124: 		      '<td><b>'.&standard_parameter_names($name).
1.293     www      3125: 		      '</b></td><td><input type="checkbox" name="del_'.
1.124     www      3126: 		      $thiskey.'" /></td><td>');
1.145     www      3127: 	    $foundkeys++;
1.213     www      3128: 	    if (&isdateparm($thistype)) {
1.123     www      3129: 		my $jskey='key_'.$pointer;
                   3130: 		$pointer++;
                   3131: 		$r->print(
1.232     albertel 3132: 			  &Apache::lonhtmlcommon::date_setter('parmform',
1.123     www      3133: 							      $jskey,
1.219     www      3134: 						      $$resourcedata{$thiskey},
1.325     www      3135: 							      '',1,'','').
1.277     www      3136: '<input type="hidden" name="datepointer_'.$thiskey.'" value="'.$jskey.'" />'.
1.413     bisitz   3137: (($$resourcedata{$thiskey}!=0)?'<span class="LC_nobreak"><a href="/adm/parmset?&action=dateshift1&timebase='.$$resourcedata{$thiskey}.'">'.
                   3138: &mt('Shift all dates based on this date').'</a></span>':'').
1.277     www      3139: &date_sanity_info($$resourcedata{$thiskey})
1.123     www      3140: 			  );
1.385     albertel 3141: 	    } elsif ($thistype eq 'date_interval') {
                   3142: 		$r->print(&date_interval_selector($thiskey,
                   3143: 						  $$resourcedata{$thiskey}));
1.383     albertel 3144: 	    } elsif ($thistype =~ m/^string/) {
                   3145: 		$r->print(&string_selector($thistype,$thiskey,
                   3146: 					   $$resourcedata{$thiskey}));
1.123     www      3147: 	    } else {
1.383     albertel 3148: 		$r->print(&default_selector($thiskey,$$resourcedata{$thiskey}));
1.123     www      3149: 	    }
1.211     www      3150: 	    $r->print('<input type="hidden" name="typeof_'.$thiskey.'" value="'.
1.423     bisitz   3151: 		      $thistype.'" />');
1.295     albertel 3152: 	    $r->print('</td>'.&Apache::loncommon::end_data_table_row());
1.122     www      3153: 	}
1.121     www      3154:     }
1.208     www      3155:     return $foundkeys;
                   3156: }
                   3157: 
1.385     albertel 3158: 
                   3159: sub date_interval_selector {
                   3160:     my ($thiskey, $showval) = @_;
                   3161:     my $result;
                   3162:     foreach my $which (['days', 86400, 31],
                   3163: 		       ['hours', 3600, 23],
                   3164: 		       ['minutes', 60, 59],
                   3165: 		       ['seconds',  1, 59]) {
                   3166: 	my ($name, $factor, $max) = @{ $which };
                   3167: 	my $amount = int($showval/$factor);
                   3168: 	$showval  %= $factor;
                   3169: 	my %select = ((map {$_ => $_} (0..$max)),
                   3170: 		      'select_form_order' => [0..$max]);
                   3171: 	$result .= &Apache::loncommon::select_form($amount,$name.'_'.$thiskey,
                   3172: 						   %select);
                   3173: 	$result .= ' '.&mt($name);
                   3174:     }
                   3175:     $result .= '<input type="hidden" name="dateinterval_'.$thiskey.'" />';
                   3176:     return $result;
                   3177: 
                   3178: }
                   3179: 
                   3180: sub get_date_interval_from_form {
                   3181:     my ($key) = @_;
                   3182:     my $seconds = 0;
                   3183:     foreach my $which (['days', 86400],
                   3184: 		       ['hours', 3600],
                   3185: 		       ['minutes', 60],
                   3186: 		       ['seconds',  1]) {
                   3187: 	my ($name, $factor) = @{ $which };
                   3188: 	if (defined($env{'form.'.$name.'_'.$key})) {
                   3189: 	    $seconds += $env{'form.'.$name.'_'.$key} * $factor;
                   3190: 	}
                   3191:     }
                   3192:     return $seconds;
                   3193: }
                   3194: 
                   3195: 
1.383     albertel 3196: sub default_selector {
                   3197:     my ($thiskey, $showval) = @_;
1.385     albertel 3198:     return '<input type="text" name="set_'.$thiskey.'" value="'.$showval.'" />';
1.383     albertel 3199: }
                   3200: 
                   3201: my %strings = 
                   3202:     (
                   3203:      'string_yesno'
                   3204:              => [[ 'yes', 'Yes' ],
                   3205: 		 [ 'no', 'No' ]],
                   3206:      'string_problemstatus'
                   3207:              => [[ 'yes', 'Yes' ],
1.394     www      3208: 		 [ 'answer', 'Yes, and show correct answer if they exceed the maximum number of tries.' ],
1.383     albertel 3209: 		 [ 'no', 'No, don\'t show correct/incorrect feedback.' ],
                   3210: 		 [ 'no_feedback_ever', 'No, show no feedback at all.' ]],
                   3211:      );
                   3212: 
                   3213: 
                   3214: sub string_selector {
                   3215:     my ($thistype, $thiskey, $showval) = @_;
                   3216:     
                   3217:     if (!exists($strings{$thistype})) {
                   3218: 	return &default_selector($thiskey,$showval);
                   3219:     }
                   3220: 
                   3221:     my $result;
                   3222:     foreach my $possibilities (@{ $strings{$thistype} }) {
                   3223: 	my ($name, $description) = @{ $possibilities };
                   3224: 	$result .= '<label><input type="radio" name="set_'.$thiskey.
                   3225: 		  '" value="'.$name.'"';
                   3226: 	if ($showval eq $name) {
                   3227: 	    $result .= ' checked="checked"';
                   3228: 	}
                   3229: 	$result .= ' />'.&mt($description).'</label> ';
                   3230:     }
                   3231:     return $result;
                   3232: }
                   3233: 
1.389     www      3234: #
                   3235: # Shift all start and end dates by $shift
                   3236: #
                   3237: 
                   3238: sub dateshift {
                   3239:     my ($shift)=@_;
                   3240:     my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                   3241:     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
                   3242:     my %data=&Apache::lonnet::dump('resourcedata',$dom,$crs);
                   3243: # ugly retro fix for broken version of types
                   3244:     foreach my $key (keys %data) {
                   3245:         if ($key=~/\wtype$/) {
                   3246:             my $newkey=$key;
                   3247:             $newkey=~s/type$/\.type/;
                   3248:             $data{$newkey}=$data{$key};
                   3249:             delete $data{$key};
                   3250:         }
                   3251:     }
1.391     www      3252:     my %storecontent=();
1.389     www      3253: # go through all parameters and look for dates
                   3254:     foreach my $key (keys %data) {
                   3255:        if ($data{$key.'.type'}=~/^date_(start|end)$/) {
                   3256:           my $newdate=$data{$key}+$shift;
1.391     www      3257:           $storecontent{$key}=$newdate;
1.389     www      3258:        }
                   3259:     }
1.391     www      3260:     my $reply=&Apache::lonnet::cput
                   3261:                 ('resourcedata',\%storecontent,$dom,$crs);
                   3262:     if ($reply eq 'ok') {
                   3263:        &log_parmset(\%storecontent);
                   3264:     }
                   3265:     &Apache::lonnet::devalidatecourseresdata($crs,$dom);
                   3266:     return $reply;
1.389     www      3267: }
                   3268: 
1.208     www      3269: sub newoverview {
1.280     albertel 3270:     my ($r) = @_;
                   3271: 
1.208     www      3272:     my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                   3273:     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
1.414     droeschl 3274:     &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=setoverview',
                   3275:     	text=>"Overview Mode"});
1.280     albertel 3276:     my $start_page = &Apache::loncommon::start_page('Set Parameters');
1.298     albertel 3277:     my $breadcrumbs = &Apache::lonhtmlcommon::breadcrumbs('Overview');
1.208     www      3278:     $r->print(<<ENDOVER);
1.280     albertel 3279: $start_page
1.208     www      3280: $breadcrumbs
1.232     albertel 3281: <form method="post" action="/adm/parmset?action=newoverview" name="parmform">
1.208     www      3282: ENDOVER
1.211     www      3283:     my @ids=();
                   3284:     my %typep=();
                   3285:     my %keyp=();
                   3286:     my %allparms=();
                   3287:     my %allparts=();
                   3288:     my %allmaps=();
                   3289:     my %mapp=();
                   3290:     my %symbp=();
                   3291:     my %maptitles=();
                   3292:     my %uris=();
                   3293:     my %keyorder=&standardkeyorder();
                   3294:     my %defkeytype=();
                   3295: 
                   3296:     my %alllevs=();
                   3297:     $alllevs{'Resource Level'}='full';
1.215     www      3298:     $alllevs{'Map/Folder Level'}='map';
1.211     www      3299:     $alllevs{'Course Level'}='general';
                   3300: 
                   3301:     my $csec=$env{'form.csec'};
1.269     raeburn  3302:     my $cgroup=$env{'form.cgroup'};
1.211     www      3303: 
                   3304:     my @pscat=&Apache::loncommon::get_env_multiple('form.pscat');
                   3305:     my $pschp=$env{'form.pschp'};
                   3306:     my @psprt=&Apache::loncommon::get_env_multiple('form.psprt');
                   3307:     if (!@psprt) { $psprt[0]='0'; }
                   3308: 
                   3309:     my @selected_sections = 
                   3310: 	&Apache::loncommon::get_env_multiple('form.Section');
                   3311:     @selected_sections = ('all') if (! @selected_sections);
1.374     albertel 3312:     foreach my $sec (@selected_sections) {
                   3313:         if ($sec eq 'all') {
1.211     www      3314:             @selected_sections = ('all');
                   3315:         }
                   3316:     }
1.269     raeburn  3317:     my @selected_groups =
                   3318:         &Apache::loncommon::get_env_multiple('form.Group');
1.211     www      3319: 
                   3320:     my $pssymb='';
                   3321:     my $parmlev='';
                   3322:  
                   3323:     unless ($env{'form.parmlev'}) {
                   3324:         $parmlev = 'map';
                   3325:     } else {
                   3326:         $parmlev = $env{'form.parmlev'};
                   3327:     }
                   3328: 
                   3329:     &extractResourceInformation(\@ids, \%typep,\%keyp, \%allparms, \%allparts, \%allmaps, 
                   3330: 				\%mapp, \%symbp,\%maptitles,\%uris,
                   3331: 				\%keyorder,\%defkeytype);
                   3332: 
1.374     albertel 3333:     if (grep {$_ eq 'all'} (@psprt)) {
                   3334: 	@psprt = keys(%allparts);
                   3335:     }
1.211     www      3336: # Menu to select levels, etc
                   3337: 
1.317     albertel 3338:     $r->print('<table id="LC_parm_overview_scope">
                   3339:                <tr><td class="LC_parm_overview_level_menu">');
1.211     www      3340:     &levelmenu($r,\%alllevs,$parmlev);
                   3341:     if ($parmlev ne 'general') {
1.317     albertel 3342: 	$r->print('<td class="LC_parm_overview_map_menu">');
1.211     www      3343: 	&mapmenu($r,\%allmaps,$pschp,\%maptitles);
                   3344: 	$r->print('</td>');
                   3345:     }
                   3346:     $r->print('</td></tr></table>');
                   3347: 
1.317     albertel 3348:     $r->print('<table id="LC_parm_overview_controls">
                   3349:                <tr><td class="LC_parm_overview_parm_selectors">');  
1.211     www      3350:     &parmmenu($r,\%allparms,\@pscat,\%keyorder);
1.317     albertel 3351:     $r->print('</td><td class="LC_parm_overview_restrictions">
                   3352:                 <table class="LC_parm_overview_restrictions">'.
                   3353:               '<tr><th>'.&mt('Parts').'</th><th>'.&mt('Section(s)').
                   3354:               '</th><th>'.&mt('Group(s)').'</th></tr><tr><td>');
1.211     www      3355:     &partmenu($r,\%allparts,\@psprt);
1.317     albertel 3356:     $r->print('</td><td>');
1.211     www      3357:     &sectionmenu($r,\@selected_sections);
1.317     albertel 3358:     $r->print('</td><td>');
1.269     raeburn  3359:     &groupmenu($r,\@selected_groups);
                   3360:     $r->print('</td></tr></table>');
1.214     www      3361:     $r->print('</td></tr></table>');
                   3362:  
                   3363:     my $sortorder=$env{'form.sortorder'};
                   3364:     unless ($sortorder) { $sortorder='realmstudent'; }
                   3365:     &sortmenu($r,$sortorder);
                   3366: 
                   3367:     $r->print('<p><input type="submit" name="dis" value="'.&mt('Display').'" /></p>');
1.211     www      3368: 
                   3369: # Build the list data hash from the specified parms
                   3370: 
                   3371:     my $listdata;
                   3372:     %{$listdata}=();
                   3373: 
                   3374:     foreach my $cat (@pscat) {
1.269     raeburn  3375:         &secgroup_lister($cat,$pschp,$parmlev,$listdata,\@psprt,\@selected_sections,\%defkeytype,\%allmaps,\@ids,\%symbp);
                   3376:         &secgroup_lister($cat,$pschp,$parmlev,$listdata,\@psprt,\@selected_groups,\%defkeytype,\%allmaps,\@ids,\%symbp);
1.211     www      3377:     }
                   3378: 
1.212     www      3379:     if (($env{'form.store'}) || ($env{'form.dis'})) {
1.211     www      3380: 
1.212     www      3381: 	if ($env{'form.store'}) { &storedata($r,$crs,$dom); }
1.211     www      3382: 
                   3383: # Read modified data
                   3384: 
                   3385: 	my $resourcedata=&readdata($crs,$dom);
                   3386: 
                   3387: # List data
                   3388: 
1.214     www      3389: 	&listdata($r,$resourcedata,$listdata,$sortorder);
1.211     www      3390:     }
                   3391:     $r->print(&tableend().
1.365     albertel 3392: 	     ((($env{'form.store'}) || ($env{'form.dis'}))?'<p><input type="submit" name="store" value="'.&mt('Save').'" /></p>':'').
1.280     albertel 3393: 	      '</form>'.&Apache::loncommon::end_page());
1.208     www      3394: }
                   3395: 
1.269     raeburn  3396: sub secgroup_lister {
                   3397:     my ($cat,$pschp,$parmlev,$listdata,$psprt,$selections,$defkeytype,$allmaps,$ids,$symbp) = @_;
                   3398:     foreach my $item (@{$selections}) {
                   3399:         foreach my $part (@{$psprt}) {
                   3400:             my $rootparmkey=$env{'request.course.id'};
                   3401:             if (($item ne 'all') && ($item ne 'none') && ($item)) {
                   3402:                 $rootparmkey.='.['.$item.']';
                   3403:             }
                   3404:             if ($parmlev eq 'general') {
                   3405: # course-level parameter
                   3406:                 my $newparmkey=$rootparmkey.'.'.$part.'.'.$cat;
                   3407:                 $$listdata{$newparmkey}=1;
                   3408:                 $$listdata{$newparmkey.'.type'}=$$defkeytype{$cat};
                   3409:             } elsif ($parmlev eq 'map') {
                   3410: # map-level parameter
                   3411:                 foreach my $mapid (keys %{$allmaps}) {
                   3412:                     if (($pschp ne 'all') && ($pschp ne $mapid)) { next; }
                   3413:                     my $newparmkey=$rootparmkey.'.'.$$allmaps{$mapid}.'___(all).'.$part.'.'.$cat;
                   3414:                     $$listdata{$newparmkey}=1;
                   3415:                     $$listdata{$newparmkey.'.type'}=$$defkeytype{$cat};
                   3416:                 }
                   3417:             } else {
                   3418: # resource-level parameter
                   3419:                 foreach my $rid (@{$ids}) {
                   3420:                     my ($map,$resid,$url)=&Apache::lonnet::decode_symb($$symbp{$rid});
                   3421:                     if (($pschp ne 'all') && ($$allmaps{$pschp} ne $map)) { next; }
                   3422:                     my $newparmkey=$rootparmkey.'.'.$$symbp{$rid}.'.'.$part.'.'.$cat;
                   3423:                     $$listdata{$newparmkey}=1;
                   3424:                     $$listdata{$newparmkey.'.type'}=$$defkeytype{$cat};
                   3425:                 }
                   3426:             }
                   3427:         }
                   3428:     }
                   3429: }
                   3430: 
1.208     www      3431: sub overview {
1.280     albertel 3432:     my ($r) = @_;
1.208     www      3433:     my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                   3434:     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
1.280     albertel 3435: 
1.414     droeschl 3436:     &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=setoverview',
                   3437: 	text=>"Overview Mode"});
1.280     albertel 3438:     my $start_page=&Apache::loncommon::start_page('Modify Parameters');
1.298     albertel 3439:     my $breadcrumbs = &Apache::lonhtmlcommon::breadcrumbs('Overview');
1.208     www      3440:     $r->print(<<ENDOVER);
1.280     albertel 3441: $start_page
1.208     www      3442: $breadcrumbs
1.232     albertel 3443: <form method="post" action="/adm/parmset?action=setoverview" name="parmform">
1.208     www      3444: ENDOVER
                   3445: # Store modified
                   3446: 
                   3447:     &storedata($r,$crs,$dom);
                   3448: 
                   3449: # Read modified data
                   3450: 
                   3451:     my $resourcedata=&readdata($crs,$dom);
                   3452: 
1.214     www      3453: 
                   3454:     my $sortorder=$env{'form.sortorder'};
                   3455:     unless ($sortorder) { $sortorder='realmstudent'; }
                   3456:     &sortmenu($r,$sortorder);
                   3457: 
1.208     www      3458: # List data
                   3459: 
1.214     www      3460:     my $foundkeys=&listdata($r,$resourcedata,$resourcedata,$sortorder);
1.208     www      3461: 
1.145     www      3462:     $r->print(&tableend().'<p>'.
1.430   ! schafran 3463: 	($foundkeys?'<input type="submit" value="'.&mt('Save').'" />':&mt('There are no parameters.')).'</p></form>'.
1.280     albertel 3464: 	      &Apache::loncommon::end_page());
1.120     www      3465: }
1.121     www      3466: 
1.333     albertel 3467: sub clean_parameters {
                   3468:     my ($r) = @_;
                   3469:     my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                   3470:     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
                   3471: 
1.414     droeschl 3472:     &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=cleanparameters',
                   3473:     	text=>"Clean Parameters"});
1.333     albertel 3474:     my $start_page=&Apache::loncommon::start_page('Clean Parameters');
                   3475:     my $breadcrumbs = &Apache::lonhtmlcommon::breadcrumbs('Clean');
                   3476:     $r->print(<<ENDOVER);
                   3477: $start_page
                   3478: $breadcrumbs
                   3479: <form method="post" action="/adm/parmset?action=cleanparameters" name="parmform">
                   3480: ENDOVER
                   3481: # Store modified
                   3482: 
                   3483:     &storedata($r,$crs,$dom);
                   3484: 
                   3485: # Read modified data
                   3486: 
                   3487:     my $resourcedata=&readdata($crs,$dom);
                   3488: 
                   3489: # List data
                   3490: 
                   3491:     $r->print('<h3>'.
                   3492: 	      &mt('These parameters refer to resources that do not exist.').
                   3493: 	      '</h3>'.
1.415     schafran 3494: 	      '<input type="submit" value="'.&mt('Delete Selected').'" />'.'<br />'.
1.333     albertel 3495: 	      '<br />');
                   3496:     $r->print(&Apache::loncommon::start_data_table().
                   3497: 	      '<tr>'.
                   3498: 	      '<th>'.&mt('Delete').'</th>'.
                   3499: 	      '<th>'.&mt('Parameter').'</th>'.
                   3500: 	      '</tr>');
                   3501:     foreach my $thiskey (sort(keys(%{$resourcedata}))) {
                   3502: 	next if (!exists($resourcedata->{$thiskey.'.type'})
                   3503: 		 && $thiskey=~/\.type$/);
                   3504: 	my %data = &parse_key($thiskey);
1.383     albertel 3505: 	if (1) { #exists($data{'realm_exists'})
                   3506: 	    #&& !$data{'realm_exists'}) {
1.333     albertel 3507: 	    $r->print(&Apache::loncommon::start_data_table_row().
                   3508: 		      '<tr>'.
                   3509: 		      '<td><input type="checkbox" name="del_'.$thiskey.'" /></td>'		      );
                   3510: 	    
                   3511: 	    $r->print('<td>');
1.362     albertel 3512: 	    my $display_value = $resourcedata->{$thiskey};
                   3513: 	    if (&isdateparm($resourcedata->{$thiskey.'.type'})) {
                   3514: 		$display_value = 
                   3515: 		    &Apache::lonlocal::locallocaltime($display_value);
                   3516: 	    }
1.333     albertel 3517: 	    $r->print(&mt('Parameter: "[_1]" with value: "[_2]"',
                   3518: 			  &standard_parameter_names($data{'parameter_name'}),
                   3519: 			  $resourcedata->{$thiskey}));
                   3520: 	    $r->print('<br />');
                   3521: 	    if ($data{'scope_type'} eq 'all') {
                   3522: 		$r->print(&mt('All users'));
                   3523: 	    } elsif ($data{'scope_type'} eq 'user') {
                   3524: 		$r->print(&mt('User: [_1]',join(':',@{$data{'scope'}})));
                   3525: 	    } elsif ($data{'scope_type'} eq 'section') {
                   3526: 		$r->print(&mt('Section: [_1]',$data{'scope'}));
                   3527: 	    } elsif ($data{'scope_type'} eq 'group') {
                   3528: 		$r->print(&mt('Group: [_1]',$data{'scope'}));
                   3529: 	    }
                   3530: 	    $r->print('<br />');
                   3531: 	    if ($data{'realm_type'} eq 'all') {
                   3532: 		$r->print(&mt('All Resources'));
                   3533: 	    } elsif ($data{'realm_type'} eq 'folder') {
                   3534: 		$r->print(&mt('Folder: [_1]'),$data{'realm'});
                   3535: 	    } elsif ($data{'realm_type'} eq 'symb') {
                   3536: 		my ($map,$resid,$url) =
                   3537: 		    &Apache::lonnet::decode_symb($data{'realm'});
                   3538: 		$r->print(&mt('Resource: [_1] <br />&nbsp;&nbsp;&nbsp;with ID: [_2] <br />&nbsp;&nbsp;&nbsp;in folder [_3]',
                   3539: 			      $url,$resid,$map));
                   3540: 	    }
1.362     albertel 3541: 	    $r->print(' <br />&nbsp;&nbsp;&nbsp;'.&mt('Part: [_1]',$data{'parameter_part'}));
1.333     albertel 3542: 	    $r->print('</td></tr>');
                   3543: 	
                   3544: 	}
                   3545:     }
                   3546:     $r->print(&Apache::loncommon::end_data_table().'<p>'.
1.415     schafran 3547: 	      '<input type="submit" value="'.&mt('Delete Selected').'" />'.
1.333     albertel 3548: 	      '</p></form>'.
                   3549: 	      &Apache::loncommon::end_page());
                   3550: }
                   3551: 
1.390     www      3552: sub date_shift_one {
                   3553:     my ($r) = @_;
                   3554:     my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                   3555:     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
                   3556: 
1.414     droeschl 3557:     &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=dateshift1&timebase='.$env{'form.timebase'},
                   3558:     	text=>"Shifting Dates"});
1.390     www      3559:     my $start_page=&Apache::loncommon::start_page('Shift Dates');
                   3560:     my $breadcrumbs = &Apache::lonhtmlcommon::breadcrumbs('Shift');
                   3561:     $r->print(<<ENDOVER);
                   3562: $start_page
                   3563: $breadcrumbs
                   3564: ENDOVER
                   3565:     $r->print('<form name="shiftform" method="post">'.
                   3566:               '<table><tr><td>'.&mt('Currently set date:').'</td><td>'.
                   3567:               &Apache::lonlocal::locallocaltime($env{'form.timebase'}).'</td></tr>'.
                   3568:               '<tr><td>'.&mt('Shifted date:').'</td><td>'.
                   3569:                     &Apache::lonhtmlcommon::date_setter('shiftform',
                   3570:                                                         'timeshifted',
                   3571:                                                         $env{'form.timebase'},,
                   3572:                                                         '').
                   3573:               '</td></tr></table>'.
                   3574:               '<input type="hidden" name="action" value="dateshift2" />'.
                   3575:               '<input type="hidden" name="timebase" value="'.$env{'form.timebase'}.'" />'.
                   3576:               '<input type="submit" value="'.&mt('Shift all dates accordingly').'" /></form>');
                   3577:     $r->print(&Apache::loncommon::end_page());
                   3578: }
                   3579: 
                   3580: sub date_shift_two {
                   3581:     my ($r) = @_;
                   3582:     my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                   3583:     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
1.414     droeschl 3584:     &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=dateshift1&timebase='.$env{'form.timebase'},
                   3585:     	text=>"Shifting Dates"});
1.390     www      3586:     my $start_page=&Apache::loncommon::start_page('Shift Dates');
                   3587:     my $breadcrumbs = &Apache::lonhtmlcommon::breadcrumbs('Shift');
                   3588:     $r->print(<<ENDOVER);
                   3589: $start_page
                   3590: $breadcrumbs
                   3591: ENDOVER
                   3592:     my $timeshifted=&Apache::lonhtmlcommon::get_date_from_form('timeshifted');
                   3593:     $r->print(&mt('Shifting all dates such that [_1] becomes [_2]',
                   3594:               &Apache::lonlocal::locallocaltime($env{'form.timebase'}),
                   3595:               &Apache::lonlocal::locallocaltime($timeshifted)));
                   3596:     my $delta=$timeshifted-$env{'form.timebase'};
                   3597:     &dateshift($delta);
                   3598:     $r->print(&Apache::loncommon::end_page());
                   3599: }
                   3600: 
1.333     albertel 3601: sub parse_key {
                   3602:     my ($key) = @_;
                   3603:     my %data;
                   3604:     my ($middle,$part,$name)=
                   3605: 	($key=~/^$env{'request.course.id'}\.(?:(.+)\.)*([\w\s]+)\.(\w+)$/);
                   3606:     $data{'scope_type'} = 'all';
                   3607:     if ($middle=~/^\[(.*)\]/) {
                   3608:        	$data{'scope'} = $1;
1.350     albertel 3609: 	if ($data{'scope'}=~/^useropt\:($match_username)\:($match_domain)/) {
1.333     albertel 3610: 	    $data{'scope_type'} = 'user';
                   3611: 	    $data{'scope'} = [$1,$2];
                   3612: 	} else {
                   3613: 	    #FIXME check for group scope
                   3614: 	    $data{'scope_type'} = 'section';
                   3615: 	}
                   3616: 	$middle=~s/^\[(.*)\]//;
                   3617:     }
                   3618:     $middle=~s/\.+$//;
                   3619:     $middle=~s/^\.+//;
                   3620:     $data{'realm_type'}='all';
                   3621:     if ($middle=~/^(.+)\_\_\_\(all\)$/) {
                   3622: 	$data{'realm'} = $1;
                   3623: 	$data{'realm_type'} = 'folder';
                   3624: 	$data{'realm_title'} = &Apache::lonnet::gettitle($data{'realm'});
                   3625: 	($data{'realm_exists'}) = &Apache::lonnet::is_on_map($data{'realm'});
                   3626:     } elsif ($middle) {
                   3627: 	$data{'realm'} = $middle;
                   3628: 	$data{'realm_type'} = 'symb';
                   3629: 	$data{'realm_title'} = &Apache::lonnet::gettitle($data{'realm'});
                   3630: 	my ($map,$resid,$url) = &Apache::lonnet::decode_symb($data{'realm'});
                   3631: 	$data{'realm_exists'} = &Apache::lonnet::symbverify($data{'realm'},$url);
                   3632:     }
                   3633:     
                   3634:     $data{'parameter_part'} = $part;
                   3635:     $data{'parameter_name'} = $name;
                   3636: 
                   3637:     return %data;
                   3638: }
                   3639: 
1.239     raeburn  3640: 
1.178     raeburn  3641: 
1.239     raeburn  3642: sub extract_cloners {
                   3643:     my ($clonelist,$allowclone) = @_;
                   3644:     if ($clonelist =~ /,/) {
1.380     albertel 3645:         @{$allowclone} = split(/,/,$clonelist);
1.239     raeburn  3646:     } else {
                   3647:         $$allowclone[0] = $clonelist;
                   3648:     }
                   3649: }
                   3650: 
                   3651: sub check_cloners {
                   3652:     my ($clonelist,$oldcloner) = @_;
1.379     raeburn  3653:     my ($clean_clonelist,%disallowed);
1.239     raeburn  3654:     my @allowclone = ();
                   3655:     &extract_cloners($$clonelist,\@allowclone);
                   3656:     foreach my $currclone (@allowclone) {
1.380     albertel 3657:         if (!grep(/^\Q$currclone\E$/,@$oldcloner)) {
1.379     raeburn  3658:             if ($currclone eq '*') {
                   3659:                 $clean_clonelist .= $currclone.',';
                   3660:             } else {
                   3661:                 my ($uname,$udom) = split(/:/,$currclone);
                   3662:                 if ($uname eq '*') {
                   3663:                     if ($udom =~ /^$match_domain$/) {
1.380     albertel 3664:                         if (!&Apache::lonnet::domain($udom)) {
1.379     raeburn  3665:                             $disallowed{'domain'} .= $currclone.',';
                   3666:                         } else {
                   3667:                             $clean_clonelist .= $currclone.',';
                   3668:                         }
                   3669:                     } else {
                   3670:                         $disallowed{'format'} .= $currclone.',';
                   3671:                     }
                   3672:                 } elsif ($currclone !~/^($match_username)\:($match_domain)$/) {
                   3673:                     $disallowed{'format'} .= $currclone.','; 
1.239     raeburn  3674:                 } else {
1.379     raeburn  3675:                     if (&Apache::lonnet::homeserver($uname,$udom) eq 'no_host') {
                   3676:                         $disallowed{'newuser'} .= $currclone.',';
                   3677:                     } else {
                   3678:                         $clean_clonelist .= $currclone.',';
                   3679:                     }
1.239     raeburn  3680:                 }
                   3681:             }
                   3682:         } else {
                   3683:             $clean_clonelist .= $currclone.',';
                   3684:         }
                   3685:     }
1.379     raeburn  3686:     foreach my $key (keys(%disallowed)) {
                   3687:         $disallowed{$key} =~ s/,$//;
1.239     raeburn  3688:     }
                   3689:     if ($clean_clonelist) {
                   3690:         $clean_clonelist =~ s/,$//;
                   3691:     }
                   3692:     $$clonelist = $clean_clonelist;
1.379     raeburn  3693:     return %disallowed;
                   3694: }
1.178     raeburn  3695: 
                   3696: sub change_clone {
                   3697:     my ($clonelist,$oldcloner) = @_;
                   3698:     my ($uname,$udom);
1.190     albertel 3699:     my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
                   3700:     my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
1.178     raeburn  3701:     my $clone_crs = $cnum.':'.$cdom;
                   3702:     
                   3703:     if ($cnum && $cdom) {
1.239     raeburn  3704:         my @allowclone;
                   3705:         &extract_cloners($clonelist,\@allowclone);
1.178     raeburn  3706:         foreach my $currclone (@allowclone) {
1.380     albertel 3707:             if (!grep(/^$currclone$/,@$oldcloner)) {
1.379     raeburn  3708:                 if ($currclone ne '*') {
1.380     albertel 3709:                     ($uname,$udom) = split(/:/,$currclone);
1.379     raeburn  3710:                     if ($uname && $udom && $uname ne '*') {
                   3711:                         if (&Apache::lonnet::homeserver($uname,$udom) ne 'no_host') {
                   3712:                             my %currclonecrs = &Apache::lonnet::dump('environment',$udom,$uname,'cloneable');
                   3713:                             if ($currclonecrs{'cloneable'} !~ /\Q$clone_crs\E/) {
                   3714:                                 if ($currclonecrs{'cloneable'} eq '') {
                   3715:                                     $currclonecrs{'cloneable'} = $clone_crs;
                   3716:                                 } else {
                   3717:                                     $currclonecrs{'cloneable'} .= ','.$clone_crs;
                   3718:                                 }
                   3719:                                 &Apache::lonnet::put('environment',\%currclonecrs,$udom,$uname);
1.178     raeburn  3720:                             }
                   3721:                         }
                   3722:                     }
                   3723:                 }
                   3724:             }
                   3725:         }
                   3726:         foreach my $oldclone (@$oldcloner) {
1.380     albertel 3727:             if (!grep(/^\Q$oldclone\E$/,@allowclone)) {
1.379     raeburn  3728:                 if ($oldclone ne '*') {
1.380     albertel 3729:                     ($uname,$udom) = split(/:/,$oldclone);
1.379     raeburn  3730:                     if ($uname && $udom && $uname ne '*' ) {
                   3731:                         if (&Apache::lonnet::homeserver($uname,$udom) ne 'no_host') {
                   3732:                             my %currclonecrs = &Apache::lonnet::dump('environment',$udom,$uname,'cloneable');
                   3733:                             my %newclonecrs = ();
                   3734:                             if ($currclonecrs{'cloneable'} =~ /\Q$clone_crs\E/) {
                   3735:                                 if ($currclonecrs{'cloneable'} =~ /,/) {
                   3736:                                     my @currclonecrs = split/,/,$currclonecrs{'cloneable'};
                   3737:                                     foreach my $crs (@currclonecrs) {
                   3738:                                         if ($crs ne $clone_crs) {
                   3739:                                             $newclonecrs{'cloneable'} .= $crs.',';
                   3740:                                         }
1.178     raeburn  3741:                                     }
1.379     raeburn  3742:                                     $newclonecrs{'cloneable'} =~ s/,$//;
                   3743:                                 } else {
                   3744:                                     $newclonecrs{'cloneable'} = '';
1.178     raeburn  3745:                                 }
1.379     raeburn  3746:                                 &Apache::lonnet::put('environment',\%newclonecrs,$udom,$uname);
1.178     raeburn  3747:                             }
                   3748:                         }
                   3749:                     }
                   3750:                 }
                   3751:             }
                   3752:         }
                   3753:     }
                   3754: }
                   3755: 
1.193     albertel 3756: 
                   3757: 
1.416     jms      3758: sub header {
                   3759:     return &Apache::loncommon::start_page('Parameter Manager');
                   3760: }
1.193     albertel 3761: 
                   3762: 
                   3763: 
                   3764: sub print_main_menu {
                   3765:     my ($r,$parm_permission)=@_;
                   3766:     #
1.414     droeschl 3767:     $r->print(&header());
                   3768:     $r->print(&Apache::lonhtmlcommon::breadcrumbs('Parameter Manager'));
1.193     albertel 3769:     $r->print(<<ENDMAINFORMHEAD);
                   3770: <form method="post" enctype="multipart/form-data"
                   3771:       action="/adm/parmset" name="studentform">
                   3772: ENDMAINFORMHEAD
                   3773: #
1.195     albertel 3774:     my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
                   3775:     my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
1.268     albertel 3776:     my $vgr  = &Apache::lonnet::allowed('vgr',$env{'request.course.id'});
1.366     albertel 3777:     my $mgr  = &Apache::lonnet::allowed('mgr',$env{'request.course.id'});
1.268     albertel 3778: 
1.417     droeschl 3779: 
1.193     albertel 3780:     my @menu =
1.417     droeschl 3781:         ( { categorytitle=>'Settings for this Course',
1.414     droeschl 3782: 	    items => [
1.417     droeschl 3783: 		  { linktext => 'Course Environment',
1.414     droeschl 3784: 		    url => '/adm/parmset?action=crsenv',
                   3785: 		    permission => $parm_permission,
1.417     droeschl 3786: 		    linktitle =>'Edit environment settings for this course.'  ,
                   3787: 		    icon => 'preferences-desktop-remote-desktop.png'  ,
                   3788: 		    #help => 'Course_Environment',
1.414     droeschl 3789: 		    },
1.417     droeschl 3790: 		  { linktext => 'Portfolio Metadata',
1.414     droeschl 3791: 		    url => '/adm/parmset?action=setrestrictmeta',
                   3792: 		    permission => $parm_permission,
1.417     droeschl 3793: 		    linktitle => 'Restrict metadata for this course.' ,
                   3794: 		    icon =>'contact-new.png'   ,
1.414     droeschl 3795: 		    },
                   3796: 		  { linktext => 'Manage Course Slots',
                   3797: 		    url => '/adm/slotrequest?command=showslots',
                   3798: 		    permission => $vgr,
1.417     droeschl 3799: 		    linktitle =>'Manage slots for this course.'  ,
                   3800: 		    icon => 'format-justify-fill.png'  ,
1.414     droeschl 3801: 		    },
                   3802: 		  { linktext => 'Reset Student Access Times',
                   3803: 		    url => '/adm/helper/resettimes.helper',
                   3804: 		    permission => $mgr,
1.417     droeschl 3805: 		    linktitle =>'Reset access times for folders/maps, resources or the course.'  ,
                   3806: 		    icon => 'start-here.png'  ,
1.414     droeschl 3807: 		    },
                   3808: 
                   3809: 		  { linktext => 'Set Parameter Setting Default Actions',
                   3810: 		    url => '/adm/parmset?action=setdefaults',
                   3811: 		    permission => $parm_permission,
1.417     droeschl 3812: 		    linktitle =>'Set default actions for parameters.'  ,
                   3813: 		    icon => 'folder-new.png'  ,
1.414     droeschl 3814: 		    }]},          
1.417     droeschl 3815: 	  { categorytitle => 'New and Existing Parameter Settings for Resources',
1.414     droeschl 3816: 	    items => [
1.417     droeschl 3817: 		  { linktext => 'Edit Resource Parameters - Helper Mode',
1.414     droeschl 3818: 		    url => '/adm/helper/parameter.helper',
                   3819: 		    permission => $parm_permission,
1.417     droeschl 3820: 		    linktitle =>'Set/Modify resource parameters in helper mode.'  ,
                   3821: 		    icon => 'dialog-information.png'  ,
                   3822: 		    #help => 'Parameter_Helper',
1.414     droeschl 3823: 		    },
1.417     droeschl 3824: 		  { linktext => 'Edit Resource Parameters - Overview Mode',
1.414     droeschl 3825: 		    url => '/adm/parmset?action=newoverview',
                   3826: 		    permission => $parm_permission,
1.417     droeschl 3827: 		    linktitle =>'Set/Modify resource parameters in overview mode.'  ,
                   3828: 		    icon => 'edit-find.png'  ,
                   3829: 		    #help => 'Parameter_Overview',
1.414     droeschl 3830: 		    },
1.417     droeschl 3831: 		  { linktext => 'Edit Resource Parameters - Table Mode',
1.414     droeschl 3832: 		    url => '/adm/parmset?action=settable',
                   3833: 		    permission => $parm_permission,
1.417     droeschl 3834: 		    linktitle =>'Set/Modify resource parameters in table mode.'  ,
                   3835: 		    icon => 'edit-copy.png'  ,
                   3836: 		    #help => 'Table_Mode',
1.414     droeschl 3837: 		    }]},
1.417     droeschl 3838:            { categorytitle => 'Existing Parameter Settings for Resources',
1.414     droeschl 3839: 	     items => [
                   3840: 		  { linktext => 'Modify Resource Parameters - Overview Mode',
                   3841: 		    url => '/adm/parmset?action=setoverview',
                   3842: 		    permission => $parm_permission,
1.417     droeschl 3843: 		    linktitle =>'Set/Modify existing resource parameters in overview mode.'  ,
                   3844: 		    icon => 'preferences-desktop-wallpaper.png'  ,
                   3845: 		    #help => 'Parameter_Overview',
1.414     droeschl 3846: 		    },          
1.417     droeschl 3847: 		  { linktext => 'Change Log',
1.414     droeschl 3848: 		    url => '/adm/parmset?action=parameterchangelog',
                   3849: 		    permission => $parm_permission,
1.417     droeschl 3850: 		    linktitle =>'View parameter and course blog posting/user notification change log.'  ,
                   3851: 		    icon => 'emblem-system.png'   ,
1.414     droeschl 3852: 		    }]}
1.193     albertel 3853:           );
1.414     droeschl 3854:     $r->print(&Apache::lonhtmlcommon::generate_menu(@menu));
1.193     albertel 3855:     return;
                   3856: }
1.414     droeschl 3857: 
1.416     jms      3858: 
                   3859: 
1.252     banghart 3860: sub output_row {
1.347     banghart 3861:     my ($r, $field_name, $field_text, $added_flag) = @_;
1.252     banghart 3862:     my $output;
1.263     banghart 3863:     my $options=$env{'course.'.$env{'request.course.id'}.'.metadata.'.$field_name.'.options'};
                   3864:     my $values=$env{'course.'.$env{'request.course.id'}.'.metadata.'.$field_name.'.values'};
1.337     banghart 3865:     if (!defined($options)) {
1.254     banghart 3866:         $options = 'active,stuadd';
1.261     banghart 3867:         $values = '';
1.252     banghart 3868:     }
1.337     banghart 3869:     if (!($options =~ /deleted/)) {
                   3870:         my @options= ( ['active', 'Show to student'],
1.418     schafran 3871:                     ['stuadd', 'Provide text area for students to type metadata'],
1.351     banghart 3872:                     ['choices','Provide choices for students to select from']);
                   3873: #		   ['onlyone','Student may select only one choice']);
1.337     banghart 3874:         if ($added_flag) {
                   3875:             push @options,['deleted', 'Delete Metadata Field'];
                   3876:         }
1.351     banghart 3877:        $output = &Apache::loncommon::start_data_table_row();
                   3878:         $output .= '<td><span class="LC_metadata"><strong>'.$field_text.':</strong></span></td>';
                   3879:         $output .= &Apache::loncommon::end_data_table_row();
1.337     banghart 3880:         foreach my $opt (@options) {
                   3881: 	    my $checked = ($options =~ m/$opt->[0]/) ? ' checked="checked" ' : '' ;
1.347     banghart 3882: 	    $output .= &Apache::loncommon::continue_data_table_row();
1.351     banghart 3883: 	    $output .= '<td>'.('&nbsp;' x 5).'<span class="LC_metadata"><label>
                   3884: 	               <input type="checkbox" name="'.
                   3885: 	               $field_name.'_'.$opt->[0].'" value="yes"'.$checked.' />'.
                   3886: 	               &mt($opt->[1]).'</label></span> </td>';
1.347     banghart 3887: 	    $output .= &Apache::loncommon::end_data_table_row();
1.337     banghart 3888: 	}
1.351     banghart 3889:         $output .= &Apache::loncommon::continue_data_table_row();
                   3890:         $output .= '<td>'.('&nbsp;' x 10).'<span class="LC_metadata"><input name="'.$field_name.'_values" type="text" value="'.$values.'" size="80" /></span></td>';
                   3891:         $output .= &Apache::loncommon::end_data_table_row();
                   3892:         my $multiple_checked;
                   3893:         my $single_checked;
                   3894:         if ($options =~ m/onlyone/) {
1.422     bisitz   3895:             $multiple_checked = '';
1.423     bisitz   3896:             $single_checked = ' checked="checked"';
1.351     banghart 3897:         } else {
1.423     bisitz   3898:             $multiple_checked = ' checked="checked"';
1.422     bisitz   3899:             $single_checked = '';
1.351     banghart 3900:         }
                   3901: 	$output .= &Apache::loncommon::continue_data_table_row();
                   3902: 	$output .= '<td>'.('&nbsp;' x 10).'<span class="LC_metadata">
1.423     bisitz   3903: 	            <input type="radio" name="'.$field_name.'_onlyone" value="multiple"'.$multiple_checked .' />
1.418     schafran 3904: 	            '.&mt('Student may select multiple choices from list').'</span></td>';
1.351     banghart 3905: 	$output .= &Apache::loncommon::end_data_table_row();
                   3906: 	$output .= &Apache::loncommon::continue_data_table_row();
                   3907: 	$output .= '<td>'.('&nbsp;' x 10).'<span class="LC_metadata">
1.423     bisitz   3908: 	            <input type="radio" name="'.$field_name.'_onlyone"  value="single"'.$single_checked.' />
1.418     schafran 3909: 	            '.&mt('Student may select only one choice from list').'</span></td>';
1.351     banghart 3910: 	$output .= &Apache::loncommon::end_data_table_row();
1.252     banghart 3911:     }
                   3912:     return ($output);
                   3913: }
1.416     jms      3914: 
                   3915: 
                   3916: 
1.340     banghart 3917: sub order_meta_fields {
                   3918:     my ($r)=@_;
                   3919:     my $idx = 1;
                   3920:     my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                   3921:     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
1.341     banghart 3922:     $r->print(&Apache::loncommon::start_page('Order Metadata Fields'));
1.414     droeschl 3923:     &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=addmetadata',
                   3924:     	text=>"Add Metadata Field"});
1.345     banghart 3925:     &Apache::lonhtmlcommon::add_breadcrumb
                   3926:             ({href=>"/adm/parmset?action=setrestrictmeta",
                   3927:               text=>"Restrict Metadata"},
                   3928:              {text=>"Order Metadata"});
                   3929:     $r->print(&Apache::lonhtmlcommon::breadcrumbs('Order Metadata'));
1.340     banghart 3930:     if ($env{'form.storeorder'}) {
                   3931:         my $newpos = $env{'form.newpos'} - 1;
                   3932:         my $currentpos = $env{'form.currentpos'} - 1;
                   3933:         my @neworder = ();
                   3934:         my @oldorder = split /,/,$env{'course.'.$env{'request.course.id'}.'.metadata.addedorder'};
                   3935:         my $i;
1.341     banghart 3936:         if ($newpos > $currentpos) {
1.340     banghart 3937:         # moving stuff up
                   3938:             for ($i=0;$i<$currentpos;$i++) {
                   3939:         	$neworder[$i]=$oldorder[$i];
                   3940:             }
                   3941:             for ($i=$currentpos;$i<$newpos;$i++) {
                   3942:         	$neworder[$i]=$oldorder[$i+1];
                   3943:             }
                   3944:             $neworder[$newpos]=$oldorder[$currentpos];
                   3945:             for ($i=$newpos+1;$i<=$#oldorder;$i++) {
                   3946:         	$neworder[$i]=$oldorder[$i];
                   3947:             }
                   3948:         } else {
                   3949:         # moving stuff down
                   3950:     	    for ($i=0;$i<$newpos;$i++) {
                   3951:     	        $neworder[$i]=$oldorder[$i];
                   3952:     	    }
                   3953:     	    $neworder[$newpos]=$oldorder[$currentpos];
                   3954:     	    for ($i=$newpos+1;$i<$currentpos+1;$i++) {
                   3955:     	        $neworder[$i]=$oldorder[$i-1];
                   3956:     	    }
                   3957:     	    for ($i=$currentpos+1;$i<=$#oldorder;$i++) {
                   3958:     	        $neworder[$i]=$oldorder[$i];
                   3959:     	    }
                   3960:         }
                   3961: 	my $ordered_fields = join ",", @neworder;
1.343     banghart 3962:         my $put_result = &Apache::lonnet::put('environment',
                   3963:                            {'metadata.addedorder'=>$ordered_fields},$dom,$crs); 	
1.393     raeburn  3964: 	&Apache::lonnet::appenv({'course.'.$env{'request.course.id'}.'.metadata.addedorder' => $ordered_fields});
1.340     banghart 3965:     }
1.357     raeburn  3966:     my $fields = &get_added_meta_fieldnames($env{'request.course.id'});
1.341     banghart 3967:     my $ordered_fields;
1.340     banghart 3968:     my @fields_in_order = split /,/,$env{'course.'.$env{'request.course.id'}.'.metadata.addedorder'};
                   3969:     if (!@fields_in_order) {
                   3970:         # no order found, pick sorted order then create metadata.addedorder key.
                   3971:         foreach my $key (sort keys %$fields) {
                   3972:             push @fields_in_order, $key;
1.341     banghart 3973:             $ordered_fields = join ",", @fields_in_order;
1.340     banghart 3974:         }
1.341     banghart 3975:         my $put_result = &Apache::lonnet::put('environment',
                   3976:                             {'metadata.addedorder'=>$ordered_fields},$dom,$crs); 
                   3977:     } 
1.340     banghart 3978:     $r->print('<table>');
                   3979:     my $num_fields = scalar(@fields_in_order);
                   3980:     foreach my $key (@fields_in_order) {
                   3981:         $r->print('<tr><td>');
                   3982:         $r->print('<form method="post" action="">');
                   3983:         $r->print('<select name="newpos" onChange="this.form.submit()">');
                   3984:         for (my $i = 1;$i le $num_fields;$i ++) {
                   3985:             if ($i eq $idx) {
                   3986:                 $r->print('<option value="'.$i.'"  SELECTED>('.$i.')</option>');
                   3987:             } else {
                   3988:                 $r->print('<option value="'.$i.'">'.$i.'</option>');
                   3989:             }
                   3990:         }
                   3991:         $r->print('</select></td><td>');
                   3992:         $r->print('<input type="hidden" name="currentpos" value="'.$idx.'" />');
                   3993:         $r->print('<input type="hidden" name="storeorder" value="true" />');
                   3994:         $r->print('</form>');
                   3995:         $r->print($$fields{$key}.'</td></tr>');
                   3996:         $idx ++;
                   3997:     }
                   3998:     $r->print('</table>');
                   3999:     return 'ok';
                   4000: }
1.416     jms      4001: 
                   4002: 
1.359     banghart 4003: sub continue {
                   4004:     my $output;
                   4005:     $output .= '<form action="" method="post">';
                   4006:     $output .= '<input type="hidden" name="action" value="setrestrictmeta" />';
                   4007:     $output .= '<input type="submit" value="Continue" />';
                   4008:     return ($output);
                   4009: }
1.416     jms      4010: 
                   4011: 
1.334     banghart 4012: sub addmetafield {
                   4013:     my ($r)=@_;
1.414     droeschl 4014:     &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=addmetadata',
                   4015:     	text=>"Add Metadata Field"});
1.334     banghart 4016:     $r->print(&Apache::loncommon::start_page('Add Metadata Field'));
                   4017:     $r->print(&Apache::lonhtmlcommon::breadcrumbs('Add Metadata Field'));
1.335     banghart 4018:     my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                   4019:     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
1.339     banghart 4020:     if (exists($env{'form.undelete'})) {
1.358     banghart 4021:         my @meta_fields = &Apache::loncommon::get_env_multiple('form.undeletefield');
1.339     banghart 4022:         foreach my $meta_field(@meta_fields) {
                   4023:             my $options = $env{'course.'.$env{'request.course.id'}.'.metadata.'.$meta_field.'.options'};
                   4024:             $options =~ s/deleted//;
                   4025:             $options =~ s/,,/,/;
                   4026:             my $put_result = &Apache::lonnet::put('environment',
                   4027:                                         {'metadata.'.$meta_field.'.options'=>$options},$dom,$crs);
                   4028:                                         
                   4029:             $r->print('Undeleted Metadata Field <strong>'.$env{'course.'.$env{'request.course.id'}.'.metadata.'.$meta_field.'.added'}."</strong> with result ".$put_result.'<br />');
                   4030:         }
1.359     banghart 4031:         $r->print(&continue());
1.339     banghart 4032:     } elsif (exists($env{'form.fieldname'})) {
1.335     banghart 4033:         my $meta_field = $env{'form.fieldname'};
                   4034:         my $display_field = $env{'form.fieldname'};
                   4035:         $meta_field =~ s/\W/_/g;
1.338     banghart 4036:         $meta_field =~ tr/A-Z/a-z/;
1.335     banghart 4037:         my $put_result = &Apache::lonnet::put('environment',
                   4038:                             {'metadata.'.$meta_field.'.values'=>"",
                   4039:                              'metadata.'.$meta_field.'.added'=>"$display_field",
                   4040:                              'metadata.'.$meta_field.'.options'=>""},$dom,$crs);
1.359     banghart 4041:         $r->print('Added new Metadata Field <strong>'.$env{'form.fieldname'}."</strong> with result ".$put_result.'<br />');
                   4042:         $r->print(&continue());
1.335     banghart 4043:     } else {
1.357     raeburn  4044:         my $fields = &get_deleted_meta_fieldnames($env{'request.course.id'});
1.339     banghart 4045:         if ($fields) {
                   4046:             $r->print('You may undelete previously deleted fields.<br />Check those you wish to undelete and click Undelete.<br />');
                   4047:             $r->print('<form method="post" action="">');
                   4048:             foreach my $key(keys(%$fields)) {
1.358     banghart 4049:                 $r->print('<input type="checkbox" name="undeletefield" value="'.$key.'" />'.$$fields{$key}.'<br /');
1.339     banghart 4050:             }
                   4051:             $r->print('<input type="submit" name="undelete" value="Undelete" />');
                   4052:             $r->print('</form>');
                   4053:         }
                   4054:         $r->print('<hr /><strong>Or</strong> you may enter a new metadata field name.<form method="post" action="/adm/parmset?action=addmetadata"');
1.335     banghart 4055:         $r->print('<input type="text" name="fieldname" /><br />');
                   4056:         $r->print('<input type="submit" value="Add Metadata Field" />');
1.334     banghart 4057:     }
1.361     albertel 4058:     $r->print('</form>');
1.334     banghart 4059: }
1.416     jms      4060: 
                   4061: 
                   4062: 
1.259     banghart 4063: sub setrestrictmeta {
1.240     banghart 4064:     my ($r)=@_;
1.242     banghart 4065:     my $next_meta;
1.244     banghart 4066:     my $output;
1.245     banghart 4067:     my $item_num;
1.246     banghart 4068:     my $put_result;
1.414     droeschl 4069:     &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=setrestrictmeta',
                   4070:     	text=>"Restrict Metadata"});
1.280     albertel 4071:     $r->print(&Apache::loncommon::start_page('Restrict Metadata'));
1.298     albertel 4072:     $r->print(&Apache::lonhtmlcommon::breadcrumbs('Restrict Metadata'));
1.240     banghart 4073:     my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                   4074:     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
1.259     banghart 4075:     my $key_base = $env{'course.'.$env{'request.course.id'}.'.'};
1.252     banghart 4076:     my $save_field = '';
1.259     banghart 4077:     if ($env{'form.restrictmeta'}) {
1.254     banghart 4078:         foreach my $field (sort(keys(%env))) {
1.252     banghart 4079:             if ($field=~m/^form.(.+)_(.+)$/) {
1.254     banghart 4080:                 my $options;
1.252     banghart 4081:                 my $meta_field = $1;
                   4082:                 my $meta_key = $2;
1.253     banghart 4083:                 if ($save_field ne $meta_field) {
1.252     banghart 4084:                     $save_field = $meta_field;
1.253     banghart 4085:             	    if ($env{'form.'.$meta_field.'_stuadd'}) {
1.254     banghart 4086:             	        $options.='stuadd,';
                   4087:             	    } 
1.351     banghart 4088:             	    if ($env{'form.'.$meta_field.'_choices'}) {
                   4089:             	        $options.='choices,';
                   4090:             	    } 
                   4091:             	    if ($env{'form.'.$meta_field.'_onlyone'} eq 'single') {
1.254     banghart 4092:             	        $options.='onlyone,';
                   4093:             	    } 
                   4094:             	    if ($env{'form.'.$meta_field.'_active'}) {
                   4095:             	        $options.='active,';
1.253     banghart 4096:             	    }
1.337     banghart 4097:             	    if ($env{'form.'.$meta_field.'_deleted'}) {
                   4098:             	        $options.='deleted,';
                   4099:             	    }
1.259     banghart 4100:                     my $name = $save_field;
1.253     banghart 4101:                      $put_result = &Apache::lonnet::put('environment',
1.262     banghart 4102:                                                   {'metadata.'.$meta_field.'.options'=>$options,
                   4103:                                                    'metadata.'.$meta_field.'.values'=>$env{'form.'.$meta_field.'_values'},
1.253     banghart 4104:                                                    },$dom,$crs);
1.252     banghart 4105:                 }
                   4106:             }
                   4107:         }
                   4108:     }
1.296     albertel 4109:     &Apache::lonnet::coursedescription($env{'request.course.id'},
                   4110: 				       {'freshen_cache' => 1});
1.335     banghart 4111:     # Get the default metadata fields
1.258     albertel 4112:     my %metadata_fields = &Apache::lonmeta::fieldnames('portfolio');
1.335     banghart 4113:     # Now get possible added metadata fields
1.357     raeburn  4114:     my $added_metadata_fields = &get_added_meta_fieldnames($env{'request.course.id'});
1.346     banghart 4115:     my $row_alt = 1;
1.347     banghart 4116:     $output .= &Apache::loncommon::start_data_table();
1.258     albertel 4117:     foreach my $field (sort(keys(%metadata_fields))) {
1.265     banghart 4118:         if ($field ne 'courserestricted') {
1.346     banghart 4119:             $row_alt = $row_alt ? 0 : 1;
1.347     banghart 4120: 	    $output.= &output_row($r, $field, $metadata_fields{$field});
1.265     banghart 4121: 	}
1.255     banghart 4122:     }
1.351     banghart 4123:     my $buttons = (<<ENDButtons);
                   4124:         <input type="submit" name="restrictmeta" value="Save" />
                   4125:         </form><br />
                   4126:         <form method="post" action="/adm/parmset?action=addmetadata" name="form1">
                   4127:         <input type="submit" name="restrictmeta" value="Add a Metadata Field" />
                   4128:         </form>
                   4129:         <br />
                   4130:         <form method="post" action="/adm/parmset?action=ordermetadata" name="form2">
                   4131:         <input type="submit" name="restrictmeta" value="Order Metadata Fields" />
                   4132: ENDButtons
1.337     banghart 4133:     my $added_flag = 1;
1.335     banghart 4134:     foreach my $field (sort(keys(%$added_metadata_fields))) {
1.346     banghart 4135:         $row_alt = $row_alt ? 0 : 1;
                   4136:         $output.= &output_row($r, $field, $$added_metadata_fields{$field},$added_flag, $row_alt);
1.335     banghart 4137:     }
1.347     banghart 4138:     $output .= &Apache::loncommon::end_data_table();
1.244     banghart 4139:     $r->print(<<ENDenv);       
1.259     banghart 4140:         <form method="post" action="/adm/parmset?action=setrestrictmeta" name="form">
1.244     banghart 4141:         $output
1.351     banghart 4142:         $buttons
1.340     banghart 4143:         </form>
1.244     banghart 4144: ENDenv
1.280     albertel 4145:     $r->print(&Apache::loncommon::end_page());
1.240     banghart 4146:     return 'ok';
                   4147: }
1.416     jms      4148: 
                   4149: 
                   4150: 
1.335     banghart 4151: sub get_added_meta_fieldnames {
1.357     raeburn  4152:     my ($cid) = @_;
1.335     banghart 4153:     my %fields;
                   4154:     foreach my $key(%env) {
1.357     raeburn  4155:         if ($key =~ m/\Q$cid\E\.metadata\.(.+)\.added$/) {
1.335     banghart 4156:             my $field_name = $1;
                   4157:             my ($display_field_name) = $env{$key};
                   4158:             $fields{$field_name} = $display_field_name;
                   4159:         }
                   4160:     }
                   4161:     return \%fields;
                   4162: }
1.416     jms      4163: 
                   4164: 
                   4165: 
1.339     banghart 4166: sub get_deleted_meta_fieldnames {
1.357     raeburn  4167:     my ($cid) = @_;
1.339     banghart 4168:     my %fields;
                   4169:     foreach my $key(%env) {
1.357     raeburn  4170:         if ($key =~ m/\Q$cid\E\.metadata\.(.+)\.added$/) {
1.339     banghart 4171:             my $field_name = $1;
                   4172:             if ($env{'course.'.$env{'request.course.id'}.'.metadata.'.$field_name.'.options'} =~ m/deleted/) {
                   4173:                 my ($display_field_name) = $env{$key};
                   4174:                 $fields{$field_name} = $display_field_name;
                   4175:             }
                   4176:         }
                   4177:     }
                   4178:     return \%fields;
                   4179: }
1.220     www      4180: sub defaultsetter {
1.280     albertel 4181:     my ($r) = @_;
                   4182: 
1.414     droeschl 4183:     &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=setdefaults',
                   4184:     	text=>"Set Defaults"});
1.280     albertel 4185:     my $start_page = 
                   4186: 	&Apache::loncommon::start_page('Parameter Setting Default Actions');
1.298     albertel 4187:     my $breadcrumbs = &Apache::lonhtmlcommon::breadcrumbs('Defaults');
1.220     www      4188:     $r->print(<<ENDDEFHEAD);
1.280     albertel 4189: $start_page
1.220     www      4190: $breadcrumbs
                   4191: <form method="post" action="/adm/parmset?action=setdefaults" name="defaultform">
                   4192: ENDDEFHEAD
1.280     albertel 4193: 
                   4194:     my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                   4195:     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
1.221     www      4196:     my @ids=();
                   4197:     my %typep=();
                   4198:     my %keyp=();
                   4199:     my %allparms=();
                   4200:     my %allparts=();
                   4201:     my %allmaps=();
                   4202:     my %mapp=();
                   4203:     my %symbp=();
                   4204:     my %maptitles=();
                   4205:     my %uris=();
                   4206:     my %keyorder=&standardkeyorder();
                   4207:     my %defkeytype=();
                   4208: 
                   4209:     &extractResourceInformation(\@ids, \%typep,\%keyp, \%allparms, \%allparts, \%allmaps, 
                   4210: 				\%mapp, \%symbp,\%maptitles,\%uris,
                   4211: 				\%keyorder,\%defkeytype);
1.224     www      4212:     if ($env{'form.storerules'}) {
                   4213: 	my %newrules=();
                   4214: 	my @delrules=();
1.226     www      4215: 	my %triggers=();
1.225     albertel 4216: 	foreach my $key (keys(%env)) {
                   4217:             if ($key=~/^form\.(\w+)\_action$/) {
1.224     www      4218: 		my $tempkey=$1;
1.226     www      4219: 		my $action=$env{$key};
                   4220:                 if ($action) {
                   4221: 		    $newrules{$tempkey.'_action'}=$action;
                   4222: 		    if ($action ne 'default') {
                   4223: 			my ($whichaction,$whichparm)=($action=~/^(.*\_)([^\_]+)$/);
                   4224: 			$triggers{$whichparm}.=$tempkey.':';
                   4225: 		    }
                   4226: 		    $newrules{$tempkey.'_type'}=$defkeytype{$tempkey};
1.224     www      4227: 		    if (&isdateparm($defkeytype{$tempkey})) {
1.227     www      4228: 			$newrules{$tempkey.'_days'}=$env{'form.'.$tempkey.'_days'};
1.224     www      4229: 			$newrules{$tempkey.'_hours'}=$env{'form.'.$tempkey.'_hours'};
                   4230: 			$newrules{$tempkey.'_min'}=$env{'form.'.$tempkey.'_min'};
                   4231: 			$newrules{$tempkey.'_sec'}=$env{'form.'.$tempkey.'_sec'};
                   4232: 		    } else {
                   4233: 			$newrules{$tempkey.'_value'}=$env{'form.'.$tempkey.'_value'};
1.227     www      4234: 			$newrules{$tempkey.'_triggervalue'}=$env{'form.'.$tempkey.'_triggervalue'};
1.224     www      4235: 		    }
                   4236: 		} else {
1.225     albertel 4237: 		    push(@delrules,$tempkey.'_action');
1.226     www      4238: 		    push(@delrules,$tempkey.'_type');
1.225     albertel 4239: 		    push(@delrules,$tempkey.'_hours');
                   4240: 		    push(@delrules,$tempkey.'_min');
                   4241: 		    push(@delrules,$tempkey.'_sec');
                   4242: 		    push(@delrules,$tempkey.'_value');
1.224     www      4243: 		}
                   4244: 	    }
                   4245: 	}
1.226     www      4246: 	foreach my $key (keys %allparms) {
                   4247: 	    $newrules{$key.'_triggers'}=$triggers{$key};
                   4248: 	}
1.224     www      4249: 	&Apache::lonnet::put('parmdefactions',\%newrules,$dom,$crs);
                   4250: 	&Apache::lonnet::del('parmdefactions',\@delrules,$dom,$crs);
                   4251: 	&resetrulescache();
                   4252:     }
1.227     www      4253:     my %lt=&Apache::lonlocal::texthash('days' => 'Days',
                   4254: 				       'hours' => 'Hours',
1.221     www      4255: 				       'min' => 'Minutes',
                   4256: 				       'sec' => 'Seconds',
                   4257: 				       'yes' => 'Yes',
                   4258: 				       'no' => 'No');
1.222     www      4259:     my @standardoptions=('','default');
                   4260:     my @standarddisplay=('',&mt('Default value when manually setting'));
                   4261:     my @dateoptions=('','default');
                   4262:     my @datedisplay=('',&mt('Default value when manually setting'));
                   4263:     foreach my $tempkey (&keysindisplayorder(\%allparms,\%keyorder)) {
                   4264: 	unless ($tempkey) { next; }
                   4265: 	push @standardoptions,'when_setting_'.$tempkey;
                   4266: 	push @standarddisplay,&mt('Automatically set when setting ').$tempkey;
                   4267: 	if (&isdateparm($defkeytype{$tempkey})) {
                   4268: 	    push @dateoptions,'later_than_'.$tempkey;
                   4269: 	    push @datedisplay,&mt('Automatically set later than ').$tempkey;
                   4270: 	    push @dateoptions,'earlier_than_'.$tempkey;
                   4271: 	    push @datedisplay,&mt('Automatically set earlier than ').$tempkey;
                   4272: 	} 
                   4273:     }
1.231     www      4274: $r->print(&mt('Manual setting rules apply to all interfaces.').'<br />'.
                   4275: 	  &mt('Automatic setting rules apply to table mode interfaces only.'));
1.318     albertel 4276:     $r->print("\n".&Apache::loncommon::start_data_table().
                   4277: 	      &Apache::loncommon::start_data_table_header_row().
                   4278: 	      "<th>".&mt('Rule for parameter').'</th><th>'.
                   4279: 	      &mt('Action').'</th><th>'.&mt('Value').'</th>'.
                   4280: 	      &Apache::loncommon::end_data_table_header_row());
1.221     www      4281:     foreach my $tempkey (&keysindisplayorder(\%allparms,\%keyorder)) {
1.222     www      4282: 	unless ($tempkey) { next; }
1.318     albertel 4283: 	$r->print("\n".&Apache::loncommon::start_data_table_row().
                   4284: 		  "<td>".$allparms{$tempkey}."\n<br />(".$tempkey.')</td><td>');
1.222     www      4285: 	my $action=&rulescache($tempkey.'_action');
                   4286: 	$r->print('<select name="'.$tempkey.'_action">');
                   4287: 	if (&isdateparm($defkeytype{$tempkey})) {
                   4288: 	    for (my $i=0;$i<=$#dateoptions;$i++) {
                   4289: 		if ($dateoptions[$i]=~/\_$tempkey$/) { next; }
                   4290: 		$r->print("\n<option value='$dateoptions[$i]'".
                   4291: 			  ($dateoptions[$i] eq $action?' selected="selected"':'').
                   4292: 			  ">$datedisplay[$i]</option>");
                   4293: 	    }
                   4294: 	} else {
                   4295: 	    for (my $i=0;$i<=$#standardoptions;$i++) {
                   4296: 		if ($standardoptions[$i]=~/\_$tempkey$/) { next; }
                   4297: 		$r->print("\n<option value='$standardoptions[$i]'".
                   4298: 			  ($standardoptions[$i] eq $action?' selected="selected"':'').
                   4299: 			  ">$standarddisplay[$i]</option>");
                   4300: 	    }
                   4301: 	}
                   4302: 	$r->print('</select>');
1.227     www      4303: 	unless (&isdateparm($defkeytype{$tempkey})) {
                   4304: 	    $r->print("\n<br />".&mt('Triggering value(s) of other parameter (optional, comma-separated):').
                   4305: 		      '<input type="text" size="20" name="'.$tempkey.'_triggervalue" value="'.&rulescache($tempkey.'_triggervalue').'" />');
                   4306: 	}
1.222     www      4307: 	$r->print("\n</td><td>\n");
                   4308: 
1.221     www      4309:         if (&isdateparm($defkeytype{$tempkey})) {
1.227     www      4310: 	    my $days=&rulescache($tempkey.'_days');
1.222     www      4311: 	    my $hours=&rulescache($tempkey.'_hours');
                   4312: 	    my $min=&rulescache($tempkey.'_min');
                   4313: 	    my $sec=&rulescache($tempkey.'_sec');
1.221     www      4314: 	    $r->print(<<ENDINPUTDATE);
1.227     www      4315: <input name="$tempkey\_days" type="text" size="4" value="$days" />$lt{'days'}<br />
1.222     www      4316: <input name="$tempkey\_hours" type="text" size="4" value="$hours" />$lt{'hours'}<br />
                   4317: <input name="$tempkey\_min" type="text" size="4" value="$min" />$lt{'min'}<br />
                   4318: <input name="$tempkey\_sec" type="text" size="4" value="$sec" />$lt{'sec'}
1.221     www      4319: ENDINPUTDATE
                   4320: 	} elsif ($defkeytype{$tempkey} eq 'string_yesno') {
1.222     www      4321:             my $yeschecked='';
                   4322:             my $nochecked='';
                   4323:             if (&rulescache($tempkey.'_value') eq 'yes') { $yeschecked='checked="checked"'; }
                   4324:             if (&rulescache($tempkey.'_value') eq 'no') { $nochecked='checked="checked"'; }
                   4325: 
1.221     www      4326: 	    $r->print(<<ENDYESNO);
1.224     www      4327: <label><input type="radio" name="$tempkey\_value" value="yes" $yeschecked /> $lt{'yes'}</label><br />
                   4328: <label><input type="radio" name="$tempkey\_value" value="no" $nochecked /> $lt{'no'}</label>
1.221     www      4329: ENDYESNO
                   4330:         } else {
1.224     www      4331: 	    $r->print('<input type="text" size="20" name="'.$tempkey.'_value" value="'.&rulescache($tempkey.'_value').'" />');
1.221     www      4332: 	}
1.318     albertel 4333:         $r->print('</td>'.&Apache::loncommon::end_data_table_row());
1.221     www      4334:     }
1.318     albertel 4335:     $r->print(&Apache::loncommon::end_data_table().
1.419     bisitz   4336: 	      "\n".'<input type="submit" name="storerules" value="'.
1.430   ! schafran 4337: 	      &mt('Save').'" /></form>'."\n".
1.280     albertel 4338: 	      &Apache::loncommon::end_page());
1.220     www      4339:     return;
                   4340: }
1.193     albertel 4341: 
1.290     www      4342: sub components {
1.330     albertel 4343:     my ($key,$uname,$udom,$exeuser,$exedomain,$typeflag)=@_;
                   4344: 
                   4345:     if ($typeflag) {
1.290     www      4346: 	$key=~s/\.type$//;
                   4347:     }
1.330     albertel 4348: 
                   4349:     my ($middle,$part,$name)=
                   4350: 	($key=~/^$env{'request.course.id'}\.(?:(.+)\.)*([\w\s]+)\.(\w+)$/);
1.291     www      4351:     my $issection;
1.330     albertel 4352: 
1.290     www      4353:     my $section=&mt('All Students');
                   4354:     if ($middle=~/^\[(.*)\]/) {
1.291     www      4355: 	$issection=$1;
                   4356: 	$section=&mt('Group/Section').': '.$issection;
1.290     www      4357: 	$middle=~s/^\[(.*)\]//;
                   4358:     }
                   4359:     $middle=~s/\.+$//;
                   4360:     $middle=~s/^\.+//;
1.291     www      4361:     if ($uname) {
                   4362: 	$section=&mt('User').": ".&Apache::loncommon::plainname($uname,$udom);
                   4363: 	$issection='';
                   4364:     }
1.316     albertel 4365:     my $realm='<span class="LC_parm_scope_all">'.&mt('All Resources').'</span>';
1.304     www      4366:     my $realmdescription=&mt('all resources'); 
1.290     www      4367:     if ($middle=~/^(.+)\_\_\_\(all\)$/) {
1.316     albertel 4368: 	$realm='<span class="LC_parm_scope_folder">'.&mt('Folder/Map').': '.&Apache::lonnet::gettitle($1).' <span class="LC_parm_folder"><br />('.$1.')</span></span>';
1.304     www      4369:  	$realmdescription=&mt('folder').' '.&Apache::lonnet::gettitle($1);
                   4370:    } elsif ($middle) {
1.290     www      4371: 	my ($map,$id,$url)=&Apache::lonnet::decode_symb($middle);
1.316     albertel 4372: 	$realm='<span class="LC_parm_scope_resource">'.&mt('Resource').': '.&Apache::lonnet::gettitle($middle).' <br /><span class="LC_parm_symb">('.$url.' in '.$map.' id: '.$id.')</span></span>';
1.304     www      4373: 	$realmdescription=&mt('resource').' '.&Apache::lonnet::gettitle($middle);
1.290     www      4374:     }
1.291     www      4375:     my $what=$part.'.'.$name;
1.330     albertel 4376:     return ($realm,$section,$name,$part,
1.304     www      4377: 	    $what,$middle,$uname,$udom,$issection,$realmdescription);
1.290     www      4378: }
1.293     www      4379: 
1.328     albertel 4380: my %standard_parms;
1.416     jms      4381: 
                   4382: 
1.328     albertel 4383: sub load_parameter_names {
                   4384:     open(my $config,"<$Apache::lonnet::perlvar{'lonTabDir'}/packages.tab");
                   4385:     while (my $configline=<$config>) {
                   4386: 	if ($configline !~ /\S/ || $configline=~/^\#/) { next; }
                   4387: 	chomp($configline);
                   4388: 	my ($short,$plain)=split(/:/,$configline);
                   4389: 	my (undef,$name,$type)=split(/\&/,$short,3);
                   4390: 	if ($type eq 'display') {
                   4391: 	    $standard_parms{$name} = $plain;
                   4392: 	}
                   4393:     }
                   4394:     close($config);
                   4395:     $standard_parms{'int_pos'}      = 'Positive Integer';
                   4396:     $standard_parms{'int_zero_pos'} = 'Positive Integer or Zero';
                   4397:     %standard_parms=&Apache::lonlocal::texthash(%standard_parms);	
                   4398: }
                   4399: 
1.292     www      4400: sub standard_parameter_names {
                   4401:     my ($name)=@_;
1.328     albertel 4402:     if (!%standard_parms) {
                   4403: 	&load_parameter_names();
                   4404:     }
1.292     www      4405:     if ($standard_parms{$name}) {
                   4406: 	return $standard_parms{$name}; 
                   4407:     } else { 
                   4408: 	return $name; 
                   4409:     }
                   4410: }
1.290     www      4411: 
1.309     www      4412: 
                   4413: 
1.285     albertel 4414: sub parm_change_log {
1.284     www      4415:     my ($r)=@_;
1.414     droeschl 4416:     &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=settable',
                   4417: 	text=>"Parameter Change Log"});
1.327     albertel 4418:     $r->print(&Apache::loncommon::start_page('Parameter Change Log'));
                   4419:     $r->print(&Apache::lonhtmlcommon::breadcrumbs('Parameter Change Log'));
                   4420: 
1.286     www      4421:     my %parmlog=&Apache::lonnet::dump('nohist_parameterlog',
                   4422: 				      $env{'course.'.$env{'request.course.id'}.'.domain'},
                   4423: 				      $env{'course.'.$env{'request.course.id'}.'.num'});
1.311     albertel 4424: 
1.301     www      4425:     if ((keys(%parmlog))[0]=~/^error\:/) { undef(%parmlog); }
1.311     albertel 4426: 
1.327     albertel 4427:     $r->print('<form action="/adm/parmset?action=parameterchangelog"
                   4428:                      method="post" name="parameterlog">');
1.311     albertel 4429:     
                   4430:     my %saveable_parameters = ('show' => 'scalar',);
                   4431:     &Apache::loncommon::store_course_settings('parameter_log',
                   4432:                                               \%saveable_parameters);
                   4433:     &Apache::loncommon::restore_course_settings('parameter_log',
                   4434:                                                 \%saveable_parameters);
1.348     www      4435:     $r->print(&Apache::loncommon::display_filter().
1.326     www      4436:               '<label>'.&Apache::lonhtmlcommon::checkbox('includetypes',$env{'form.includetypes'},'1').
                   4437: 	      ' '.&mt('Include parameter types').'</label>'.
1.327     albertel 4438: 	      '<input type="submit" value="'.&mt('Display').'" /></form>');
1.301     www      4439: 
1.291     www      4440:     my $courseopt=&Apache::lonnet::get_courseresdata($env{'course.'.$env{'request.course.id'}.'.num'},
                   4441: 						     $env{'course.'.$env{'request.course.id'}.'.domain'});
1.301     www      4442:     $r->print(&Apache::loncommon::start_data_table().&Apache::loncommon::start_data_table_header_row().
                   4443: 	      '<th>'.&mt('Time').'</th><th>'.&mt('User').'</th><th>'.&mt('Extent').'</th><th>'.&mt('Users').'</th><th>'.
                   4444: 	      &mt('Parameter').'</th><th>'.&mt('Part').'</th><th>'.&mt('New Value').'</th><th>'.&mt('Announce').'</th>'.
                   4445: 	      &Apache::loncommon::end_data_table_header_row());
1.309     www      4446:     my $shown=0;
1.349     www      4447:     my $folder='';
                   4448:     if ($env{'form.displayfilter'} eq 'currentfolder') {
                   4449: 	my $last='';
                   4450: 	if (tie(my %hash,'GDBM_File',$env{'request.course.fn'}.'_symb.db',
                   4451: 		&GDBM_READER(),0640)) {
                   4452: 	    $last=$hash{'last_known'};
                   4453: 	    untie(%hash);
                   4454: 	}
                   4455: 	if ($last) { ($folder) = &Apache::lonnet::decode_symb($last); }
                   4456:     }
1.356     albertel 4457:     foreach my $id (sort 
                   4458: 		    {
                   4459: 			if ($parmlog{$b}{'exe_time'} ne $parmlog{$a}{'exe_time'}) {
                   4460: 			    return $parmlog{$b}{'exe_time'} <=>$parmlog{$a}{'exe_time'}
                   4461: 			}
                   4462: 			my $aid = (split('00000',$a))[-1];
                   4463: 			my $bid = (split('00000',$b))[-1];
                   4464: 			return $bid<=>$aid;
                   4465: 		    } (keys(%parmlog))) {
1.294     www      4466:         my @changes=keys(%{$parmlog{$id}{'logentry'}});
1.332     albertel 4467: 	my $count = 0;
1.288     albertel 4468: 	my $time =
1.294     www      4469: 	    &Apache::lonlocal::locallocaltime($parmlog{$id}{'exe_time'});
1.289     www      4470: 	my $plainname = 
1.294     www      4471: 	    &Apache::loncommon::plainname($parmlog{$id}{'exe_uname'},
                   4472: 					  $parmlog{$id}{'exe_udom'});
1.288     albertel 4473: 	my $about_me_link = 
1.289     www      4474: 	    &Apache::loncommon::aboutmewrapper($plainname,
1.294     www      4475: 					       $parmlog{$id}{'exe_uname'},
                   4476: 					       $parmlog{$id}{'exe_udom'});
1.293     www      4477: 	my $send_msg_link='';
1.294     www      4478: 	if ((($parmlog{$id}{'exe_uname'} ne $env{'user.name'}) 
                   4479: 	     || ($parmlog{$id}{'exe_udom'} ne $env{'user.domain'}))) {
1.293     www      4480: 	    $send_msg_link ='<br />'.
1.288     albertel 4481: 		&Apache::loncommon::messagewrapper(&mt('Send message'),
1.294     www      4482: 						   $parmlog{$id}{'exe_uname'},
                   4483: 						   $parmlog{$id}{'exe_udom'});
1.288     albertel 4484: 	}
1.301     www      4485: 	my $row_start=&Apache::loncommon::start_data_table_row();
1.290     www      4486: 	my $makenewrow=0;
                   4487: 	my %istype=();
1.332     albertel 4488: 	my $output;
1.293     www      4489: 	foreach my $changed (reverse(sort(@changes))) {
1.330     albertel 4490:             my $value=$parmlog{$id}{'logentry'}{$changed};
1.331     albertel 4491: 	    my $typeflag = ($changed =~/\.type$/ &&
                   4492: 			    !exists($parmlog{$id}{'logentry'}{$changed.'.type'}));
1.330     albertel 4493:             my ($realm,$section,$parmname,$part,$what,$middle,$uname,$udom,$issection,$realmdescription)=
                   4494: 		&components($changed,$parmlog{$id}{'uname'},$parmlog{$id}{'udom'},undef,undef,$typeflag);
1.349     www      4495: 	    if ($env{'form.displayfilter'} eq 'currentfolder') {
                   4496: 		if ($folder) {
                   4497: 		    if ($middle!~/^\Q$folder\E/) { next; }
                   4498: 		}
                   4499: 	    }
1.326     www      4500: 	    if ($typeflag) {
1.329     albertel 4501: 		$istype{$parmname}=$value; 
1.326     www      4502: 		if (!$env{'form.includetypes'}) { next; } 
                   4503: 	    }
1.332     albertel 4504: 	    $count++;
                   4505: 	    if ($makenewrow) {
                   4506: 		$output .= $row_start;
                   4507: 	    } else {
                   4508: 		$makenewrow=1;
                   4509: 	    }
                   4510: 	    $output .='<td>'.$realm.'</td><td>'.$section.'</td><td>'.
1.292     www      4511: 		      &standard_parameter_names($parmname).'</td><td>'.
1.332     albertel 4512: 		      ($part?&mt('Part: [_1]',$part):&mt('All Parts')).'</td><td>';
1.291     www      4513: 	    my $stillactive=0;
1.332     albertel 4514: 	    if ($parmlog{$id}{'delflag'}) {
                   4515: 		$output .= &mt('Deleted');
1.288     albertel 4516: 	    } else {
1.290     www      4517: 		if ($typeflag) {
1.332     albertel 4518: 		    $output .= &mt('Type: [_1]',&standard_parameter_names($value));
1.290     www      4519: 		} else {
1.291     www      4520: 		    my ($level,@all)=&parmval_by_symb($what,$middle,&Apache::lonnet::metadata($middle,$what),
                   4521: 						      $uname,$udom,$issection,$issection,$courseopt);
                   4522: 		    if (&isdateparm($istype{$parmname})) {
1.332     albertel 4523: 			$output .= &Apache::lonlocal::locallocaltime($value);
1.291     www      4524: 		    } else {
1.332     albertel 4525: 			$output .= $value;
1.291     www      4526: 		    }
                   4527: 		    if ($value ne $all[$level]) {
1.332     albertel 4528: 			$output .= '<br /><span class="LC_warning">'.&mt('Not active anymore').'</span>';
1.291     www      4529: 		    } else {
                   4530: 			$stillactive=1;
                   4531: 		    }
1.290     www      4532: 		}
1.288     albertel 4533: 	    }
1.332     albertel 4534: 	    $output .= '</td><td>';
1.291     www      4535: 	    if ($stillactive) {
1.304     www      4536: 		my $title=&mt('Changed [_1]',&standard_parameter_names($parmname));
                   4537:                 my $description=&mt('Changed [_1] for [_2] to [_3]',&standard_parameter_names($parmname),$realmdescription,
                   4538: 				    (&isdateparm($istype{$parmname})?&Apache::lonlocal::locallocaltime($value):$value));
1.292     www      4539: 		if (($uname) && ($udom)) {
1.332     albertel 4540: 		    $output .= 
                   4541: 			&Apache::loncommon::messagewrapper('Notify User',
                   4542: 							   $uname,$udom,$title,
                   4543: 							   $description);
1.292     www      4544: 		} else {
1.332     albertel 4545: 		    $output .= 
                   4546: 			&Apache::lonrss::course_blog_link($id,$title,
                   4547: 							  $description);
1.292     www      4548: 		}
1.291     www      4549: 	    }
1.332     albertel 4550: 	    $output .= '</td>'.&Apache::loncommon::end_data_table_row();
1.288     albertel 4551: 	}
1.349     www      4552:         if ($env{'form.displayfilter'} eq 'containing') {
                   4553: 	    my $wholeentry=$about_me_link.':'.
                   4554: 		$parmlog{$id}{'exe_uname'}.':'.$parmlog{$id}{'exe_udom'}.':'.
                   4555: 		$output;
                   4556: 	    if ($wholeentry!~/\Q$env{'form.containingphrase'}\E/i) { next; }        
                   4557: 	}
                   4558:         if ($count) {
                   4559: 	    $r->print($row_start.'<td rowspan="'.$count.'">'.$time.'</td>
1.332     albertel 4560:                        <td rowspan="'.$count.'">'.$about_me_link.
                   4561: 		  '<br /><tt>'.$parmlog{$id}{'exe_uname'}.
                   4562: 			          ':'.$parmlog{$id}{'exe_udom'}.'</tt>'.
                   4563: 		  $send_msg_link.'</td>'.$output);
1.349     www      4564: 	    $shown++;
                   4565: 	}
1.311     albertel 4566: 	if (!($env{'form.show'} eq &mt('all') 
                   4567: 	      || $shown<=$env{'form.show'})) { last; }
1.286     www      4568:     }
1.301     www      4569:     $r->print(&Apache::loncommon::end_data_table());
1.284     www      4570:     $r->print(&Apache::loncommon::end_page());
                   4571: }
                   4572: 
1.355     albertel 4573: sub check_for_course_info {
                   4574:     my $navmap = Apache::lonnavmaps::navmap->new();
                   4575:     return 1 if ($navmap);
                   4576:     return 0;
                   4577: }
                   4578: 
1.259     banghart 4579: 
1.30      www      4580: sub handler {
1.43      albertel 4581:     my $r=shift;
1.30      www      4582: 
1.376     albertel 4583:     &reset_caches();
                   4584: 
1.414     droeschl 4585:     &Apache::loncommon::content_type($r,'text/html');
                   4586:     $r->send_http_header;
                   4587:     return OK if $r->header_only;
                   4588: 
1.193     albertel 4589:     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
1.205     www      4590: 					    ['action','state',
                   4591:                                              'pres_marker',
                   4592:                                              'pres_value',
1.206     www      4593:                                              'pres_type',
1.390     www      4594:                                              'udom','uname','symb','serial','timebase']);
1.131     www      4595: 
1.83      bowersj2 4596: 
1.193     albertel 4597:     &Apache::lonhtmlcommon::clear_breadcrumbs();
1.194     albertel 4598:     &Apache::lonhtmlcommon::add_breadcrumb({href=>"/adm/parmset",
                   4599: 					    text=>"Parameter Manager",
1.204     www      4600: 					    faq=>10,
1.324     www      4601: 					    bug=>'Instructor Interface',
                   4602:                                             help => 'Parameter_Manager'});
1.203     www      4603: 
1.30      www      4604: # ----------------------------------------------------- Needs to be in a course
1.194     albertel 4605:     my $parm_permission =
                   4606: 	(&Apache::lonnet::allowed('opa',$env{'request.course.id'}) ||
1.190     albertel 4607: 	 &Apache::lonnet::allowed('opa',$env{'request.course.id'}.'/'.
1.193     albertel 4608: 				  $env{'request.course.sec'}));
1.355     albertel 4609:     my $exists = &check_for_course_info();
                   4610: 
                   4611:     if ($env{'request.course.id'} &&  $parm_permission && $exists) {
1.193     albertel 4612:         #
                   4613:         # Main switch on form.action and form.state, as appropriate
                   4614:         #
                   4615:         # Check first if coming from someone else headed directly for
                   4616:         #  the table mode
                   4617:         if ((($env{'form.command'} eq 'set') && ($env{'form.url'})
                   4618: 	     && (!$env{'form.dis'})) || ($env{'form.symb'})) {
                   4619: 	    &assessparms($r);
                   4620:         } elsif (! exists($env{'form.action'})) {
                   4621:             &print_main_menu($r,$parm_permission);
1.414     droeschl 4622:         } elsif ($env{'form.action'} eq 'crsenv') {
1.193     albertel 4623:             &crsenv($r); 
1.414     droeschl 4624:         } elsif ($env{'form.action'} eq 'setoverview') {
1.121     www      4625: 	    &overview($r);
1.414     droeschl 4626: 	} elsif ($env{'form.action'} eq 'addmetadata') {
1.334     banghart 4627: 	    &addmetafield($r);
1.414     droeschl 4628: 	} elsif ($env{'form.action'} eq 'ordermetadata') {
1.340     banghart 4629: 	    &order_meta_fields($r);
1.414     droeschl 4630:         } elsif ($env{'form.action'} eq 'setrestrictmeta') {
1.259     banghart 4631: 	    &setrestrictmeta($r);
1.414     droeschl 4632:         } elsif ($env{'form.action'} eq 'newoverview') {
1.208     www      4633: 	    &newoverview($r);
1.414     droeschl 4634:         } elsif ($env{'form.action'} eq 'setdefaults') {
1.220     www      4635: 	    &defaultsetter($r);
1.414     droeschl 4636: 	} elsif ($env{'form.action'} eq 'settable') {
1.121     www      4637: 	    &assessparms($r);
1.414     droeschl 4638:         } elsif ($env{'form.action'} eq 'parameterchangelog') {
1.285     albertel 4639: 	    &parm_change_log($r);
1.414     droeschl 4640:         } elsif ($env{'form.action'} eq 'cleanparameters') {
1.333     albertel 4641: 	    &clean_parameters($r);
1.414     droeschl 4642:         } elsif ($env{'form.action'} eq 'dateshift1') {
1.390     www      4643:             &date_shift_one($r);
1.414     droeschl 4644:         } elsif ($env{'form.action'} eq 'dateshift2') {
1.390     www      4645:             &date_shift_two($r);
1.414     droeschl 4646: 	} elsif ($env{'form.action'} eq 'categorizecourse') {
1.403     raeburn  4647:             &assign_course_categories($r);
                   4648:         } 
1.43      albertel 4649:     } else {
1.1       www      4650: # ----------------------------- Not in a course, or not allowed to modify parms
1.355     albertel 4651: 	if ($exists) {
                   4652: 	    $env{'user.error.msg'}=
                   4653: 		"/adm/parmset:opa:0:0:Cannot modify assessment parameters";
                   4654: 	} else {
                   4655: 	    $env{'user.error.msg'}=
                   4656: 		"/adm/parmset::0:1:Course environment gone, reinitialize the course";
                   4657: 	}
1.43      albertel 4658: 	return HTTP_NOT_ACCEPTABLE;
                   4659:     }
1.376     albertel 4660:     &reset_caches();
                   4661: 
1.43      albertel 4662:     return OK;
1.1       www      4663: }
                   4664: 
                   4665: 1;
                   4666: __END__
                   4667: 
                   4668: 

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