Annotation of loncom/interface/lonparmset.pm, revision 1.135
1.1 www 1: # The LearningOnline Network with CAPA
2: # Handler to set parameters for assessments
3: #
1.135 ! albertel 4: # $Id: lonparmset.pm,v 1.134 2003/11/10 16:33:57 albertel 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:
47: =over 4
48:
49: =cut
50:
51: ###################################################################
52: ###################################################################
1.1 www 53:
54: package Apache::lonparmset;
55:
56: use strict;
57: use Apache::lonnet;
58: use Apache::Constants qw(:common :http REDIRECT);
1.88 matthew 59: use Apache::lonhtmlcommon();
1.36 albertel 60: use Apache::loncommon;
1.1 www 61: use GDBM_File;
1.57 albertel 62: use Apache::lonhomework;
63: use Apache::lonxml;
1.130 www 64: use Apache::lonlocal;
1.1 www 65:
1.2 www 66: my %courseopt;
67: my %useropt;
68: my %parmhash;
69:
1.3 www 70: my @ids;
71: my %symbp;
1.10 www 72: my %mapp;
1.3 www 73: my %typep;
1.16 www 74: my %keyp;
1.2 www 75:
1.82 www 76: my %maptitles;
77:
1.2 www 78: my $uname;
79: my $udom;
80: my $uhome;
81: my $csec;
1.57 albertel 82: my $coursename;
1.2 www 83:
1.59 matthew 84: ##################################################
85: ##################################################
86:
87: =pod
88:
89: =item parmval
90:
91: Figure out a cascading parameter.
92:
1.71 albertel 93: Inputs: $what - a parameter spec (incluse part info and name I.E. 0.weight)
94: $id - a bighash Id number
95: $def - the resource's default value 'stupid emacs
96:
97: 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 11 possible levels
98:
99: 11- resource default
100: 10- map default
101: 9 - General Course
1.82 www 102: 8 - Map or Folder level in course
1.71 albertel 103: 7 - resource level in course
104: 6 - General for section
1.82 www 105: 5 - Map or Folder level for section
1.71 albertel 106: 4 - resource level in section
107: 3 - General for specific student
1.82 www 108: 2 - Map or Folder level for specific student
1.71 albertel 109: 1 - resource level for specific student
1.2 www 110:
1.59 matthew 111: =cut
112:
113: ##################################################
114: ##################################################
1.2 www 115: sub parmval {
1.11 www 116: my ($what,$id,$def)=@_;
1.8 www 117: my $result='';
1.44 albertel 118: my @outpar=();
1.2 www 119: # ----------------------------------------------------- Cascading lookup scheme
1.10 www 120:
1.43 albertel 121: my $symbparm=$symbp{$id}.'.'.$what;
122: my $mapparm=$mapp{$id}.'___(all).'.$what;
1.10 www 123:
1.43 albertel 124: my $seclevel=$ENV{'request.course.id'}.'.['.$csec.'].'.$what;
125: my $seclevelr=$ENV{'request.course.id'}.'.['.$csec.'].'.$symbparm;
126: my $seclevelm=$ENV{'request.course.id'}.'.['.$csec.'].'.$mapparm;
127:
128: my $courselevel=$ENV{'request.course.id'}.'.'.$what;
129: my $courselevelr=$ENV{'request.course.id'}.'.'.$symbparm;
130: my $courselevelm=$ENV{'request.course.id'}.'.'.$mapparm;
1.2 www 131:
1.11 www 132: # -------------------------------------------------------- first, check default
133:
1.43 albertel 134: if ($def) { $outpar[11]=$def; $result=11; }
1.11 www 135:
136: # ----------------------------------------------------- second, check map parms
137:
1.43 albertel 138: my $thisparm=$parmhash{$symbparm};
139: if ($thisparm) { $outpar[10]=$thisparm; $result=10; }
1.11 www 140:
141: # --------------------------------------------------------- third, check course
142:
1.71 albertel 143: if (defined($courseopt{$courselevel})) {
1.43 albertel 144: $outpar[9]=$courseopt{$courselevel};
145: $result=9;
146: }
1.11 www 147:
1.71 albertel 148: if (defined($courseopt{$courselevelm})) {
1.43 albertel 149: $outpar[8]=$courseopt{$courselevelm};
150: $result=8;
151: }
1.11 www 152:
1.71 albertel 153: if (defined($courseopt{$courselevelr})) {
1.43 albertel 154: $outpar[7]=$courseopt{$courselevelr};
155: $result=7;
156: }
1.11 www 157:
1.71 albertel 158: if (defined($csec)) {
159: if (defined($courseopt{$seclevel})) {
1.43 albertel 160: $outpar[6]=$courseopt{$seclevel};
161: $result=6;
162: }
1.71 albertel 163: if (defined($courseopt{$seclevelm})) {
1.43 albertel 164: $outpar[5]=$courseopt{$seclevelm};
165: $result=5;
166: }
167:
1.71 albertel 168: if (defined($courseopt{$seclevelr})) {
1.43 albertel 169: $outpar[4]=$courseopt{$seclevelr};
170: $result=4;
171: }
172: }
1.11 www 173:
174: # ---------------------------------------------------------- fourth, check user
175:
1.71 albertel 176: if (defined($uname)) {
177: if (defined($useropt{$courselevel})) {
1.43 albertel 178: $outpar[3]=$useropt{$courselevel};
179: $result=3;
180: }
1.10 www 181:
1.71 albertel 182: if (defined($useropt{$courselevelm})) {
1.43 albertel 183: $outpar[2]=$useropt{$courselevelm};
184: $result=2;
185: }
1.2 www 186:
1.71 albertel 187: if (defined($useropt{$courselevelr})) {
1.43 albertel 188: $outpar[1]=$useropt{$courselevelr};
189: $result=1;
190: }
191: }
1.44 albertel 192: return ($result,@outpar);
1.2 www 193: }
194:
1.59 matthew 195: ##################################################
196: ##################################################
197:
198: =pod
199:
200: =item valout
201:
202: Format a value for output.
203:
204: Inputs: $value, $type
205:
206: Returns: $value, formatted for output. If $type indicates it is a date,
207: localtime($value) is returned.
1.9 www 208:
1.59 matthew 209: =cut
210:
211: ##################################################
212: ##################################################
1.9 www 213: sub valout {
214: my ($value,$type)=@_;
1.59 matthew 215: my $result = '';
216: # Values of zero are valid.
217: if (! $value && $value ne '0') {
1.71 albertel 218: $result = ' ';
1.59 matthew 219: } else {
1.66 www 220: if ($type eq 'date_interval') {
221: my ($sec,$min,$hour,$mday,$mon,$year)=gmtime($value);
222: $year=$year-70;
223: $mday--;
224: if ($year) {
225: $result.=$year.' yrs ';
226: }
227: if ($mon) {
228: $result.=$mon.' mths ';
229: }
230: if ($mday) {
231: $result.=$mday.' days ';
232: }
233: if ($hour) {
234: $result.=$hour.' hrs ';
235: }
236: if ($min) {
237: $result.=$min.' mins ';
238: }
239: if ($sec) {
240: $result.=$sec.' secs ';
241: }
242: $result=~s/\s+$//;
243: } elsif ($type=~/^date/) {
1.59 matthew 244: $result = localtime($value);
245: } else {
246: $result = $value;
247: }
248: }
249: return $result;
1.9 www 250: }
251:
1.59 matthew 252: ##################################################
253: ##################################################
254:
255: =pod
1.5 www 256:
1.59 matthew 257: =item plink
258:
259: Produces a link anchor.
260:
261: Inputs: $type,$dis,$value,$marker,$return,$call
262:
263: Returns: scalar with html code for a link which will envoke the
264: javascript function 'pjump'.
265:
266: =cut
267:
268: ##################################################
269: ##################################################
1.5 www 270: sub plink {
271: my ($type,$dis,$value,$marker,$return,$call)=@_;
1.23 www 272: my $winvalue=$value;
273: unless ($winvalue) {
274: if ($type=~/^date/) {
275: $winvalue=$ENV{'form.recent_'.$type};
276: } else {
277: $winvalue=$ENV{'form.recent_'.(split(/\_/,$type))[0]};
278: }
279: }
280: return
1.43 albertel 281: '<a href="javascript:pjump('."'".$type."','".$dis."','".$winvalue."','"
282: .$marker."','".$return."','".$call."'".');">'.
283: &valout($value,$type).'</a><a name="'.$marker.'"></a>';
1.5 www 284: }
285:
1.44 albertel 286:
287: sub startpage {
1.99 albertel 288: my ($r,$id,$udom,$csec,$uname,$have_assesments)=@_;
289:
1.120 www 290: my $bodytag=&Apache::loncommon::bodytag('Set/Modify Course Parameters','',
1.98 www 291: 'onUnload="pclose()"');
1.81 www 292: my $chooseopt=&Apache::loncommon::select_dom_form($udom,'udom').' '.
293: &Apache::loncommon::selectstudent_link('parmform','uname','udom');
294: my $selscript=&Apache::loncommon::studentbrowser_javascript();
1.88 matthew 295: my $pjump_def = &Apache::lonhtmlcommon::pjump_javascript_definition();
1.133 www 296: my %lt=&Apache::lonlocal::texthash(
297: 'cep' => "Course Environment Parameters",
298: 'scep' => "Set Course Environment Parameters",
299: 'smcap' => "Set/Modify Course Assessment Parameter",
300: 'mcap' => "Modify Course Assessment Parameters",
301: 'caphm' => "Course Assessment Parameter - Helper Mode",
302: 'capom' => "Course Assessment Parameters - Overview Mode",
303: 'captm' => "Course Assessments Parameters - Table Mode",
304: 'sg' => "Section/Group",
305: 'fu' => "For User",
306: 'oi' => "or ID",
307: 'ad' => "at Domain"
308: );
1.44 albertel 309: $r->print(<<ENDHEAD);
310: <html>
311: <head>
312: <title>LON-CAPA Course Parameters</title>
313: <script>
314:
315: function pclose() {
316: parmwin=window.open("/adm/rat/empty.html","LONCAPAparms",
317: "height=350,width=350,scrollbars=no,menubar=no");
318: parmwin.close();
319: }
320:
1.88 matthew 321: $pjump_def
1.44 albertel 322:
323: function psub() {
324: pclose();
325: if (document.parmform.pres_marker.value!='') {
326: document.parmform.action+='#'+document.parmform.pres_marker.value;
327: var typedef=new Array();
328: typedef=document.parmform.pres_type.value.split('_');
329: if (document.parmform.pres_type.value!='') {
330: if (typedef[0]=='date') {
331: eval('document.parmform.recent_'+
332: document.parmform.pres_type.value+
333: '.value=document.parmform.pres_value.value;');
334: } else {
335: eval('document.parmform.recent_'+typedef[0]+
336: '.value=document.parmform.pres_value.value;');
337: }
338: }
339: document.parmform.submit();
340: } else {
341: document.parmform.pres_value.value='';
342: document.parmform.pres_marker.value='';
343: }
344: }
345:
1.57 albertel 346: function openWindow(url, wdwName, w, h, toolbar,scrollbar) {
347: var options = "width=" + w + ",height=" + h + ",";
348: options += "resizable=yes,scrollbars="+scrollbar+",status=no,";
349: options += "menubar=no,toolbar="+toolbar+",location=no,directories=no";
350: var newWin = window.open(url, wdwName, options);
351: newWin.focus();
352: }
1.44 albertel 353: </script>
1.81 www 354: $selscript
1.44 albertel 355: </head>
1.64 www 356: $bodytag
1.91 bowersj2 357:
1.44 albertel 358: <form method="post" action="/adm/parmset" name="envform">
1.133 www 359: <h4>$lt{'cep'}</h4>
360: <input type="submit" name="crsenv" value="$lt{'scep'}" />
1.120 www 361: </form>
362: <hr />
363: <form method="post" action="/adm/helper/parameter.helper" name="helpform">
1.133 www 364: <h4>$lt{'caphm'}</h4>
365: <input type="submit" value="$lt{'smcap'}" />
1.120 www 366: </form>
367: <hr />
368: <form method="post" action="/adm/parmset" name="overview">
1.133 www 369: <h4>$lt{'capom'}</h4>
370: <input type="submit" name="overview" value="$lt{'mcap'}" />
1.44 albertel 371: </form>
1.101 www 372: <hr />
1.44 albertel 373: <form method="post" action="/adm/parmset" name="parmform">
1.133 www 374: <h4>$lt{'captm'}</h4>
1.99 albertel 375: ENDHEAD
376:
377: if (!$have_assesments) {
1.133 www 378: $r->print('<font color="red">'.&mt('There are no assesment parameters in this course to set.').'</font><br />');
1.99 albertel 379: } else {
380: $r->print(<<ENDHEAD);
1.44 albertel 381: <b>
1.133 www 382: $lt{'sg'}:
1.44 albertel 383: <input type="text" value="$csec" size="6" name="csec">
384: <br>
1.133 www 385: $lt{'fu'}
1.44 albertel 386: <input type="text" value="$uname" size="12" name="uname">
1.133 www 387: $lt{'oi'}
1.44 albertel 388: <input type="text" value="$id" size="12" name="id">
1.133 www 389: $lt{'ad'}
1.81 www 390: $chooseopt
1.44 albertel 391: </b>
392: <input type="hidden" value='' name="pres_value">
393: <input type="hidden" value='' name="pres_type">
394: <input type="hidden" value='' name="pres_marker">
395: ENDHEAD
1.99 albertel 396: }
1.44 albertel 397: }
398:
399: sub print_row {
1.66 www 400: my ($r,$which,$part,$name,$rid,$default,$defaulttype,$display,$defbgone,
1.57 albertel 401: $defbgtwo,$parmlev)=@_;
1.66 www 402: # get the values for the parameter in cascading order
403: # empty levels will remain empty
1.44 albertel 404: my ($result,@outpar)=&parmval($$part{$which}.'.'.$$name{$which},
405: $rid,$$default{$which});
1.66 www 406: # get the type for the parameters
407: # problem: these may not be set for all levels
408: my ($typeresult,@typeoutpar)=&parmval($$part{$which}.'.'.
409: $$name{$which}.'.type',
410: $rid,$$defaulttype{$which});
411: # cascade down manually
412: my $cascadetype=$defaulttype;
413: for (my $i=$#typeoutpar;$i>0;$i--) {
414: if ($typeoutpar[$i]) {
415: $cascadetype=$typeoutpar[$i];
416: } else {
417: $typeoutpar[$i]=$cascadetype;
418: }
419: }
420:
1.57 albertel 421: my $parm=$$display{$which};
422:
423: if ($parmlev eq 'full' || $parmlev eq 'brief') {
424: $r->print('<td bgcolor='.$defbgtwo.' align="center">'
425: .$$part{$which}.'</td>');
426: } else {
427: $parm=~s|\[.*\]\s||g;
428: }
429:
430: $r->print('<td bgcolor='.$defbgone.'>'.$parm.'</td>');
431:
1.44 albertel 432: my $thismarker=$which;
433: $thismarker=~s/^parameter\_//;
434: my $mprefix=$rid.'&'.$thismarker.'&';
435:
1.57 albertel 436: if ($parmlev eq 'general') {
437:
438: if ($uname) {
1.66 www 439: &print_td($r,3,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57 albertel 440: } elsif ($csec) {
1.66 www 441: &print_td($r,6,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57 albertel 442: } else {
1.66 www 443: &print_td($r,9,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57 albertel 444: }
445: } elsif ($parmlev eq 'map') {
446:
447: if ($uname) {
1.66 www 448: &print_td($r,2,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57 albertel 449: } elsif ($csec) {
1.66 www 450: &print_td($r,5,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57 albertel 451: } else {
1.66 www 452: &print_td($r,8,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57 albertel 453: }
454: } else {
455:
1.66 www 456: &print_td($r,11,'#FFDDDD',$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57 albertel 457:
458: if ($parmlev eq 'brief') {
459:
1.66 www 460: &print_td($r,7,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57 albertel 461:
462: if ($csec) {
1.66 www 463: &print_td($r,4,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57 albertel 464: }
465: if ($uname) {
1.66 www 466: &print_td($r,1,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57 albertel 467: }
468: } else {
469:
1.66 www 470: &print_td($r,10,'#FFDDDD',$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
471: &print_td($r,9,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
472: &print_td($r,8,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
473: &print_td($r,7,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57 albertel 474:
475: if ($csec) {
1.66 www 476: &print_td($r,6,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
477: &print_td($r,5,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
478: &print_td($r,4,$defbgtwo,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57 albertel 479: }
480: if ($uname) {
1.66 www 481: &print_td($r,3,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
482: &print_td($r,2,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
483: &print_td($r,1,$defbgone,$result,\@outpar,$mprefix,$_,\@typeoutpar,$display);
1.57 albertel 484: }
485: } # end of $brief if/else
486: } # end of $parmlev if/else
487:
488: if ($parmlev eq 'full' || $parmlev eq 'brief') {
1.59 matthew 489: $r->print('<td bgcolor=#CCCCFF align="center">'.
1.66 www 490: &valout($outpar[$result],$typeoutpar[$result]).'</td>');
1.59 matthew 491: }
1.44 albertel 492: my $sessionval=&Apache::lonnet::EXT('resource.'.$$part{$which}.
1.57 albertel 493: '.'.$$name{$which},$symbp{$rid});
1.70 albertel 494: # this doesn't seem to work, and I don't think is correct
495: # my $sessionvaltype=&Apache::lonnet::EXT('resource.'.$$part{$which}.
496: # '.'.$$name{$which}.'.type',$symbp{$rid});
497: # this seems to work
498: my $sessionvaltype=$typeoutpar[$result];
1.72 albertel 499: if (!defined($sessionvaltype)) { $sessionvaltype=$$defaulttype{$which}; }
1.57 albertel 500: $r->print('<td bgcolor=#999999 align="center"><font color=#FFFFFF>'.
1.66 www 501: &valout($sessionval,$sessionvaltype).' '.
1.57 albertel 502: '</font></td>');
1.44 albertel 503: $r->print('</tr>');
1.57 albertel 504: $r->print("\n");
1.44 albertel 505: }
1.59 matthew 506:
1.44 albertel 507: sub print_td {
1.66 www 508: my ($r,$which,$defbg,$result,$outpar,$mprefix,$value,$typeoutpar,$display)=@_;
1.57 albertel 509: $r->print('<td bgcolor='.(($result==$which)?'"#AAFFAA"':$defbg).
1.114 www 510: ' align="center">');
511: if ($which<10) {
512: $r->print(&plink($$typeoutpar[$which],
513: $$display{$value},$$outpar[$which],
514: $mprefix."$which",'parmform.pres','psub'));
515: } else {
516: $r->print(&valout($$outpar[$which],$$typeoutpar[$which]));
517: }
518: $r->print('</td>'."\n");
1.57 albertel 519: }
520:
1.63 bowersj2 521: =pod
522:
523: =item B<extractResourceInformation>: Given the course data hash, extractResourceInformation extracts lots of information about the course's resources into a variety of hashes.
524:
525: Input: See list below:
526:
527: =over 4
528:
529: =item B<ids>: An array that will contain all of the ids in the course.
530:
531: =item B<typep>: hash, id->type, where "type" contains the extension of the file, thus, I<problem exam quiz assess survey form>.
532:
533: =item B<keyp>: hash, id->key list, will contain a comma seperated list of the meta-data keys available for the given id
534:
535: =item B<allparms>: hash, name of parameter->display value (what is the display value?)
536:
537: =item B<allparts>: hash, part identification->text representation of part, where the text representation is "[Part $part]"
538:
539: =item B<allkeys>: hash, full key to part->display value (what's display value?)
540:
541: =item B<allmaps>: hash, ???
542:
543: =item B<fcat>: ???
544:
545: =item B<defp>: hash, ???
546:
547: =item B<mapp>: ??
548:
549: =item B<symbp>: hash, id->full sym?
550:
551: =back
552:
553: =cut
554:
555: sub extractResourceInformation {
556: my $bighash = shift;
557: my $ids = shift;
558: my $typep = shift;
559: my $keyp = shift;
560: my $allparms = shift;
561: my $allparts = shift;
562: my $allkeys = shift;
563: my $allmaps = shift;
564: my $fcat = shift;
565: my $defp = shift;
566: my $mapp = shift;
567: my $symbp = shift;
1.82 www 568: my $maptitles=shift;
1.63 bowersj2 569:
570: foreach (keys %$bighash) {
571: if ($_=~/^src\_(\d+)\.(\d+)$/) {
572: my $mapid=$1;
573: my $resid=$2;
574: my $id=$mapid.'.'.$resid;
575: my $srcf=$$bighash{$_};
576: if ($srcf=~/\.(problem|exam|quiz|assess|survey|form)$/) {
577: $$ids[$#$ids+1]=$id;
578: $$typep{$id}=$1;
579: $$keyp{$id}='';
1.65 albertel 580: foreach (split(/\,/,&Apache::lonnet::metadata($srcf,'allpossiblekeys'))) {
1.63 bowersj2 581: if ($_=~/^parameter\_(.*)/) {
582: my $key=$_;
583: my $allkey=$1;
584: $allkey=~s/\_/\./g;
585: my $display= &Apache::lonnet::metadata($srcf,$key.'.display');
586: my $name=&Apache::lonnet::metadata($srcf,$key.'.name');
587: my $part= &Apache::lonnet::metadata($srcf,$key.'.part');
588: my $parmdis = $display;
589: $parmdis =~ s|(\[Part.*$)||g;
590: my $partkey = $part;
591: $partkey =~ tr|_|.|;
592: $$allparms{$name} = $parmdis;
593: $$allparts{$part} = "[Part $part]";
594: $$allkeys{$allkey}=$display;
595: if ($allkey eq $fcat) {
596: $$defp{$id}= &Apache::lonnet::metadata($srcf,$key);
597: }
598: if ($$keyp{$id}) {
599: $$keyp{$id}.=','.$key;
600: } else {
601: $$keyp{$id}=$key;
602: }
603: }
604: }
605: $$mapp{$id}=
606: &Apache::lonnet::declutter($$bighash{'map_id_'.$mapid});
607: $$mapp{$mapid}=$$mapp{$id};
608: $$allmaps{$mapid}=$$mapp{$id};
1.82 www 609: $$maptitles{$mapid}=
610: $$bighash{'title_'.$$bighash{'ids_'.&Apache::lonnet::clutter($$mapp{$id})}};
611: $$maptitles{$$mapp{$id}}=$$maptitles{$mapid};
1.63 bowersj2 612: $$symbp{$id}=$$mapp{$id}.
613: '___'.$resid.'___'.
614: &Apache::lonnet::declutter($srcf);
615: $$symbp{$mapid}=$$mapp{$id}.'___(all)';
616: }
617: }
618: }
619: }
620:
1.59 matthew 621: ##################################################
622: ##################################################
623:
624: =pod
625:
626: =item assessparms
627:
628: Show assessment data and parameters. This is a large routine that should
629: be simplified and shortened... someday.
630:
631: Inputs: $r
632:
633: Returns: nothing
634:
1.63 bowersj2 635: Variables used (guessed by Jeremy):
636:
637: =over 4
638:
639: =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.
640:
641: =item B<psprt>: ParameterS PaRTs? a list of the parts of a problem that we are displaying? Used to display only selected parts?
642:
643: =item B<allmaps>:
644:
645: =back
646:
1.59 matthew 647: =cut
648:
649: ##################################################
650: ##################################################
1.30 www 651: sub assessparms {
1.1 www 652:
1.43 albertel 653: my $r=shift;
1.2 www 654: # -------------------------------------------------------- Variable declaration
1.129 www 655: my %allkeys=();
656: my %allmaps=();
657: my %alllevs=();
1.57 albertel 658:
659: $alllevs{'Resource Level'}='full';
660: # $alllevs{'Resource Level [BRIEF]'}='brief';
661: $alllevs{'Map Level'}='map';
662: $alllevs{'Course Level'}='general';
663:
664: my %allparms;
665: my %allparts;
666:
1.43 albertel 667: my %defp;
668: %courseopt=();
669: %useropt=();
1.44 albertel 670: my %bighash=();
1.43 albertel 671:
672: @ids=();
673: %symbp=();
674: %typep=();
675:
676: my $message='';
677:
678: $csec=$ENV{'form.csec'};
679: $udom=$ENV{'form.udom'};
680: unless ($udom) { $udom=$r->dir_config('lonDefDomain'); }
681:
1.134 albertel 682: my @pscat=&Apache::loncommon::get_env_multiple('form.pscat');
1.43 albertel 683: my $pschp=$ENV{'form.pschp'};
1.134 albertel 684: my @psprt=&Apache::loncommon::get_env_multiple('form.psprt');
1.76 www 685: if (!@psprt) { $psprt[0]='0'; }
1.57 albertel 686: my $showoptions=$ENV{'form.showoptions'};
687:
1.43 albertel 688: my $pssymb='';
1.57 albertel 689: my $parmlev='';
690: my $prevvisit=$ENV{'form.prevvisit'};
691:
692: # unless ($parmlev==$ENV{'form.parmlev'}) {
693: # $parmlev = 'full';
694: # }
695:
696: unless ($ENV{'form.parmlev'}) {
697: $parmlev = 'map';
698: } else {
699: $parmlev = $ENV{'form.parmlev'};
700: }
1.26 www 701:
1.29 www 702: # ----------------------------------------------- Was this started from grades?
703:
1.43 albertel 704: if (($ENV{'form.command'} eq 'set') && ($ENV{'form.url'})
705: && (!$ENV{'form.dis'})) {
706: my $url=$ENV{'form.url'};
707: $url=~s-^http://($ENV{'SERVER_NAME'}|$ENV{'HTTP_HOST'})--;
708: $pssymb=&Apache::lonnet::symbread($url);
1.92 albertel 709: if (!@pscat) { @pscat=('all'); }
1.43 albertel 710: $pschp='';
1.57 albertel 711: $parmlev = 'full';
1.43 albertel 712: } elsif ($ENV{'form.symb'}) {
713: $pssymb=$ENV{'form.symb'};
1.92 albertel 714: if (!@pscat) { @pscat=('all'); }
1.43 albertel 715: $pschp='';
1.57 albertel 716: $parmlev = 'full';
1.43 albertel 717: } else {
718: $ENV{'form.url'}='';
719: }
720:
721: my $id=$ENV{'form.id'};
722: if (($id) && ($udom)) {
723: $uname=(&Apache::lonnet::idget($udom,$id))[1];
724: if ($uname) {
725: $id='';
726: } else {
727: $message=
1.133 www 728: "<font color=red>".&mt("Unknown ID")." '$id' ".
729: &mt('at domain')." '$udom'</font>";
1.43 albertel 730: }
731: } else {
732: $uname=$ENV{'form.uname'};
733: }
734: unless ($udom) { $uname=''; }
735: $uhome='';
736: if ($uname) {
737: $uhome=&Apache::lonnet::homeserver($uname,$udom);
738: if ($uhome eq 'no_host') {
739: $message=
1.133 www 740: "<font color=red>".&mt("Unknown user")." '$uname' ".
741: &mt("at domain")." '$udom'</font>";
1.43 albertel 742: $uname='';
1.12 www 743: } else {
1.103 albertel 744: $csec=&Apache::lonnet::getsection($udom,$uname,
745: $ENV{'request.course.id'});
1.43 albertel 746: if ($csec eq '-1') {
747: $message="<font color=red>".
1.133 www 748: &mt("User")." '$uname' ".&mt("at domain")." '$udom' ".
749: &mt("not in this course")."</font>";
1.43 albertel 750: $uname='';
751: $csec=$ENV{'form.csec'};
752: } else {
753: my %name=&Apache::lonnet::userenvironment($udom,$uname,
754: ('firstname','middlename','lastname','generation','id'));
1.133 www 755: $message="\n<p>\n".&mt("Full Name").": ".
1.43 albertel 756: $name{'firstname'}.' '.$name{'middlename'}.' '
757: .$name{'lastname'}.' '.$name{'generation'}.
1.133 www 758: "<br>\n".&mt('ID').": ".$name{'id'}.'<p>';
1.43 albertel 759: }
1.12 www 760: }
1.43 albertel 761: }
1.2 www 762:
1.43 albertel 763: unless ($csec) { $csec=''; }
1.12 www 764:
1.44 albertel 765: my $fcat=$ENV{'form.fcat'};
1.43 albertel 766: unless ($fcat) { $fcat=''; }
1.2 www 767:
768: # ------------------------------------------------------------------- Tie hashs
1.44 albertel 769: if (!(tie(%bighash,'GDBM_File',$ENV{'request.course.fn'}.'.db',
1.58 albertel 770: &GDBM_READER(),0640))) {
1.44 albertel 771: $r->print("Unable to access course data. (File $ENV{'request.course.fn'}.db not tieable)");
772: return ;
773: }
774: if (!(tie(%parmhash,'GDBM_File',
1.58 albertel 775: $ENV{'request.course.fn'}.'_parms.db',&GDBM_READER(),0640))) {
1.44 albertel 776: $r->print("Unable to access parameter data. (File $ENV{'request.course.fn'}_parms.db not tieable)");
777: return ;
778: }
1.63 bowersj2 779:
1.14 www 780: # --------------------------------------------------------- Get all assessments
1.82 www 781: extractResourceInformation(\%bighash, \@ids, \%typep,\%keyp, \%allparms, \%allparts, \%allkeys, \%allmaps, $fcat, \%defp, \%mapp, \%symbp,\%maptitles);
1.63 bowersj2 782:
1.57 albertel 783: $mapp{'0.0'} = '';
784: $symbp{'0.0'} = '';
1.99 albertel 785:
1.14 www 786: # ---------------------------------------------------------- Anything to store?
1.44 albertel 787: if ($ENV{'form.pres_marker'}) {
788: my ($sresid,$spnam,$snum)=split(/\&/,$ENV{'form.pres_marker'});
789: $spnam=~s/\_([^\_]+)$/\.$1/;
1.15 www 790: # ---------------------------------------------------------- Construct prefixes
1.14 www 791:
1.44 albertel 792: my $symbparm=$symbp{$sresid}.'.'.$spnam;
793: my $mapparm=$mapp{$sresid}.'___(all).'.$spnam;
794:
795: my $seclevel=$ENV{'request.course.id'}.'.['.$csec.'].'.$spnam;
796: my $seclevelr=$ENV{'request.course.id'}.'.['.$csec.'].'.$symbparm;
797: my $seclevelm=$ENV{'request.course.id'}.'.['.$csec.'].'.$mapparm;
798:
799: my $courselevel=$ENV{'request.course.id'}.'.'.$spnam;
800: my $courselevelr=$ENV{'request.course.id'}.'.'.$symbparm;
801: my $courselevelm=$ENV{'request.course.id'}.'.'.$mapparm;
802:
803: my $storeunder='';
804: if (($snum==9) || ($snum==3)) { $storeunder=$courselevel; }
805: if (($snum==8) || ($snum==2)) { $storeunder=$courselevelm; }
806: if (($snum==7) || ($snum==1)) { $storeunder=$courselevelr; }
807: if ($snum==6) { $storeunder=$seclevel; }
808: if ($snum==5) { $storeunder=$seclevelm; }
809: if ($snum==4) { $storeunder=$seclevelr; }
810:
1.79 albertel 811: my $delete;
812: if ($ENV{'form.pres_value'} eq '') { $delete=1;}
1.66 www 813: my %storecontent = ($storeunder => $ENV{'form.pres_value'},
814: $storeunder.'.type' => $ENV{'form.pres_type'});
1.44 albertel 815: my $reply='';
816: if ($snum>3) {
1.14 www 817: # ---------------------------------------------------------------- Store Course
1.24 www 818: #
819: # Expire sheets
1.44 albertel 820: &Apache::lonnet::expirespread('','','studentcalc');
821: if (($snum==7) || ($snum==4)) {
822: &Apache::lonnet::expirespread('','','assesscalc',$symbp{$sresid});
823: } elsif (($snum==8) || ($snum==5)) {
824: &Apache::lonnet::expirespread('','','assesscalc',$mapp{$sresid});
825: } else {
826: &Apache::lonnet::expirespread('','','assesscalc');
827: }
1.24 www 828: # Store parameter
1.79 albertel 829: if ($delete) {
830: $reply=&Apache::lonnet::del
831: ('resourcedata',[keys(%storecontent)],
832: $ENV{'course.'.$ENV{'request.course.id'}.'.domain'},
833: $ENV{'course.'.$ENV{'request.course.id'}.'.num'});
834: } else {
835: $reply=&Apache::lonnet::cput
836: ('resourcedata',\%storecontent,
837: $ENV{'course.'.$ENV{'request.course.id'}.'.domain'},
838: $ENV{'course.'.$ENV{'request.course.id'}.'.num'});
839: }
1.44 albertel 840: } else {
1.14 www 841: # ------------------------------------------------------------------ Store User
1.24 www 842: #
843: # Expire sheets
1.44 albertel 844: &Apache::lonnet::expirespread($uname,$udom,'studentcalc');
845: if ($snum==1) {
846: &Apache::lonnet::expirespread
847: ($uname,$udom,'assesscalc',$symbp{$sresid});
848: } elsif ($snum==2) {
849: &Apache::lonnet::expirespread
850: ($uname,$udom,'assesscalc',$mapp{$sresid});
851: } else {
852: &Apache::lonnet::expirespread($uname,$udom,'assesscalc');
853: }
1.24 www 854: # Store parameter
1.79 albertel 855: if ($delete) {
856: $reply=&Apache::lonnet::del
857: ('resourcedata',[keys(%storecontent)],$udom,$uname);
858: } else {
859: $reply=&Apache::lonnet::cput
860: ('resourcedata',\%storecontent,$udom,$uname);
861: }
1.44 albertel 862: }
1.15 www 863:
1.44 albertel 864: if ($reply=~/^error\:(.*)/) {
865: $message.="<font color=red>Write Error: $1</font>";
866: }
1.68 www 867: # ---------------------------------------------------------------- Done storing
1.130 www 868: $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 869: }
1.67 www 870: # --------------------------------------------- Devalidate cache for this child
1.109 albertel 871: &Apache::lonnet::devalidatecourseresdata(
1.67 www 872: $ENV{'course.'.$ENV{'request.course.id'}.'.num'},
873: $ENV{'course.'.$ENV{'request.course.id'}.'.domain'});
1.109 albertel 874: &Apache::lonnet::clear_EXT_cache_status();
1.2 www 875: # -------------------------------------------------------------- Get coursedata
1.45 matthew 876: %courseopt = &Apache::lonnet::dump
877: ('resourcedata',
878: $ENV{'course.'.$ENV{'request.course.id'}.'.domain'},
879: $ENV{'course.'.$ENV{'request.course.id'}.'.num'});
1.44 albertel 880: # --------------------------------------------------- Get userdata (if present)
881: if ($uname) {
1.45 matthew 882: %useropt=&Apache::lonnet::dump('resourcedata',$udom,$uname);
1.44 albertel 883: }
1.14 www 884:
1.2 www 885: # ------------------------------------------------------------------- Sort this
1.17 www 886:
1.44 albertel 887: @ids=sort {
888: if ($fcat eq '') {
889: $a<=>$b;
890: } else {
891: my ($result,@outpar)=&parmval($fcat,$a,$defp{$a});
892: my $aparm=$outpar[$result];
893: ($result,@outpar)=&parmval($fcat,$b,$defp{$b});
894: my $bparm=$outpar[$result];
895: 1*$aparm<=>1*$bparm;
896: }
897: } @ids;
1.57 albertel 898: #----------------------------------------------- if all selected, fill in array
899: if ($pscat[0] eq "all" || !@pscat) {@pscat = (keys %allparms);}
900: if ($psprt[0] eq "all" || !@psprt) {@psprt = (keys %allparts);}
1.2 www 901: # ------------------------------------------------------------------ Start page
1.63 bowersj2 902:
1.99 albertel 903: my $have_assesments=1;
904: if (scalar(keys(%allkeys)) eq 0) { $have_assesments=0; }
905:
906: &startpage($r,$id,$udom,$csec,$uname,$have_assesments);
907:
1.112 albertel 908: if (!$have_assesments) {
909: untie(%bighash);
910: untie(%parmhash);
911: return '';
912: }
1.44 albertel 913: # if ($ENV{'form.url'}) {
914: # $r->print('<input type="hidden" value="'.$ENV{'form.url'}.
915: # '" name="url"><input type="hidden" name="command" value="set">');
916: # }
1.57 albertel 917: $r->print('<input type="hidden" value="true" name="prevvisit">');
918:
1.44 albertel 919: foreach ('tolerance','date_default','date_start','date_end',
920: 'date_interval','int','float','string') {
921: $r->print('<input type="hidden" value="'.
922: $ENV{'form.recent_'.$_}.'" name="recent_'.$_.'">');
923: }
924:
1.57 albertel 925: $r->print('<h2>'.$message.'</h2><table>');
926:
1.130 www 927: my $submitmessage = &mt('Update Section or Specific User');
1.44 albertel 928: if (!$pssymb) {
1.130 www 929: $r->print('<tr><td>'.&mt('Select Parameter Level').'</td><td colspan="2">');
1.57 albertel 930: $r->print('<select name="parmlev">');
931: foreach (reverse sort keys %alllevs) {
932: $r->print('<option value="'.$alllevs{$_}.'"');
933: if ($parmlev eq $alllevs{$_}) {
934: $r->print(' selected');
935: }
936: $r->print('>'.$_.'</option>');
937: }
938: $r->print("</select></td>\n");
939:
1.101 www 940: $r->print('</tr>');
1.128 albertel 941: if ($parmlev ne 'general') {
1.130 www 942: $r->print('<tr><td>'.&mt('Select Enclosing Map or Folder').'</td>');
1.128 albertel 943: $r->print('<td colspan="2"><select name="pschp">');
1.130 www 944: $r->print('<option value="all">'.&mt('All Maps or Folders').'</option>');
1.128 albertel 945: foreach (sort {$allmaps{$a} cmp $allmaps{$b}} keys %allmaps) {
946: $r->print('<option value="'.$_.'"');
947: if (($pschp eq $_)) { $r->print(' selected'); }
948: $r->print('>'.$maptitles{$_}.($allmaps{$_}!~/^uploaded/?' ['.$allmaps{$_}.']':'').'</option>');
949: }
950: $r->print("</select></td></tr>\n");
951: }
1.44 albertel 952: } else {
1.125 www 953: my ($map,$id,$resource)=&Apache::lonnet::decode_symb($pssymb);
1.130 www 954: $r->print("<tr><td>".&mt('Specific Resource')."</td><td>$resource</td>");
1.57 albertel 955: $r->print('<td><input type="submit" name="dis" value="'.$submitmessage.'"></td>');
956: $r->print('</tr>');
957: $r->print('<input type="hidden" value="'.$pssymb.'" name="symb">');
958: }
959:
960: $r->print('<tr><td colspan="3"><hr /><input type="checkbox"');
961: if ($showoptions eq 'show') {$r->print(" checked ");}
1.130 www 962: $r->print(' name="showoptions" value="show">'.&mt('Show More Options').'<hr /></td></tr>');
1.57 albertel 963: # $r->print("<tr><td>Show: $showoptions</td></tr>");
964: # $r->print("<tr><td>pscat: @pscat</td></tr>");
965: # $r->print("<tr><td>psprt: @psprt</td></tr>");
966: # $r->print("<tr><td>fcat: $fcat</td></tr>");
967:
968: if ($showoptions eq 'show') {
969: my $tempkey;
970:
1.130 www 971: $r->print('<tr><td colspan="3" align="center">'.&mt('Select Parameters to View').'</td></tr>');
1.57 albertel 972:
973: $r->print('<tr><td colspan="2"><table>');
974: $r->print('<tr><td><input type="checkbox" name="pscat" value="all"');
975: $r->print(' checked') unless (@pscat);
1.130 www 976: $r->print('>'.&mt('All Parameters').'</td>');
1.57 albertel 977:
978: my $cnt=0;
979: foreach $tempkey (sort { $allparms{$a} cmp $allparms{$b} }
980: keys %allparms ) {
981: ++$cnt;
982: $r->print('</tr><tr>') unless ($cnt%2);
983: $r->print('<td><input type="checkbox" name="pscat" ');
984: $r->print('value="'.$tempkey.'"');
985: if ($pscat[0] eq "all" || grep $_ eq $tempkey, @pscat) {
986: $r->print(' checked');
987: }
988: $r->print('>'.$allparms{$tempkey}.'</td>');
989: }
990: $r->print('</tr></table>');
991:
992: # $r->print('<tr><td>Select Parts</td><td>');
993: $r->print('<td><select multiple name="psprt" size="5">');
994: $r->print('<option value="all"');
995: $r->print(' selected') unless (@psprt);
1.130 www 996: $r->print('>'.&mt('All Parts').'</option>');
1.76 www 997: my %temphash=();
998: foreach (@psprt) { $temphash{$_}=1; }
1.57 albertel 999: foreach $tempkey (sort keys %allparts) {
1000: unless ($tempkey =~ /\./) {
1001: $r->print('<option value="'.$tempkey.'"');
1.76 www 1002: if ($psprt[0] eq "all" || $temphash{$tempkey}) {
1.57 albertel 1003: $r->print(' selected');
1004: }
1005: $r->print('>'.$allparts{$tempkey}.'</option>');
1006: }
1007: }
1008: $r->print('</select></td></tr><tr><td colspan="3"><hr /></td></tr>');
1009:
1.130 www 1010: $r->print('<tr><td>'.&mt('Sort list by').'</td><td>');
1.57 albertel 1011: $r->print('<select name="fcat">');
1.130 www 1012: $r->print('<option value="">'.&mt('Enclosing Map or Folder').'</option>');
1.57 albertel 1013: foreach (sort keys %allkeys) {
1014: $r->print('<option value="'.$_.'"');
1015: if ($fcat eq $_) { $r->print(' selected'); }
1016: $r->print('>'.$allkeys{$_}.'</option>');
1017: }
1018: $r->print('</select></td>');
1019:
1020: $r->print('</tr><tr><td colspan="3"><hr /></td></tr>');
1021:
1022: } else { # hide options - include any necessary extras here
1023:
1024: $r->print('<input type="hidden" name="fcat" value="'.$fcat.'">'."\n");
1025:
1026: unless (@pscat) {
1027: foreach (keys %allparms ) {
1028: $r->print('<input type="hidden" name="pscat" value="'.$_.'">'."\n");
1029: }
1030: } else {
1031: foreach (@pscat) {
1032: $r->print('<input type="hidden" name="pscat" value="'.$_.'">'."\n");
1033: }
1034: }
1035:
1036: unless (@psprt) {
1037: foreach (keys %allparts ) {
1038: $r->print('<input type="hidden" name="psprt" value="'.$_.'">'."\n");
1039: }
1040: } else {
1041: foreach (@psprt) {
1042: $r->print('<input type="hidden" name="psprt" value="'.$_.'">'."\n");
1043: }
1044: }
1045:
1.44 albertel 1046: }
1.101 www 1047: $r->print('</table><br />');
1048: if (($prevvisit) || ($pschp) || ($pssymb)) {
1.130 www 1049: $submitmessage = &mt("Update Course Assessment Parameter Display");
1.101 www 1050: } else {
1.130 www 1051: $submitmessage = &mt("Set/Modify Course Assessment Parameters");
1.101 www 1052: }
1053: $r->print('<input type="submit" name="dis" value="'.$submitmessage.'">');
1.57 albertel 1054:
1.76 www 1055: # my @temp_psprt;
1056: # foreach my $t (@psprt) {
1057: # push(@temp_psprt, grep {eval (/^$t\./ || ($_ == $t))} (keys %allparts));
1058: # }
1.57 albertel 1059:
1.76 www 1060: # @psprt = @temp_psprt;
1.57 albertel 1061:
1062: my @temp_pscat;
1063: map {
1064: my $cat = $_;
1065: push(@temp_pscat, map { $_.'.'.$cat } @psprt);
1066: } @pscat;
1067:
1068: @pscat = @temp_pscat;
1069:
1070: if (($prevvisit) || ($pschp) || ($pssymb)) {
1.10 www 1071: # ----------------------------------------------------------------- Start Table
1.57 albertel 1072: my @catmarker=map { tr|.|_|; 'parameter_'.$_; } @pscat;
1073: my $csuname=$ENV{'user.name'};
1074: my $csudom=$ENV{'user.domain'};
1075:
1076: if ($parmlev eq 'full' || $parmlev eq 'brief') {
1077: my $coursespan=$csec?8:5;
1078: $r->print('<p><table border=2>');
1079: $r->print('<tr><td colspan=5></td>');
1.130 www 1080: $r->print('<th colspan='.($coursespan).'>'.&mt('Any User').'</th>');
1.57 albertel 1081: if ($uname) {
1082: $r->print("<th colspan=3 rowspan=2>");
1.130 www 1083: $r->print(&mt("User")." $uname ".&mt('at Domain')." $udom</th>");
1.57 albertel 1084: }
1.133 www 1085: my %lt=&Apache::lonlocal::texthash(
1086: 'pie' => "Parameter in Effect",
1087: 'csv' => "Current Session Value",
1088: 'at' => 'at',
1089: 'rl' => "Resource Level",
1090: 'ic' => 'in Course',
1091: 'aut' => "Assessment URL and Title",
1092: 'type' => 'Type',
1093: 'emof' => "Enclosing Map or Folder",
1094: 'part' => 'Part',
1095: 'pn' => 'Parameter Name',
1096: 'def' => 'default',
1097: 'femof' => 'from Enclosing Map or Folder',
1098: 'gen' => 'general',
1099: 'foremf' => 'for Enclosing Map or Folder',
1100: 'fr' => 'for Resource'
1101: );
1.57 albertel 1102: $r->print(<<ENDTABLETWO);
1.133 www 1103: <th rowspan=3>$lt{'pie'}</th>
1104: <th rowspan=3>$lt{'csv'}<br>($csuname $lt{'at'} $csudom)</th>
1105: </tr><tr><td colspan=5></td><th colspan=2>$lt{'rl'}</th>
1106: <th colspan=3>$lt{'ic'}</th>
1.10 www 1107: ENDTABLETWO
1.57 albertel 1108: if ($csec) {
1.133 www 1109: $r->print("<th colspan=3>".
1110: &mt("in Section/Group")." $csec</th>");
1.57 albertel 1111: }
1112: $r->print(<<ENDTABLEHEADFOUR);
1.133 www 1113: </tr><tr><th>$lt{'aut'}</th><th>$lt{'type'}</th>
1114: <th>$lt{'emof'}</th><th>$lt{'part'}</th><th>$lt{'pn'}</th>
1115: <th>$lt{'def'}</th><th>$lt{'femof'}</th>
1116: <th>$lt{'gen'}</th><th>$lt{'foremf'}</th><th>$lt{'fr'}</th>
1.10 www 1117: ENDTABLEHEADFOUR
1.57 albertel 1118:
1119: if ($csec) {
1.130 www 1120: $r->print('<th>'.&mt('general').'</th><th>'.&mt('for Enclosing Map or Folder').'</th><th>'.&mt('for Resource').'</th>');
1.57 albertel 1121: }
1122:
1123: if ($uname) {
1.130 www 1124: $r->print('<th>'.&mt('general').'</th><th>'.&mt('for Enclosing Map or Folder').'</th><th>'.&mt('for Resource').'</th>');
1.57 albertel 1125: }
1126:
1127: $r->print('</tr>');
1128:
1129: my $defbgone='';
1130: my $defbgtwo='';
1131:
1132: foreach (@ids) {
1133:
1134: my $rid=$_;
1135: my ($inmapid)=($rid=~/\.(\d+)$/);
1136:
1137: if (($pschp eq 'all') || ($allmaps{$pschp} eq $mapp{$rid}) ||
1138: ($pssymb eq $symbp{$rid})) {
1.4 www 1139: # ------------------------------------------------------ Entry for one resource
1.57 albertel 1140: if ($defbgone eq '"E0E099"') {
1141: $defbgone='"E0E0DD"';
1142: } else {
1143: $defbgone='"E0E099"';
1144: }
1145: if ($defbgtwo eq '"FFFF99"') {
1146: $defbgtwo='"FFFFDD"';
1147: } else {
1148: $defbgtwo='"FFFF99"';
1149: }
1150: my $thistitle='';
1151: my %name= ();
1152: undef %name;
1153: my %part= ();
1154: my %display=();
1155: my %type= ();
1156: my %default=();
1157: my $uri=&Apache::lonnet::declutter($bighash{'src_'.$rid});
1158:
1159: foreach (split(/\,/,$keyp{$rid})) {
1160: my $tempkeyp = $_;
1161: if (grep $_ eq $tempkeyp, @catmarker) {
1162: $part{$_}=&Apache::lonnet::metadata($uri,$_.'.part');
1163: $name{$_}=&Apache::lonnet::metadata($uri,$_.'.name');
1164: $display{$_}=&Apache::lonnet::metadata($uri,$_.'.display');
1165: unless ($display{$_}) { $display{$_}=''; }
1166: $display{$_}.=' ('.$name{$_}.')';
1167: $default{$_}=&Apache::lonnet::metadata($uri,$_);
1168: $type{$_}=&Apache::lonnet::metadata($uri,$_.'.type');
1169: $thistitle=&Apache::lonnet::metadata($uri,$_.'.title');
1170: }
1171: }
1172: my $totalparms=scalar keys %name;
1173: if ($totalparms>0) {
1174: my $firstrow=1;
1.127 albertel 1175: my $title=$bighash{'title_'.$rid};
1176: $title=~s/\:/:/g;
1.57 albertel 1177: $r->print('<tr><td bgcolor='.$defbgone.
1178: ' rowspan='.$totalparms.
1179: '><tt><font size=-1>'.
1180: join(' / ',split(/\//,$uri)).
1181: '</font></tt><p><b>'.
1182: "<a href=\"javascript:openWindow('/res/".$uri.
1183: "', 'metadatafile', '450', '500', 'no', 'yes')\";".
1.127 albertel 1184: " TARGET=_self>$title");
1.57 albertel 1185:
1186: if ($thistitle) {
1187: $r->print(' ('.$thistitle.')');
1188: }
1189: $r->print('</a></b></td>');
1190: $r->print('<td bgcolor='.$defbgtwo.
1191: ' rowspan='.$totalparms.'>'.$typep{$rid}.
1192: '</td>');
1193:
1194: $r->print('<td bgcolor='.$defbgone.
1195: ' rowspan='.$totalparms.
1196: '><tt><font size=-1>');
1197:
1198: $r->print(' / res / ');
1199: $r->print(join(' / ', split(/\//,$mapp{$rid})));
1200:
1201: $r->print('</font></tt></td>');
1202:
1203: foreach (sort keys %name) {
1204: unless ($firstrow) {
1205: $r->print('<tr>');
1206: } else {
1207: undef $firstrow;
1208: }
1209:
1210: &print_row($r,$_,\%part,\%name,$rid,\%default,
1211: \%type,\%display,$defbgone,$defbgtwo,
1212: $parmlev);
1213: }
1214: }
1215: }
1216: } # end foreach ids
1.43 albertel 1217: # -------------------------------------------------- End entry for one resource
1.57 albertel 1218: $r->print('</table>');
1219: } # end of brief/full
1220: #--------------------------------------------------- Entry for parm level map
1221: if ($parmlev eq 'map') {
1222: my $defbgone = '"E0E099"';
1223: my $defbgtwo = '"FFFF99"';
1224:
1225: my %maplist;
1226:
1227: if ($pschp eq 'all') {
1228: %maplist = %allmaps;
1229: } else {
1230: %maplist = ($pschp => $mapp{$pschp});
1231: }
1232:
1233: #-------------------------------------------- for each map, gather information
1234: my $mapid;
1.60 albertel 1235: foreach $mapid (sort {$maplist{$a} cmp $maplist{$b}} keys %maplist) {
1236: my $maptitle = $maplist{$mapid};
1.57 albertel 1237:
1238: #----------------------- loop through ids and get all parameter types for map
1239: #----------------------------------------- and associated information
1240: my %name = ();
1241: my %part = ();
1242: my %display = ();
1243: my %type = ();
1244: my %default = ();
1245: my $map = 0;
1246:
1247: # $r->print("Catmarker: @catmarker<br />\n");
1248:
1249: foreach (@ids) {
1250: ($map)=(/([\d]*?)\./);
1251: my $rid = $_;
1252:
1253: # $r->print("$mapid:$map: $rid <br /> \n");
1254:
1255: if ($map eq $mapid) {
1256: my $uri=&Apache::lonnet::declutter($bighash{'src_'.$rid});
1257: # $r->print("Keys: $keyp{$rid} <br />\n");
1258:
1259: #--------------------------------------------------------------------
1260: # @catmarker contains list of all possible parameters including part #s
1261: # $fullkeyp contains the full part/id # for the extraction of proper parameters
1262: # $tempkeyp contains part 0 only (no ids - ie, subparts)
1263: # When storing information, store as part 0
1264: # When requesting information, request from full part
1265: #-------------------------------------------------------------------
1266: foreach (split(/\,/,$keyp{$rid})) {
1267: my $tempkeyp = $_;
1268: my $fullkeyp = $tempkeyp;
1.73 albertel 1269: $tempkeyp =~ s/_\w+_/_0_/;
1.57 albertel 1270:
1271: if ((grep $_ eq $fullkeyp, @catmarker) &&(!$name{$tempkeyp})) {
1272: $part{$tempkeyp}="0";
1273: $name{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.name');
1274: $display{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.display');
1275: unless ($display{$tempkeyp}) { $display{$tempkeyp}=''; }
1276: $display{$tempkeyp}.=' ('.$name{$tempkeyp}.')';
1.73 albertel 1277: $display{$tempkeyp} =~ s/_\w+_/_0_/;
1.57 albertel 1278: $default{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp);
1279: $type{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.type');
1280: }
1281: } # end loop through keys
1282: }
1283: } # end loop through ids
1284:
1285: #---------------------------------------------------- print header information
1.133 www 1286: my $foldermap=&mt($maptitle=~/^uploaded/?'Folder':'Map');
1.82 www 1287: my $showtitle=$maptitles{$maptitle}.($maptitle!~/^uploaded/?' ['.$maptitle.']':'');
1.57 albertel 1288: $r->print(<<ENDMAPONE);
1289: <center><h4>
1.135 ! albertel 1290: Set Defaults for All Resources in $foldermap<br />
! 1291: <font color="red"><i>$showtitle</i></font><br />
1.57 albertel 1292: Specifically for
1293: ENDMAPONE
1294: if ($uname) {
1295: my %name=&Apache::lonnet::userenvironment($udom,$uname,
1296: ('firstname','middlename','lastname','generation', 'id'));
1297: my $person=$name{'firstname'}.' '.$name{'middlename'}.' '
1298: .$name{'lastname'}.' '.$name{'generation'};
1.135 ! albertel 1299: $r->print(&mt("User")." <font color=\"red\"><i>$uname \($person\) </i></font> ".
1.130 www 1300: &mt('in')." \n");
1.57 albertel 1301: } else {
1.135 ! albertel 1302: $r->print("<font color=\"red\"><i>".&mt('all').'</i></font> '.&mt('users in')." \n");
1.57 albertel 1303: }
1304:
1.135 ! albertel 1305: if ($csec) {$r->print(&mt("Section")." <font color=\"red\"><i>$csec</i></font> ".
1.130 www 1306: &mt('of')." \n")};
1.57 albertel 1307:
1.135 ! albertel 1308: $r->print("<font color=\"red\"><i>$coursename</i></font><br />");
! 1309: $r->print("</h4>\n");
1.57 albertel 1310: #---------------------------------------------------------------- print table
1311: $r->print('<p><table border="2">');
1.130 www 1312: $r->print('<tr><th>'.&mt('Parameter Name').'</th>');
1313: $r->print('<th>'.&mt('Default Value').'</th>');
1314: $r->print('<th>'.&mt('Parameter in Effect').'</th></tr>');
1.57 albertel 1315:
1316: foreach (sort keys %name) {
1317: &print_row($r,$_,\%part,\%name,$mapid,\%default,
1318: \%type,\%display,$defbgone,$defbgtwo,
1319: $parmlev);
1320: # $r->print("<tr><td>resource.$part{$_}.$name{$_},$symbp{$mapid}</td></tr>\n");
1321: }
1322: $r->print("</table></center>");
1323: } # end each map
1324: } # end of $parmlev eq map
1325: #--------------------------------- Entry for parm level general (Course level)
1326: if ($parmlev eq 'general') {
1327: my $defbgone = '"E0E099"';
1328: my $defbgtwo = '"FFFF99"';
1329:
1330: #-------------------------------------------- for each map, gather information
1331: my $mapid="0.0";
1332: #----------------------- loop through ids and get all parameter types for map
1333: #----------------------------------------- and associated information
1334: my %name = ();
1335: my %part = ();
1336: my %display = ();
1337: my %type = ();
1338: my %default = ();
1339:
1340: foreach (@ids) {
1341: my $rid = $_;
1342:
1343: my $uri=&Apache::lonnet::declutter($bighash{'src_'.$rid});
1344:
1345: #--------------------------------------------------------------------
1346: # @catmarker contains list of all possible parameters including part #s
1347: # $fullkeyp contains the full part/id # for the extraction of proper parameters
1348: # $tempkeyp contains part 0 only (no ids - ie, subparts)
1349: # When storing information, store as part 0
1350: # When requesting information, request from full part
1351: #-------------------------------------------------------------------
1352: foreach (split(/\,/,$keyp{$rid})) {
1353: my $tempkeyp = $_;
1354: my $fullkeyp = $tempkeyp;
1.73 albertel 1355: $tempkeyp =~ s/_\w+_/_0_/;
1.57 albertel 1356: if ((grep $_ eq $fullkeyp, @catmarker) &&(!$name{$tempkeyp})) {
1357: $part{$tempkeyp}="0";
1358: $name{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.name');
1359: $display{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.display');
1360: unless ($display{$tempkeyp}) { $display{$tempkeyp}=''; }
1361: $display{$tempkeyp}.=' ('.$name{$tempkeyp}.')';
1.73 albertel 1362: $display{$tempkeyp} =~ s/_\w+_/_0_/;
1.57 albertel 1363: $default{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp);
1364: $type{$tempkeyp}=&Apache::lonnet::metadata($uri,$fullkeyp.'.type');
1365: }
1366: } # end loop through keys
1367: } # end loop through ids
1368:
1369: #---------------------------------------------------- print header information
1.133 www 1370: my $setdef=&mt("Set Defaults for All Resources in Course");
1.57 albertel 1371: $r->print(<<ENDMAPONE);
1.133 www 1372: <center><h4>$setdef
1.135 ! albertel 1373: <font color="red"><i>$coursename</i></font><br />
1.57 albertel 1374: ENDMAPONE
1375: if ($uname) {
1376: my %name=&Apache::lonnet::userenvironment($udom,$uname,
1377: ('firstname','middlename','lastname','generation', 'id'));
1378: my $person=$name{'firstname'}.' '.$name{'middlename'}.' '
1379: .$name{'lastname'}.' '.$name{'generation'};
1.135 ! albertel 1380: $r->print(" ".&mt("User")."<font color=\"red\"> <i>$uname \($person\) </i></font> \n");
1.57 albertel 1381: } else {
1.135 ! albertel 1382: $r->print("<i><font color=\"red\"> ".&mt("ALL")."</i> ".&mt("USERS")."</font> \n");
1.57 albertel 1383: }
1384:
1.135 ! albertel 1385: if ($csec) {$r->print(&mt("Section")."<font color=\"red\"> <i>$csec</i></font>\n")};
! 1386: $r->print("</h4>\n");
1.57 albertel 1387: #---------------------------------------------------------------- print table
1388: $r->print('<p><table border="2">');
1.130 www 1389: $r->print('<tr><th>'.&mt('Parameter Name').'</th>');
1390: $r->print('<th>'.&mt('Default Value').'</th>');
1391: $r->print('<th>'.&mt('Parameter in Effect').'</th></tr>');
1.57 albertel 1392:
1393: foreach (sort keys %name) {
1394: &print_row($r,$_,\%part,\%name,$mapid,\%default,
1395: \%type,\%display,$defbgone,$defbgtwo,$parmlev);
1396: # $r->print("<tr><td>resource.$part{$_}.$name{$_},$symbp{$mapid}</td></tr>\n");
1397: }
1398: $r->print("</table></center>");
1399: } # end of $parmlev eq general
1.43 albertel 1400: }
1.44 albertel 1401: $r->print('</form></body></html>');
1402: untie(%bighash);
1403: untie(%parmhash);
1.57 albertel 1404: } # end sub assessparms
1.30 www 1405:
1.59 matthew 1406:
1407: ##################################################
1408: ##################################################
1409:
1410: =pod
1411:
1412: =item crsenv
1413:
1.105 matthew 1414: Show and set course data and parameters. This is a large routine that should
1.59 matthew 1415: be simplified and shortened... someday.
1416:
1417: Inputs: $r
1418:
1419: Returns: nothing
1420:
1421: =cut
1422:
1423: ##################################################
1424: ##################################################
1.30 www 1425: sub crsenv {
1426: my $r=shift;
1427: my $setoutput='';
1.64 www 1428: my $bodytag=&Apache::loncommon::bodytag(
1429: 'Set Course Environment Parameters');
1.45 matthew 1430: my $dom = $ENV{'course.'.$ENV{'request.course.id'}.'.domain'};
1431: my $crs = $ENV{'course.'.$ENV{'request.course.id'}.'.num'};
1.105 matthew 1432:
1433: #
1434: # Go through list of changes
1.38 harris41 1435: foreach (keys %ENV) {
1.105 matthew 1436: next if ($_!~/^form\.(.+)\_setparmval$/);
1437: my $name = $1;
1438: my $value = $ENV{'form.'.$name.'_value'};
1439: if ($name eq 'newp') {
1440: $name = $ENV{'form.newp_name'};
1441: }
1442: if ($name eq 'url') {
1443: $value=~s/^\/res\///;
1444: my $bkuptime=time;
1445: my @tmp = &Apache::lonnet::get
1446: ('environment',['url'],$dom,$crs);
1.130 www 1447: $setoutput.=&mt('Backing up previous URL').': '.
1.105 matthew 1448: &Apache::lonnet::put
1449: ('environment',
1450: {'top level map backup '.$bkuptime => $tmp[1] },
1451: $dom,$crs).
1452: '<br>';
1453: }
1454: #
1455: # Deal with modified default spreadsheets
1456: if ($name =~ /^spreadsheet_default_(classcalc|
1457: studentcalc|
1458: assesscalc)$/x) {
1459: my $sheettype = $1;
1460: if ($sheettype eq 'classcalc') {
1461: # no need to do anything since viewing the sheet will
1462: # cause it to be updated.
1463: } elsif ($sheettype eq 'studentcalc') {
1464: # expire all the student spreadsheets
1465: &Apache::lonnet::expirespread('','','studentcalc');
1466: } else {
1467: # expire all the assessment spreadsheets
1468: # this includes non-default spreadsheets, but better to
1469: # be safe than sorry.
1470: &Apache::lonnet::expirespread('','','assesscalc');
1471: # expire all the student spreadsheets
1472: &Apache::lonnet::expirespread('','','studentcalc');
1.30 www 1473: }
1.105 matthew 1474: }
1475: #
1.107 matthew 1476: # Deal with the enrollment dates
1477: if ($name =~ /^default_enrollment_(start|end)_date$/) {
1478: $value=&Apache::lonhtmlcommon::get_date_from_form($name.'_value');
1479: }
1480: #
1.105 matthew 1481: # Let the user know we made the changes
1482: if ($name) {
1483: my $put_result = &Apache::lonnet::put('environment',
1484: {$name=>$value},$dom,$crs);
1485: if ($put_result eq 'ok') {
1.130 www 1486: $setoutput.=&mt('Set').' <b>'.$name.'</b> '.&mt('to').' <b>'.$value.'</b>.<br />';
1.105 matthew 1487: } else {
1.130 www 1488: $setoutput.=&mt('Unable to set').' <b>'.$name.'</b> '.&mt('to').
1489: ' <b>'.$value.'</b> '.&mt('due to').' '.$put_result.'.<br />';
1.30 www 1490: }
1491: }
1.38 harris41 1492: }
1.108 www 1493: # ------------------------- Re-init course environment entries for this session
1494:
1495: &Apache::lonnet::coursedescription($ENV{'request.course.id'});
1.105 matthew 1496:
1.30 www 1497: # -------------------------------------------------------- Get parameters again
1.45 matthew 1498:
1499: my %values=&Apache::lonnet::dump('environment',$dom,$crs);
1.30 www 1500: my $output='';
1.45 matthew 1501: if (! exists($values{'con_lost'})) {
1.30 www 1502: my %descriptions=
1.47 matthew 1503: ('url' => '<b>Top Level Map</b> '.
1.46 matthew 1504: '<a href="javascript:openbrowser'.
1.47 matthew 1505: "('envform','url','sequence')\">".
1.100 www 1506: 'Select Map</a><br /><font color=red> '.
1.45 matthew 1507: 'Modification may make assessment data '.
1508: 'inaccessible</font>',
1509: 'description' => '<b>Course Description</b>',
1.75 albertel 1510: 'courseid' => '<b>Course ID or number</b><br />'.
1.45 matthew 1511: '(internal, optional)',
1.117 matthew 1512: 'grading' => '<b>Grading</b>'.
1513: '"standard" or any other value. '.
1514: 'Default for new courses is "standard".',
1515:
1.52 www 1516: 'default_xml_style' => '<b>Default XML Style File</b> '.
1517: '<a href="javascript:openbrowser'.
1518: "('envform','default_xml_style'".
1.100 www 1519: ",'sty')\">Select Style File</a><br>",
1.74 www 1520: 'question.email' => '<b>Feedback Addresses for Resource Content '.
1.75 albertel 1521: 'Questions</b><br />(<tt>user:domain,'.
1.74 www 1522: 'user:domain(section;section;...;*;...),...</tt>)',
1.75 albertel 1523: 'comment.email' => '<b>Feedback Addresses for Course Content Comments</b><br />'.
1.74 www 1524: '(<tt>user:domain,user:domain(section;section;...;*;...),...</tt>)',
1.45 matthew 1525: 'policy.email' => '<b>Feedback Addresses for Course Policy</b>'.
1.75 albertel 1526: '<br />(<tt>user:domain,user:domain(section;section;...;*;...),...</tt>)',
1527: 'hideemptyrows' => '<b>Hide Empty Rows in Spreadsheets</b><br />'.
1.45 matthew 1528: '("<tt>yes</tt>" for default hiding)',
1.75 albertel 1529: 'pageseparators' => '<b>Visibly Separate Items on Pages</b><br />'.
1.93 bowersj2 1530: '("<tt>yes</tt>" for visible separation, '.
1531: 'changes will not show until next login)',
1.118 matthew 1532:
1533: 'plc.roles.denied'=> '<b>Disallow live chatroom use for '.
1534: 'Roles</b><br />"<tt>st</tt>": '.
1535: 'student, "<tt>ta</tt>": '.
1536: 'TA, "<tt>in</tt>": '.
1537: 'instructor;<br /><tt>role,role,...</tt>) '.
1538: Apache::loncommon::help_open_topic("Course_Disable_Discussion"),
1539: 'plc.users.denied' =>
1540: '<b>Disallow live chatroom use for Users</b><br />'.
1541: '(<tt>user:domain,user:domain,...</tt>)',
1542:
1.45 matthew 1543: 'pch.roles.denied'=> '<b>Disallow Resource Discussion for '.
1.75 albertel 1544: 'Roles</b><br />"<tt>st</tt>": '.
1.61 albertel 1545: 'student, "<tt>ta</tt>": '.
1546: 'TA, "<tt>in</tt>": '.
1.75 albertel 1547: 'instructor;<br /><tt>role,role,...</tt>) '.
1.61 albertel 1548: Apache::loncommon::help_open_topic("Course_Disable_Discussion"),
1.53 www 1549: 'pch.users.denied' =>
1.75 albertel 1550: '<b>Disallow Resource Discussion for Users</b><br />'.
1.53 www 1551: '(<tt>user:domain,user:domain,...</tt>)',
1.49 matthew 1552: 'spreadsheet_default_classcalc'
1.52 www 1553: => '<b>Default Course Spreadsheet</b> '.
1.50 matthew 1554: '<a href="javascript:openbrowser'.
1555: "('envform','spreadsheet_default_classcalc'".
1.100 www 1556: ",'spreadsheet')\">Select Spreadsheet File</a><br />",
1.49 matthew 1557: 'spreadsheet_default_studentcalc'
1.52 www 1558: => '<b>Default Student Spreadsheet</b> '.
1.50 matthew 1559: '<a href="javascript:openbrowser'.
1560: "('envform','spreadsheet_default_calc'".
1.100 www 1561: ",'spreadsheet')\">Select Spreadsheet File</a><br />",
1.49 matthew 1562: 'spreadsheet_default_assesscalc'
1.52 www 1563: => '<b>Default Assessment Spreadsheet</b> '.
1.50 matthew 1564: '<a href="javascript:openbrowser'.
1565: "('envform','spreadsheet_default_assesscalc'".
1.100 www 1566: ",'spreadsheet')\">Select Spreadsheet File</a><br />",
1.75 albertel 1567: 'allow_limited_html_in_feedback'
1568: => '<b>Allow limited HTML in discussion posts</b><br />'.
1.108 www 1569: '(Set value to "<tt>yes</tt>" to allow)',
1.89 albertel 1570: 'rndseed'
1.90 albertel 1571: => '<b>Randomization algorithm used</b> <br />'.
1.89 albertel 1572: '<font color="red">Modifying this will make problems '.
1.94 sakharuk 1573: 'have different numbers and answers</font>',
1.113 sakharuk 1574: 'problem_stream_switch'
1.104 matthew 1575: => '<b>Allow problems to be split over pages</b><br />'.
1.115 www 1576: ' ("<tt>yes</tt>" if allowed, anything else if not)',
1.111 sakharuk 1577: 'anonymous_quiz'
1.110 sakharuk 1578: => '<b>Anonimous quiz/exam</b><br />'.
1579: ' (<tt><b>yes</b> to avoid print students names </tt>)',
1.108 www 1580: 'default_enrollment_start_date' => '<b>Default beginning date '.
1581: 'when enrolling students</b>',
1582: 'default_enrollment_end_date' => '<b>Default ending date '.
1583: 'when enrolling students</b>',
1.115 www 1584: 'languages' => '<b>Languages used</b>',
1585: 'disable_receipt_display'
1586: => '<b>Disable display of problem receipts</b><br />'.
1587: ' ("<tt>yes</tt>" to disable, anything else if not)'
1.107 matthew 1588: );
1.117 matthew 1589: my @Display_Order = ('url','description','courseid','grading',
1.107 matthew 1590: 'default_xml_style','pageseparators',
1591: 'question.email','comment.email','policy.email',
1.118 matthew 1592: 'plc.roles.denied','plc.users.denied',
1.107 matthew 1593: 'pch.roles.denied','pch.users.denied',
1594: 'allow_limited_html_in_feedback',
1.108 www 1595: 'languages',
1.107 matthew 1596: 'rndseed',
1597: 'problem_stream_switch',
1.115 www 1598: 'disable_receipt_display',
1.107 matthew 1599: 'spreadsheet_default_classcalc',
1600: 'spreadsheet_default_studentcalc',
1601: 'spreadsheet_default_assesscalc',
1602: 'hideemptyrows',
1603: 'default_enrollment_start_date',
1604: 'default_enrollment_end_date',
1605: );
1606: foreach my $parameter (sort(keys(%values))) {
1607: if (! $descriptions{$parameter}) {
1608: $descriptions{$parameter}=$parameter;
1609: push(@Display_Order,$parameter);
1.43 albertel 1610: }
1611: }
1.107 matthew 1612: foreach my $parameter (@Display_Order) {
1613: my $description = $descriptions{$parameter};
1.51 matthew 1614: # onchange is javascript to automatically check the 'Set' button.
1.69 www 1615: my $onchange = 'onFocus="javascript:window.document.forms'.
1.107 matthew 1616: "['envform'].elements['".$parameter."_setparmval']".
1.51 matthew 1617: '.checked=true;"';
1.107 matthew 1618: $output .= '<tr><td>'.$description.'</td>';
1619: if ($parameter =~ /^default_enrollment_(start|end)_date$/) {
1620: $output .= '<td>'.
1621: &Apache::lonhtmlcommon::date_setter('envform',
1622: $parameter.'_value',
1623: $values{$parameter},
1624: $onchange).
1625: '</td>';
1626: } else {
1627: $output .= '<td>'.
1628: &Apache::lonhtmlcommon::textbox($parameter.'_value',
1629: $values{$parameter},
1630: 40,$onchange).'</td>';
1631: }
1632: $output .= '<td>'.
1633: &Apache::lonhtmlcommon::checkbox($parameter.'_setparmval').
1634: '</td>';
1635: $output .= "</tr>\n";
1.51 matthew 1636: }
1.69 www 1637: my $onchange = 'onFocus="javascript:window.document.forms'.
1.51 matthew 1638: '[\'envform\'].elements[\'newp_setparmval\']'.
1639: '.checked=true;"';
1.130 www 1640: $output.='<tr><td><i>'.&mt('Create New Environment Variable').'</i><br />'.
1.51 matthew 1641: '<input type="text" size=40 name="newp_name" '.
1642: $onchange.' /></td><td>'.
1643: '<input type="text" size=40 name="newp_value" '.
1644: $onchange.' /></td><td>'.
1645: '<input type="checkbox" name="newp_setparmval" /></td></tr>';
1.43 albertel 1646: }
1.30 www 1647: $r->print(<<ENDENV);
1648: <html>
1.46 matthew 1649: <script type="text/javascript" language="Javascript" >
1650: var editbrowser;
1.47 matthew 1651: function openbrowser(formname,elementname,only,omit) {
1.46 matthew 1652: var url = '/res/?';
1653: if (editbrowser == null) {
1654: url += 'launch=1&';
1655: }
1656: url += 'catalogmode=interactive&';
1657: url += 'mode=parmset&';
1658: url += 'form=' + formname + '&';
1.47 matthew 1659: if (only != null) {
1660: url += 'only=' + only + '&';
1661: }
1662: if (omit != null) {
1663: url += 'omit=' + omit + '&';
1664: }
1.46 matthew 1665: url += 'element=' + elementname + '';
1666: var title = 'Browser';
1667: var options = 'scrollbars=1,resizable=1,menubar=0';
1668: options += ',width=700,height=600';
1669: editbrowser = open(url,title,options,'1');
1670: editbrowser.focus();
1671: }
1672: </script>
1.30 www 1673: <head>
1674: <title>LON-CAPA Course Environment</title>
1675: </head>
1.64 www 1676: $bodytag
1.30 www 1677: <form method="post" action="/adm/parmset" name="envform">
1678: $setoutput
1679: <p>
1680: <table border=2>
1681: <tr><th>Parameter</th><th>Value</th><th>Set?</th></tr>
1682: $output
1683: </table>
1684: <input type="submit" name="crsenv" value="Set Course Environment">
1685: </form>
1686: </body>
1687: </html>
1688: ENDENV
1689: }
1.120 www 1690: ##################################################
1.30 www 1691:
1.124 www 1692: my $tableopen;
1693:
1694: sub tablestart {
1695: if ($tableopen) {
1696: return '';
1697: } else {
1698: $tableopen=1;
1.130 www 1699: return '<table border="2"><tr><th>'.&mt('Parameter').'</th><th>'.
1700: &mt('Delete').'</th><th>'.&mt('Set to ...').'</th></tr>';
1.124 www 1701: }
1702: }
1703:
1704: sub tableend {
1705: if ($tableopen) {
1706: $tableopen=0;
1707: return '</table>';
1708: } else {
1709: return'';
1710: }
1711: }
1712:
1.120 www 1713: sub overview {
1714: my $r=shift;
1715: my $bodytag=&Apache::loncommon::bodytag(
1716: 'Set/Modify Course Assessment Parameters');
1717: my $dom = $ENV{'course.'.$ENV{'request.course.id'}.'.domain'};
1718: my $crs = $ENV{'course.'.$ENV{'request.course.id'}.'.num'};
1719: $r->print(<<ENDOVER);
1720: <html>
1721: <head>
1722: <title>LON-CAPA Course Environment</title>
1723: </head>
1724: $bodytag
1.123 www 1725: <form method="post" action="/adm/parmset" name="overviewform">
1.120 www 1726: <input type="hidden" name="overview" value="1" />
1727: ENDOVER
1.124 www 1728: # Setting
1729: my %olddata=&Apache::lonnet::dump('resourcedata',$dom,$crs);
1730: my %newdata=();
1731: undef %newdata;
1732: my @deldata=();
1733: undef @deldata;
1734: foreach (keys %ENV) {
1735: if ($_=~/^form\.([a-z]+)\_(.+)$/) {
1736: my $cmd=$1;
1737: my $thiskey=$2;
1738: if ($cmd eq 'set') {
1739: my $data=$ENV{$_};
1740: if ($olddata{$thiskey} ne $data) { $newdata{$thiskey}=$data; }
1741: } elsif ($cmd eq 'del') {
1742: push (@deldata,$thiskey);
1743: } elsif ($cmd eq 'datepointer') {
1744: my $data=&Apache::lonhtmlcommon::get_date_from_form($ENV{$_});
1745: if ($olddata{$thiskey} ne $data) { $newdata{$thiskey}=$data; }
1746: }
1747: }
1748: }
1749: # Store
1750: &Apache::lonnet::del('resourcedata',\@deldata,$dom,$crs);
1751: &Apache::lonnet::put('resourcedata',\%newdata,$dom,$crs);
1.122 www 1752: # Read and display
1753: my %resourcedata=&Apache::lonnet::dump('resourcedata',$dom,$crs);
1754: my $oldsection='';
1755: my $oldrealm='';
1756: my $oldpart='';
1.123 www 1757: my $pointer=0;
1.124 www 1758: $tableopen=0;
1.122 www 1759: foreach my $thiskey (sort keys %resourcedata) {
1.123 www 1760: if ($resourcedata{$thiskey.'.type'}) {
1761: my ($course,$middle,$part,$name)=
1762: ($thiskey=~/^(\w+)\.(?:(.+)\.)*([\w\s]+)\.(\w+)$/);
1.130 www 1763: my $section=&mt('All Students');
1.122 www 1764: if ($middle=~/^\[(.*)\]\./) {
1.130 www 1765: $section=&mt('Group/Section').': '.$1;
1.122 www 1766: $middle=~s/^\[(.*)\]\.//;
1767: }
1.123 www 1768: $middle=~s/\.$//;
1.130 www 1769: my $realm='<font color="red">'.&mt('All Resources').'</font>';
1.122 www 1770: if ($middle=~/^(.+)\_\_\_\(all\)$/) {
1.130 www 1771: $realm='<font color="green">'.&mt('Folder/Map').': '.&Apache::lonnet::gettitle($1).'</font>';
1.122 www 1772: } elsif ($middle) {
1.130 www 1773: $realm='<font color="orange">'.&mt('Resource').': '.&Apache::lonnet::gettitle($middle).'</font>';
1.122 www 1774: }
1775: if ($section ne $oldsection) {
1.124 www 1776: $r->print(&tableend()."\n<hr /><h1>$section</h1>");
1.122 www 1777: $oldsection=$section;
1778: $oldrealm='';
1779: }
1780: if ($realm ne $oldrealm) {
1.124 www 1781: $r->print(&tableend()."\n<h2>$realm</h2>");
1.122 www 1782: $oldrealm=$realm;
1783: $oldpart='';
1784: }
1785: if ($part ne $oldpart) {
1.124 www 1786: $r->print(&tableend().
1.130 www 1787: "\n<h3><font color='blue'>".&mt('Part').": $part</font></h3>");
1.122 www 1788: $oldpart=$part;
1789: }
1.123 www 1790: #
1791: # Ready to print
1792: #
1.124 www 1793: $r->print(&tablestart().'<tr><td><b>'.$name.
1794: ':</b></td><td><input type="checkbox" name="del_'.
1795: $thiskey.'" /></td><td>');
1.123 www 1796: if ($resourcedata{$thiskey.'.type'}=~/^date/) {
1797: my $jskey='key_'.$pointer;
1798: $pointer++;
1799: $r->print(
1800: &Apache::lonhtmlcommon::date_setter('overviewform',
1801: $jskey,
1802: $resourcedata{$thiskey}).
1803: '<input type="hidden" name="datepointer_'.$thiskey.'" value="'.$jskey.'" />'
1804: );
1805: } else {
1806: $r->print(
1807: '<input type="text" name="set_'.$thiskey.'" value="'.
1808: $resourcedata{$thiskey}.'">');
1809: }
1.124 www 1810: $r->print('</td></tr>');
1.122 www 1811: }
1.121 www 1812: }
1.124 www 1813:
1814: $r->print(&tableend().
1.130 www 1815: '<p><input type="submit" value="'.&mt('Modify Parameters').'" /></p></form></body></html>');
1.120 www 1816: }
1.121 www 1817:
1.59 matthew 1818: ##################################################
1819: ##################################################
1.30 www 1820:
1.59 matthew 1821: =pod
1822:
1.83 bowersj2 1823: =item * handler
1.59 matthew 1824:
1825: Main handler. Calls &assessparms and &crsenv subroutines.
1826:
1827: =cut
1828:
1829: ##################################################
1830: ##################################################
1.85 bowersj2 1831: use Data::Dumper;
1.30 www 1832: sub handler {
1.43 albertel 1833: my $r=shift;
1.30 www 1834:
1.43 albertel 1835: if ($r->header_only) {
1.126 www 1836: &Apache::loncommon::content_type($r,'text/html');
1.43 albertel 1837: $r->send_http_header;
1838: return OK;
1839: }
1840: &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'});
1.131 www 1841:
1842: # ----------------------------------------------------------- Clear out garbage
1843:
1.132 albertel 1844: %courseopt=();
1845: %useropt=();
1846: %parmhash=();
1.131 www 1847:
1.132 albertel 1848: @ids=();
1849: %symbp=();
1850: %mapp=();
1851: %typep=();
1852: %keyp=();
1.131 www 1853:
1.132 albertel 1854: %maptitles=();
1.83 bowersj2 1855:
1.30 www 1856: # ----------------------------------------------------- Needs to be in a course
1857:
1.43 albertel 1858: if (($ENV{'request.course.id'}) &&
1859: (&Apache::lonnet::allowed('opa',$ENV{'request.course.id'}))) {
1.106 www 1860:
1.126 www 1861: &Apache::loncommon::content_type($r,'text/html');
1.106 www 1862: $r->send_http_header;
1.57 albertel 1863:
1864: $coursename=$ENV{'course.'.$ENV{'request.course.id'}.'.description'};
1.30 www 1865:
1.121 www 1866: if (($ENV{'form.crsenv'}) || (!$ENV{'request.course.fn'})) {
1.30 www 1867: # ---------------------------------------------- This is for course environment
1.121 www 1868: # -------------------------- also call if toplevel map coudl not be initialized
1869: &crsenv($r);
1.120 www 1870: } elsif ($ENV{'form.overview'}) {
1.121 www 1871: # --------------------------------------------------------------- Overview mode
1872: &overview($r);
1.43 albertel 1873: } else {
1.121 www 1874: # --------------------------------------------------------- Bring up assessment
1875: &assessparms($r);
1.43 albertel 1876: }
1877: } else {
1.1 www 1878: # ----------------------------- Not in a course, or not allowed to modify parms
1.43 albertel 1879: $ENV{'user.error.msg'}=
1880: "/adm/parmset:opa:0:0:Cannot modify assessment parameters";
1881: return HTTP_NOT_ACCEPTABLE;
1882: }
1883: return OK;
1.1 www 1884: }
1885:
1886: 1;
1887: __END__
1888:
1.59 matthew 1889: =pod
1.38 harris41 1890:
1891: =back
1892:
1893: =cut
1.1 www 1894:
1895:
1896:
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>