version 1.561, 2016/07/15 18:03:52
|
version 1.569, 2016/10/25 16:38:54
|
Line 367 sub endSettingsScreen {
|
Line 367 sub endSettingsScreen {
|
|
|
|
|
################################################## |
################################################## |
# TABLE MODE |
# (mostly) TABLE MODE |
# (parmval is also used for the log of parameter changes) |
# (parmval is also used for the log of parameter changes) |
################################################## |
################################################## |
|
|
# Calls parmval_by_symb, getting the symb from $id (the big hash resource id) with &symbcache. |
# Calls parmval_by_symb, getting the symb from $id with &symbcache. |
# |
# |
# @param {string} $what - part info and parameter name separated by a dot, e.g. '0.weight' |
# @param {string} $what - part info and parameter name separated by a dot, e.g. '0.weight' |
# @param {string} $id - big hash resource id |
# @param {string} $id - resource id or map pc |
# @param {string} $def - the resource's default value for this parameter |
# @param {string} $def - the resource's default value for this parameter |
# @param {string} $uname - user name |
# @param {string} $uname - user name |
# @param {string} $udom - user domain |
# @param {string} $udom - user domain |
Line 394 sub parmval {
|
Line 394 sub parmval {
|
# (level 1 is the most specific and will have precedence) |
# (level 1 is the most specific and will have precedence) |
# |
# |
# @param {string} $what - part info and parameter name separated by a dot, e.g. '0.weight' |
# @param {string} $what - part info and parameter name separated by a dot, e.g. '0.weight' |
# @param {string} $symb - resource symb |
# @param {string} $symb - resource symb or map src |
# @param {string} $def - the resource's default value for this parameter |
# @param {string} $def - the resource's default value for this parameter |
# @param {string} $uname - user name |
# @param {string} $uname - user name |
# @param {string} $udom - user domain |
# @param {string} $udom - user domain |
Line 597 sub reset_caches {
|
Line 597 sub reset_caches {
|
} |
} |
} |
} |
|
|
# cache big hash id -> symb, using lonnavmaps to find association |
# cache resource id or map pc -> resource symb or map src, using lonnavmaps to find association |
{ |
{ |
my $symbsid; # course identifier, to initialize the cache only once for a course |
my $symbsid; # course identifier, to initialize the cache only once for a course |
my %symbs; # hash id->symb |
my %symbs; # hash id->symb |
Line 607 sub reset_caches {
|
Line 607 sub reset_caches {
|
undef(%symbs); |
undef(%symbs); |
} |
} |
|
|
# returns the symb corresponding to a big hash id (using lonnavmaps and a cache) |
# returns the resource symb or map src corresponding to a resource id or map pc |
|
# (using lonnavmaps and a cache) |
sub symbcache { |
sub symbcache { |
my $id=shift; |
my $id=shift; |
if ($symbsid ne $env{'request.course.id'}) { |
if ($symbsid ne $env{'request.course.id'}) { |
Line 718 sub date_sanity_info {
|
Line 719 sub date_sanity_info {
|
|
|
# Store a parameter value and type by ID, also triggering more parameter changes based on parameter default actions. |
# Store a parameter value and type by ID, also triggering more parameter changes based on parameter default actions. |
# |
# |
# @param {string} $sresid - resource big hash id |
# @param {string} $sresid - resource id or map pc |
# @param {string} $spnam - part info and parameter name separated by a dot, e.g. '0.weight' |
# @param {string} $spnam - part info and parameter name separated by a dot or underscore, e.g. '0.weight' |
# @param {integer} $snum - level |
# @param {integer} $snum - level |
# @param {string} $nval - new value |
# @param {string} $nval - new value |
# @param {string} $ntype - new type |
# @param {string} $ntype - new type |
Line 737 my %recstack; # hash parameter name -> 1
|
Line 738 my %recstack; # hash parameter name -> 1
|
# Store a parameter value and type by symb, also triggering more parameter changes based on parameter default actions. |
# Store a parameter value and type by symb, also triggering more parameter changes based on parameter default actions. |
# Uses storeparm_by_symb_inner to actually store the parameter, ignoring any returned error. |
# Uses storeparm_by_symb_inner to actually store the parameter, ignoring any returned error. |
# |
# |
# @param {string} $symb - resource symb |
# @param {string} $symb - resource symb or map src |
# @param {string} $spnam - part info and parameter name separated by a dot, e.g. '0.weight' |
# @param {string} $spnam - part info and parameter name separated by a dot or underscore, e.g. '0.weight' |
# @param {integer} $snum - level |
# @param {integer} $snum - level |
# @param {string} $nval - new value |
# @param {string} $nval - new value |
# @param {string} $ntype - new type |
# @param {string} $ntype - new type |
Line 776 sub storeparm_by_symb {
|
Line 777 sub storeparm_by_symb {
|
# are there restrictions? |
# are there restrictions? |
if (&rulescache($triggered.'_triggervalue')=~/\w/) { |
if (&rulescache($triggered.'_triggervalue')=~/\w/) { |
$active=0; |
$active=0; |
foreach my $possiblevalue (split(/\s*\, |
foreach my $possiblevalue (split(/\s*\,\s*/,&rulescache($triggered.'_triggervalue'))) { |
\s*/,&rulescache($triggered.'_triggervalue'))) { |
|
if (lc($possiblevalue) eq lc($nval)) { $active=1; } |
if (lc($possiblevalue) eq lc($nval)) { $active=1; } |
} |
} |
} |
} |
Line 808 sub log_parmset {
|
Line 808 sub log_parmset {
|
# Store a parameter value and type by symb, without using the parameter default actions. |
# Store a parameter value and type by symb, without using the parameter default actions. |
# Expire related sheets. |
# Expire related sheets. |
# |
# |
# @param {string} $symb - resource symb |
# @param {string} $symb - resource symb or map src |
# @param {string} $spnam - part info and parameter name separated by a dot, e.g. '0.weight' |
# @param {string} $spnam - part info and parameter name separated by a dot, e.g. '0.weight' |
# @param {integer} $snum - level |
# @param {integer} $snum - level |
# @param {string} $nval - new value |
# @param {string} $nval - new value |
Line 1065 sub page_js {
|
Line 1065 sub page_js {
|
document.parmform.action+='#'+document.parmform.pres_marker.value; |
document.parmform.action+='#'+document.parmform.pres_marker.value; |
var typedef=new Array(); |
var typedef=new Array(); |
typedef=document.parmform.pres_type.value.split('_'); |
typedef=document.parmform.pres_type.value.split('_'); |
if (document.parmform.pres_type.value!='') { |
if (document.parmform.pres_type.value!='') { |
if (typedef[0]=='date') { |
if (typedef[0]=='date') { |
eval('document.parmform.recent_'+ |
eval('document.parmform.recent_'+ |
document.parmform.pres_type.value+ |
document.parmform.pres_type.value+ |
'.value=document.parmform.pres_value.value;'); |
'.value=document.parmform.pres_value.value;'); |
} else { |
} else { |
eval('document.parmform.recent_'+typedef[0]+ |
eval('document.parmform.recent_'+typedef[0]+ |
'.value=document.parmform.pres_value.value;'); |
'.value=document.parmform.pres_value.value;'); |
|
} |
} |
} |
} |
|
document.parmform.submit(); |
document.parmform.submit(); |
} else { |
} else { |
document.parmform.pres_value.value=''; |
document.parmform.pres_value.value=''; |
Line 1365 ENDHEAD
|
Line 1365 ENDHEAD
|
# @param {string} $which - parameter key ('parameter_'.part.'_'.name) |
# @param {string} $which - parameter key ('parameter_'.part.'_'.name) |
# @param {hash reference} $part - parameter key -> parameter part (can be problem part.'_'.response id for response parameters) |
# @param {hash reference} $part - parameter key -> parameter part (can be problem part.'_'.response id for response parameters) |
# @param {hash reference} $name - parameter key -> parameter name |
# @param {hash reference} $name - parameter key -> parameter name |
# @param {hash reference} $symbp - resource id -> symb |
# @param {hash reference} $symbp - map pc or resource/map id -> map src.'___(all)' or resource symb |
# @param {string} $rid - resource id |
# @param {string} $rid - resource id |
# @param {hash reference} $default - parameter key -> resource parameter default value |
# @param {hash reference} $default - parameter key -> resource parameter default value |
# @param {hash reference} $defaulttype - parameter key -> resource parameter default type |
# @param {hash reference} $defaulttype - parameter key -> resource parameter default type |
Line 1380 ENDHEAD
|
Line 1380 ENDHEAD
|
# @param {string} $cgroup - group name |
# @param {string} $cgroup - group name |
# @param {array reference} $usersgroups - list of groups the user belongs to, if any |
# @param {array reference} $usersgroups - list of groups the user belongs to, if any |
# @param {boolean} $noeditgrp - true if no edit is allowed for group level parameters |
# @param {boolean} $noeditgrp - true if no edit is allowed for group level parameters |
|
# @param {boolean} $readonly - true if no editing allowed. |
sub print_row { |
sub print_row { |
my ($r,$which,$part,$name,$symbp,$rid,$default,$defaulttype,$display,$defbgone, |
my ($r,$which,$part,$name,$symbp,$rid,$default,$defaulttype,$display,$defbgone, |
$defbgtwo,$defbgthree,$parmlev,$uname,$udom,$csec,$cgroup,$usersgroups,$noeditgrp)=@_; |
$defbgtwo,$defbgthree,$parmlev,$uname,$udom,$csec,$cgroup,$usersgroups,$noeditgrp, |
|
$readonly)=@_; |
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $courseopt=&Apache::lonnet::get_courseresdata($cnum,$cdom); |
my $courseopt=&Apache::lonnet::get_courseresdata($cnum,$cdom); |
Line 1427 sub print_row {
|
Line 1429 sub print_row {
|
|
|
if ($parmlev eq 'general') { |
if ($parmlev eq 'general') { |
if ($uname) { |
if ($uname) { |
&print_td($r,4,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,4,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
} elsif ($cgroup) { |
} elsif ($cgroup) { |
&print_td($r,8,$defbgthree,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,$noeditgrp); |
&print_td($r,8,$defbgthree,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,$noeditgrp,$readonly); |
} elsif ($csec) { |
} elsif ($csec) { |
&print_td($r,12,$defbgtwo,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,12,$defbgtwo,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
} else { |
} else { |
&print_td($r,18,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,18,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
} |
} |
} elsif ($parmlev eq 'map') { |
} elsif ($parmlev eq 'map') { |
if ($uname) { |
if ($uname) { |
&print_td($r,3,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,3,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
&print_td($r,2,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,2,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
} elsif ($cgroup) { |
} elsif ($cgroup) { |
&print_td($r,7,$defbgthree,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,$noeditgrp); |
&print_td($r,7,$defbgthree,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,$noeditgrp,$readonly); |
&print_td($r,6,$defbgthree,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,$noeditgrp); |
&print_td($r,6,$defbgthree,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,$noeditgrp,$readonly); |
} elsif ($csec) { |
} elsif ($csec) { |
&print_td($r,11,$defbgtwo,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,11,$defbgtwo,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
&print_td($r,10,$defbgtwo,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,10,$defbgtwo,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
} else { |
} else { |
&print_td($r,17,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,17,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
&print_td($r,16,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,16,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
} |
} |
} else { |
} else { |
if ($uname) { |
if ($uname) { |
Line 1467 sub print_row {
|
Line 1469 sub print_row {
|
} |
} |
} |
} |
|
|
&print_td($r,18,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,18,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
&print_td($r,17,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,17,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
&print_td($r,16,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,16,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
&print_td($r,15,'#FFDDDD',$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,15,'#FFDDDD',$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
&print_td($r,14,'#FFDDDD',$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,14,'#FFDDDD',$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
&print_td($r,13,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,13,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
|
|
if ($csec) { |
if ($csec) { |
&print_td($r,12,$defbgtwo,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,12,$defbgtwo,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
&print_td($r,11,$defbgtwo,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,11,$defbgtwo,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
&print_td($r,10,$defbgtwo,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,10,$defbgtwo,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
&print_td($r,9,$defbgtwo,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,9,$defbgtwo,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
} |
} |
|
|
if ($cgroup) { |
if ($cgroup) { |
&print_td($r,8,$defbgthree,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,$noeditgrp); |
&print_td($r,8,$defbgthree,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,$noeditgrp,$readonly); |
&print_td($r,7,$defbgthree,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,$noeditgrp); |
&print_td($r,7,$defbgthree,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,$noeditgrp,$readonly); |
&print_td($r,6,$defbgthree,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,$noeditgrp); |
&print_td($r,6,$defbgthree,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,$noeditgrp,$readonly); |
&print_td($r,5,$defbgthree,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,$noeditgrp); |
&print_td($r,5,$defbgthree,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,$noeditgrp.$readonly); |
} |
} |
|
|
if ($uname) { |
if ($uname) { |
if ($othergrp) { |
if ($othergrp) { |
$r->print($othergrp); |
$r->print($othergrp); |
} |
} |
&print_td($r,4,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,4,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
&print_td($r,3,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,3,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
&print_td($r,2,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,2,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
&print_td($r,1,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display); |
&print_td($r,1,$defbgone,$result,\@outpar,$mprefix,$which,\@typeoutpar,$display,'',$readonly); |
} |
} |
|
|
} # end of $parmlev if/else |
} # end of $parmlev if/else |
Line 1532 sub print_row {
|
Line 1534 sub print_row {
|
# @param {array reference} $typeoutpar - array level -> parameter type (when defined) |
# @param {array reference} $typeoutpar - array level -> parameter type (when defined) |
# @param {hash reference} $display - parameter key -> full title for the parameter |
# @param {hash reference} $display - parameter key -> full title for the parameter |
# @param {boolean} $noeditgrp - true if no edit is allowed for group level parameters |
# @param {boolean} $noeditgrp - true if no edit is allowed for group level parameters |
|
# @param {boolean} $readonly -true if editing not allowed. |
sub print_td { |
sub print_td { |
my ($r,$which,$defbg,$result,$outpar,$mprefix,$value,$typeoutpar,$display,$noeditgrp)=@_; |
my ($r,$which,$defbg,$result,$outpar,$mprefix,$value,$typeoutpar,$display,$noeditgrp,$readonly)=@_; |
$r->print('<td style="background-color:'.(($result==$which)?'#AAFFAA':$defbg). |
$r->print('<td style="background-color:'.(($result==$which)?'#AAFFAA':$defbg). |
';" align="center">'); |
';" align="center">'); |
my $nolink = 0; |
my $nolink = 0; |
if ($which == 14 || $which == 15) { |
if ($readonly) { |
$nolink = 1; |
|
} elsif (($env{'request.course.sec'} ne '') && ($which > 12)) { |
|
$nolink = 1; |
$nolink = 1; |
} elsif ($which == 5 || $which == 6 || $which == 7 || $which == 8) { |
} else { |
if ($noeditgrp) { |
if ($which == 14 || $which == 15) { |
$nolink = 1; |
|
} |
|
} elsif ($mprefix =~ /availablestudent\&$/) { |
|
if ($which > 4) { |
|
$nolink = 1; |
$nolink = 1; |
} |
} elsif (($env{'request.course.sec'} ne '') && ($which > 12)) { |
} elsif ($mprefix =~ /examcode\&$/) { |
|
unless ($which == 2) { |
|
$nolink = 1; |
$nolink = 1; |
|
} elsif ($which == 5 || $which == 6 || $which == 7 || $which == 8) { |
|
if ($noeditgrp) { |
|
$nolink = 1; |
|
} |
|
} elsif ($mprefix =~ /availablestudent\&$/) { |
|
if ($which > 4) { |
|
$nolink = 1; |
|
} |
|
} elsif ($mprefix =~ /examcode\&$/) { |
|
unless ($which == 2) { |
|
$nolink = 1; |
|
} |
} |
} |
} |
} |
if ($nolink) { |
if ($nolink) { |
Line 1648 sub parm_control_group {
|
Line 1655 sub parm_control_group {
|
|
|
|
|
|
|
# extracts lots of information about all of the the course's resources into a variety of hashes. |
# Extracts lots of information about all of the the course's resources into a variety of hashes, using lonnavmaps and lonnet::metadata. |
|
# All the parameters are references and are filled by the sub. |
|
# |
|
# @param {array reference} $ids - resource and map ids |
|
# @param {hash reference} $typep - hash resource/map id -> resource type (file extension) |
|
# @param {hash reference} $keyp - hash resource/map id -> comma-separated list of parameter keys from lonnet::metadata |
|
# @param {hash reference} $allparms - hash parameter name -> parameter title |
|
# @param {hash reference} $allparts - hash parameter part -> part title (a parameter part can be problem part.'_'.response id for response parameters) |
|
# @param {hash reference} $allmaps - hash map pc -> map src |
|
# @param {hash reference} $mapp - hash map pc or resource/map id -> enclosing map src |
|
# @param {hash reference} $symbp - hash map pc or resource/map id -> map src.'___(all)' for a map or resource symb for a resource |
|
# @param {hash reference} $maptitles - hash map pc or src -> map title (this should really be two separate hashes) |
|
# @param {hash reference} $uris - hash resource/map id -> resource src |
|
# @param {hash reference} $keyorder - hash parameter key -> appearance rank for this parameter when looking through every resource and every parameter, starting at 100 (integer) |
|
# @param {hash reference} $defkeytype - hash parameter name -> parameter type |
sub extractResourceInformation { |
sub extractResourceInformation { |
my $ids = shift; |
my $ids = shift; |
my $typep = shift; |
my $typep = shift; |
Line 1749 sub extractResourceInformation {
|
Line 1770 sub extractResourceInformation {
|
} |
} |
|
|
|
|
|
# Tells if a parameter type is a date. |
|
# |
|
# @param {string} type - parameter type |
|
# @returns{boolean} - true if it is a date |
sub isdateparm { |
sub isdateparm { |
my $type=shift; |
my $type=shift; |
return (($type=~/^date/) && (!($type eq 'date_interval'))); |
return (($type=~/^date/) && (!($type eq 'date_interval'))); |
} |
} |
|
|
|
# Prints the HTML and Javascript to select parameters, with various shortcuts. |
|
# FIXME: remove unused parameters |
# |
# |
# parmmenu displays a list of the selected parameters. |
# @param {Apache2::RequestRec} $r - the Apache request (unused) |
# It also offers a link to show/hide the complete parameter list |
# @param {hash reference} $allparms - hash parameter name -> parameter title |
# from which you can select all desired parameters. |
# @param {array reference} $pscat - list of selected parameter names (unused) |
# |
# @param {hash reference} $keyorder - hash parameter key -> appearance rank (unused) |
sub parmmenu { |
sub parmmenu { |
my ($r,$allparms,$pscat,$keyorder)=@_; |
my ($r,$allparms,$pscat,$keyorder)=@_; |
my $tempkey; |
my $tempkey; |
Line 1775 sub parmmenu {
|
Line 1801 sub parmmenu {
|
displayOverview = "none" |
displayOverview = "none" |
} |
} |
|
|
for (i=0; i<document.forms.parmform.elements.length; i++) { |
for (i=0; i<document.forms.parmform.elements.length; i++) { |
ele = document.forms.parmform.elements[i]; |
ele = document.forms.parmform.elements[i]; |
if (ele.name == checkName) { |
if (ele.name == checkName) { |
document.forms.parmform.elements[i].checked=value; |
document.forms.parmform.elements[i].checked=value; |
Line 1784 sub parmmenu {
|
Line 1810 sub parmmenu {
|
} |
} |
|
|
function checkthis(thisvalue, checkName) { |
function checkthis(thisvalue, checkName) { |
|
for (i=0; i<document.forms.parmform.elements.length; i++) { |
|
|
for (i=0; i<document.forms.parmform.elements.length; i++) { |
|
ele = document.forms.parmform.elements[i]; |
ele = document.forms.parmform.elements[i]; |
if (ele.name == checkName) { |
if (ele.name == checkName) { |
if (ele.value == thisvalue) { |
if (ele.value == thisvalue) { |
document.forms.parmform.elements[i].checked=true; |
document.forms.parmform.elements[i].checked=true; |
} |
} |
} |
} |
} |
} |
} |
} |
|
|
function checkdates() { |
function checkdates() { |
checkthis('duedate','pscat'); |
checkthis('duedate','pscat'); |
checkthis('opendate','pscat'); |
checkthis('opendate','pscat'); |
checkthis('answerdate','pscat'); |
checkthis('answerdate','pscat'); |
} |
} |
|
|
function checkdisset() { |
function checkdisset() { |
checkthis('discussend','pscat'); |
checkthis('discussend','pscat'); |
checkthis('discusshide','pscat'); |
checkthis('discusshide','pscat'); |
checkthis('discussvote','pscat'); |
checkthis('discussvote','pscat'); |
} |
} |
|
|
function checkcontdates() { |
function checkcontdates() { |
checkthis('contentopen','pscat'); |
checkthis('contentopen','pscat'); |
checkthis('contentclose','pscat'); |
checkthis('contentclose','pscat'); |
} |
} |
|
|
function checkvisi() { |
function checkvisi() { |
checkthis('hiddenresource','pscat'); |
checkthis('hiddenresource','pscat'); |
checkthis('encrypturl','pscat'); |
checkthis('encrypturl','pscat'); |
checkthis('problemstatus','pscat'); |
checkthis('problemstatus','pscat'); |
checkthis('contentopen','pscat'); |
checkthis('contentopen','pscat'); |
checkthis('opendate','pscat'); |
checkthis('opendate','pscat'); |
} |
} |
|
|
function checkparts() { |
function checkparts() { |
checkthis('hiddenparts','pscat'); |
checkthis('hiddenparts','pscat'); |
checkthis('display','pscat'); |
checkthis('display','pscat'); |
checkthis('ordered','pscat'); |
checkthis('ordered','pscat'); |
} |
} |
|
|
function checkstandard() { |
function checkstandard() { |
checkall(false,'pscat'); |
checkall(false,'pscat'); |
checkdates(); |
checkdates(); |
checkthis('weight','pscat'); |
checkthis('weight','pscat'); |
checkthis('maxtries','pscat'); |
checkthis('maxtries','pscat'); |
checkthis('type','pscat'); |
checkthis('type','pscat'); |
checkthis('problemstatus','pscat'); |
checkthis('problemstatus','pscat'); |
} |
} |
|
|
// ]]> |
// ]]> |
Line 1844 ENDSCRIPT
|
Line 1868 ENDSCRIPT
|
&shortCuts($r,$allparms,$pscat,$keyorder); |
&shortCuts($r,$allparms,$pscat,$keyorder); |
$r->print('<hr />'); |
$r->print('<hr />'); |
} |
} |
# return a hash |
|
|
# Returns parameter categories. |
|
# |
|
# @returns {hash} - category name -> title in English |
sub categories { |
sub categories { |
return ('time_settings' => 'Time Settings', |
return ('time_settings' => 'Time Settings', |
'grading' => 'Grading', |
'grading' => 'Grading', |
Line 1858 sub categories {
|
Line 1885 sub categories {
|
'misc' => 'Miscellaneous' ); |
'misc' => 'Miscellaneous' ); |
} |
} |
|
|
# return a hash. Like a look-up table |
# Returns the category for each parameter. |
|
# |
|
# @returns {hash} - parameter name -> category name |
sub lookUpTableParameter { |
sub lookUpTableParameter { |
|
|
return ( |
return ( |
Line 1909 sub lookUpTableParameter {
|
Line 1938 sub lookUpTableParameter {
|
); |
); |
} |
} |
|
|
|
# Adds the given parameter name to an array of arrays listing all parameters for each category. |
|
# |
|
# @param {string} $name - parameter name |
|
# @param {array reference} $catList - array reference category name -> array reference of parameter names |
sub whatIsMyCategory { |
sub whatIsMyCategory { |
my $name = shift; |
my $name = shift; |
my $catList = shift; |
my $catList = shift; |
Line 1932 sub whatIsMyCategory {
|
Line 1965 sub whatIsMyCategory {
|
} |
} |
} |
} |
|
|
|
# Sorts parameter names based on appearance order. |
|
# |
|
# @param {array reference} name - array reference of parameter names |
|
# @param {hash reference} $keyorder - hash parameter key -> appearance rank |
|
# @returns {Array} - array of parameter names |
sub keysindisplayorderCategory { |
sub keysindisplayorderCategory { |
my ($name,$keyorder)=@_; |
my ($name,$keyorder)=@_; |
return sort { |
return sort { |
Line 1939 sub keysindisplayorderCategory {
|
Line 1977 sub keysindisplayorderCategory {
|
} ( @{$name}); |
} ( @{$name}); |
} |
} |
|
|
|
# Returns a hash category name -> order, starting at 1 (integer) |
|
# |
|
# @returns {hash} |
sub category_order { |
sub category_order { |
return ( |
return ( |
'time_settings' => 1, |
'time_settings' => 1, |
Line 1955 sub category_order {
|
Line 1996 sub category_order {
|
|
|
} |
} |
|
|
|
# Prints HTML to let the user select parameters, from a list of all parameters organized by category. |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
|
# @param {hash reference} $allparms - hash parameter name -> parameter title |
|
# @param {array reference} $pscat - list of selected parameter names |
|
# @param {hash reference} $keyorder - hash parameter key -> appearance rank |
sub parmboxes { |
sub parmboxes { |
my ($r,$allparms,$pscat,$keyorder)=@_; |
my ($r,$allparms,$pscat,$keyorder)=@_; |
my %categories = &categories(); |
my %categories = &categories(); |
Line 1996 sub parmboxes {
|
Line 2043 sub parmboxes {
|
} |
} |
$r->print("\n"); |
$r->print("\n"); |
} |
} |
|
|
|
# Prints HTML with shortcuts to select groups of parameters in one click, or deselect all. |
|
# FIXME: remove unused parameters |
# |
# |
# This function offers some links on the parameter section to get with one click a group a parameters |
# @param {Apache2::RequestRec} $r - the Apache request |
# |
# @param {hash reference} $allparms - hash parameter name -> parameter title (unused) |
|
# @param {array reference} $pscat - list of selected parameter names (unused) |
|
# @param {hash reference} $keyorder - hash parameter key -> appearance rank (unused) |
sub shortCuts { |
sub shortCuts { |
my ($r,$allparms,$pscat,$keyorder)=@_; |
my ($r,$allparms,$pscat,$keyorder)=@_; |
|
|
Line 2031 sub shortCuts {
|
Line 2083 sub shortCuts {
|
); |
); |
} |
} |
|
|
|
# Prints HTML to select parts to view (except for the title). |
|
# Used by table and overview modes. |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
|
# @param {hash reference} $allparts - hash parameter part -> part title |
|
# @param {array reference} $psprt - list of selected parameter parts |
sub partmenu { |
sub partmenu { |
my ($r,$allparts,$psprt)=@_; |
my ($r,$allparts,$psprt)=@_; |
my $selsize = 1+scalar(keys(%{$allparts})); |
my $selsize = 1+scalar(keys(%{$allparts})); |
Line 2040 sub partmenu {
|
Line 2098 sub partmenu {
|
|
|
$r->print('<select multiple="multiple" name="psprt" size="'.$selsize.'">'); |
$r->print('<select multiple="multiple" name="psprt" size="'.$selsize.'">'); |
$r->print('<option value="all"'); |
$r->print('<option value="all"'); |
$r->print(' selected="selected"') unless (@{$psprt}); |
$r->print(' selected="selected"') unless (@{$psprt}); # useless, the array is never empty |
$r->print('>'.&mt('All Parts').'</option>'); |
$r->print('>'.&mt('All Parts').'</option>'); |
my %temphash=(); |
my %temphash=(); |
foreach (@{$psprt}) { $temphash{$_}=1; } |
foreach (@{$psprt}) { $temphash{$_}=1; } |
Line 2058 sub partmenu {
|
Line 2116 sub partmenu {
|
$r->print('</select>'); |
$r->print('</select>'); |
} |
} |
|
|
|
# Prints HTML to select a user and/or a group. |
|
# Used by table mode. |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
|
# @param {string} $uname - selected user name |
|
# @param {string} $id - selected Student/Employee ID |
|
# @param {string} $udom - selected user domain |
|
# @param {string} $csec - selected section name |
|
# @param {string} $cgroup - selected group name |
|
# @param {string} $parmlev - parameter level (Resource:'full', Map:'map', Course:'general') |
|
# @param {array reference} $usersgroups - list of groups the user belongs to, if any |
|
# @param {string} $pssymb - resource symb (when a single resource is selected) |
sub usermenu { |
sub usermenu { |
my ($r,$uname,$id,$udom,$csec,$cgroup,$parmlev,$usersgroups,$pssymb)=@_; |
my ($r,$uname,$id,$udom,$csec,$cgroup,$parmlev,$usersgroups,$pssymb)=@_; |
my $chooseopt=&Apache::loncommon::select_dom_form($udom,'udom').' '. |
my $chooseopt=&Apache::loncommon::select_dom_form($udom,'udom').' '. |
Line 2168 function group_or_section(caller) {
|
Line 2238 function group_or_section(caller) {
|
,$chooseopt)); |
,$chooseopt)); |
} |
} |
|
|
|
# Prints HTML to select parameters from a list of all parameters. |
|
# Uses parmmenu and parmboxes. |
|
# Used by table and overview modes. |
# |
# |
# This function shows on table Mode the available Parameters for the selected Resources |
# @param {Apache2::RequestRec} $r - the Apache request |
# |
# @param {hash reference} $allparms - hash parameter name -> parameter title |
|
# @param {array reference} $pscat - list of selected parameter names |
|
# @param {array reference} $psprt - list of selected parameter parts (unused) |
|
# @param {hash reference} $keyorder - hash parameter key -> appearance rank |
|
# @param {string} [$divid] - name used to give an id to the HTML element for the scroll box |
sub displaymenu { |
sub displaymenu { |
my ($r,$allparms,$pscat,$psprt,$keyorder,$divid)=@_; |
my ($r,$allparms,$pscat,$psprt,$keyorder,$divid)=@_; |
|
|
$r->print(&Apache::lonhtmlcommon::start_pick_box()); |
$r->print(&Apache::lonhtmlcommon::start_pick_box()); |
$r->print(&Apache::lonhtmlcommon::row_title(&mt('Select Parameters to View'))); |
$r->print(&Apache::lonhtmlcommon::row_title(&mt('Select Parameters to View'))); |
|
|
&parmmenu($r,$allparms,$pscat,$keyorder); |
&parmmenu($r,$allparms,$pscat,$keyorder); # only $allparms is used by parmmenu |
$r->print(&Apache::loncommon::start_scrollbox('480px','440px','200px',$divid)); |
$r->print(&Apache::loncommon::start_scrollbox('480px','440px','200px',$divid)); |
&parmboxes($r,$allparms,$pscat,$keyorder); |
&parmboxes($r,$allparms,$pscat,$keyorder); |
$r->print(&Apache::loncommon::end_scrollbox()); |
$r->print(&Apache::loncommon::end_scrollbox()); |
Line 2187 sub displaymenu {
|
Line 2264 sub displaymenu {
|
|
|
} |
} |
|
|
|
# Prints HTML to select a map. |
|
# Used by table mode and overview mode. |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
|
# @param {hash reference} $allmaps - hash map pc -> map src |
|
# @param {string} $pschp - selected map pc, or 'all' |
|
# @param {hash reference} $maptitles - hash map id or src -> map title |
|
# @param {hash reference} $symbp - hash map pc or resource/map id -> map src.'___(all)' or resource symb |
sub mapmenu { |
sub mapmenu { |
my ($r,$allmaps,$pschp,$maptitles,$symbp)=@_; |
my ($r,$allmaps,$pschp,$maptitles,$symbp)=@_; |
my %allmaps_inverted = reverse %$allmaps; |
my %allmaps_inverted = reverse %$allmaps; |
Line 2338 sub mapmenu {
|
Line 2423 sub mapmenu {
|
} |
} |
} |
} |
|
|
# Build up the select Box to choose if your parameter specification should work for the resource, map/folder or the course level |
# Prints HTML to select the parameter level (resource, map/folder or course). |
# The value of default selection in the select box is set by the value that is given by the argument in $parmlev. |
# Used by table and overview modes. |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
|
# @param {hash reference} $alllevs - all parameter levels, hash English title -> value |
|
# @param {string} $parmlev - selected level value (full|map|general), or '' |
sub levelmenu { |
sub levelmenu { |
my ($r,$alllevs,$parmlev)=@_; |
my ($r,$alllevs,$parmlev)=@_; |
|
|
Line 2357 sub levelmenu {
|
Line 2446 sub levelmenu {
|
} |
} |
|
|
|
|
|
# Returns HTML to select a section (with a select HTML element). |
|
# Used by overview mode. |
|
# |
|
# @param {array reference} $selectedsections - list of selected section ids |
|
# @returns {string} |
sub sectionmenu { |
sub sectionmenu { |
my ($selectedsections)=@_; |
my ($selectedsections)=@_; |
my %sectionhash = &Apache::loncommon::get_sections(); |
my %sectionhash = &Apache::loncommon::get_sections(); |
Line 2382 sub sectionmenu {
|
Line 2476 sub sectionmenu {
|
return $output; |
return $output; |
} |
} |
|
|
|
# Returns HTML to select a group (with a select HTML element). |
|
# Used by overview mode. |
|
# |
|
# @param {array reference} $selectedgroups - list of selected group names |
|
# @returns {string} |
sub groupmenu { |
sub groupmenu { |
my ($selectedgroups)=@_; |
my ($selectedgroups)=@_; |
my %grouphash; |
my %grouphash; |
Line 2404 sub groupmenu {
|
Line 2503 sub groupmenu {
|
return $output; |
return $output; |
} |
} |
|
|
|
# Returns an array with the given parameter split by comma. |
|
# Used by assessparms (table mode). |
|
# |
|
# @param {string} $keyp - the string to split |
|
# @returns {Array<string>} |
sub keysplit { |
sub keysplit { |
my $keyp=shift; |
my $keyp=shift; |
return (split(/\,/,$keyp)); |
return (split(/\,/,$keyp)); |
} |
} |
|
|
|
# Returns the keys in $name, sorted using $keyorder. |
|
# Parameters are sorted by key, which means they are sorted by part first, then by name. |
|
# Used by assessparms (table mode) for resource level. |
|
# |
|
# @param {hash reference} $name - parameter key -> parameter name |
|
# @param {hash reference} $keyorder - hash parameter key -> appearance rank |
|
# @returns {Array<string>} |
sub keysinorder { |
sub keysinorder { |
my ($name,$keyorder)=@_; |
my ($name,$keyorder)=@_; |
return sort { |
return sort { |
Line 2416 sub keysinorder {
|
Line 2527 sub keysinorder {
|
} (keys(%{$name})); |
} (keys(%{$name})); |
} |
} |
|
|
|
# Returns the keys in $name, sorted using $keyorder to sort parameters by name first, then by part. |
|
# Used by assessparms (table mode) for map and general levels. |
|
# |
|
# @param {hash reference} $name - parameter key -> parameter name |
|
# @param {hash reference} $keyorder - hash parameter key -> appearance rank |
|
# @returns {Array<string>} |
sub keysinorder_bytype { |
sub keysinorder_bytype { |
my ($name,$keyorder)=@_; |
my ($name,$keyorder)=@_; |
return sort { |
return sort { |
my $ta=(split('_',$a))[-1]; |
my $ta=(split('_',$a))[-1]; # parameter name |
my $tb=(split('_',$b))[-1]; |
my $tb=(split('_',$b))[-1]; |
if ($$keyorder{'parameter_0_'.$ta} == $$keyorder{'parameter_0_'.$tb}) { |
if ($$keyorder{'parameter_0_'.$ta} == $$keyorder{'parameter_0_'.$tb}) { |
return ($a cmp $b); |
return ($a cmp $b); |
Line 2428 sub keysinorder_bytype {
|
Line 2545 sub keysinorder_bytype {
|
} (keys(%{$name})); |
} (keys(%{$name})); |
} |
} |
|
|
|
# Returns the keys in $name, sorted using $keyorder to sort parameters by name. |
|
# Used by defaultsetter (parameter settings default actions). |
|
# |
|
# @param {hash reference} $name - hash parameter name -> parameter title |
|
# @param {hash reference} $keyorder - hash parameter key -> appearance rank |
|
# @returns {Array<string>} |
sub keysindisplayorder { |
sub keysindisplayorder { |
my ($name,$keyorder)=@_; |
my ($name,$keyorder)=@_; |
return sort { |
return sort { |
Line 2435 sub keysindisplayorder {
|
Line 2558 sub keysindisplayorder {
|
} (keys(%{$name})); |
} (keys(%{$name})); |
} |
} |
|
|
|
# Prints HTML with a choice to sort results by realm or student first. |
|
# Used by overview mode. |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
|
# @param {string} $sortorder - realmstudent|studentrealm |
sub sortmenu { |
sub sortmenu { |
my ($r,$sortorder)=@_; |
my ($r,$sortorder)=@_; |
$r->print('<br /><label><input type="radio" name="sortorder" value="realmstudent"'); |
$r->print('<br /><label><input type="radio" name="sortorder" value="realmstudent"'); |
Line 2450 sub sortmenu {
|
Line 2578 sub sortmenu {
|
'</label>'); |
'</label>'); |
} |
} |
|
|
|
# Returns a hash parameter key -> order (integer) giving the order for some parameters. |
|
# |
|
# @returns {hash} |
sub standardkeyorder { |
sub standardkeyorder { |
return ('parameter_0_opendate' => 1, |
return ('parameter_0_opendate' => 1, |
'parameter_0_duedate' => 2, |
'parameter_0_duedate' => 2, |
Line 2478 sub standardkeyorder {
|
Line 2609 sub standardkeyorder {
|
|
|
|
|
# Table mode UI. |
# Table mode UI. |
|
# If nothing is selected, prints HTML forms to select resources, parts, parameters, user, group and section. |
|
# Otherwise, prints the parameter table, with a link to change the selection unless a single resource is selected. |
|
# |
|
# Parameters used from the request: |
|
# action - handler action (see handler), usermenu is checking for value 'settable' |
|
# cgroup - selected group |
|
# command - 'set': direct access to table mode for a resource |
|
# csec - selected section |
|
# dis - set when the "Update Display" button was used, used only to discard command 'set' |
|
# hideparmsel - can be 'hidden' to hide the parameter selection div initially and display the "Change Parameter Selection" link instead (which displays the div) |
|
# id - student/employee ID |
|
# parmlev - selected level (full|map|general) |
|
# part - selected part (unused ?) |
|
# pres_marker - &&&-separated parameter identifiers, "resource id&part_parameter name&level" |
|
# pres_type - &&&-separated parameter types |
|
# pres_value - &&&-separated parameter values |
|
# prevvisit - '1' if the user has submitted the form before |
|
# pscat (multiple values) - selected parameter names |
|
# pschp - selected map pc, or 'all' |
|
# psprt (multiple values) - list of selected parameter parts |
|
# filter - part of or whole parameter name, to be filtered out when parameters are displayed (unused ?) |
|
# recent_* (* = parameter type) - recent values entered by the user for parameter types |
|
# symb - resource symb (when a single resource is selected) |
|
# udom - selected user domain |
|
# uname - selected user name |
|
# url - used only with command 'set', the resource url |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
|
# @param $parm_permission - ref to hash of permissions |
|
# if $parm_permission->{'edit'} is true, editing is allowed. |
sub assessparms { |
sub assessparms { |
|
|
my $r=shift; |
my ($r,$parm_permission) = @_; |
|
|
|
|
# -------------------------------------------------------- Variable declaration |
# -------------------------------------------------------- Variable declaration |
my @ids=(); |
my @ids=(); # resource and map ids |
my %symbp=(); |
my %symbp=(); # hash map pc or resource/map id -> map src.'___(all)' or resource symb |
my %mapp=(); |
my %mapp=(); # hash map pc or resource/map id -> enclosing map src |
my %typep=(); |
my %typep=(); # hash resource/map id -> resource type (file extension) |
my %keyp=(); |
my %keyp=(); # hash resource/map id -> comma-separated list of parameter keys |
my %uris=(); |
my %uris=(); # hash resource/map id -> resource src |
my %maptitles=(); |
my %maptitles=(); # hash map pc or src -> map title |
my %allmaps=(); |
my %allmaps=(); # hash map pc -> map src |
my %alllevs=(); |
my %alllevs=(); # hash English level title -> value |
|
|
my $uname; |
my $uname; # selected user name |
my $udom; |
my $udom; # selected user domain |
my $uhome; |
my $uhome; # server with the user's files, or 'no_host' |
my $csec; |
my $csec; # selected section name |
my $cgroup; |
my $cgroup; # selected group name |
my @usersgroups = (); |
my @usersgroups = (); # list of the user groups |
|
|
my $coursename=$env{'course.'.$env{'request.course.id'}.'.description'}; |
my $coursename=$env{'course.'.$env{'request.course.id'}.'.description'}; |
|
|
Line 2507 sub assessparms {
|
Line 2668 sub assessparms {
|
$alllevs{'Map/Folder Level'}='map'; |
$alllevs{'Map/Folder Level'}='map'; |
$alllevs{'Course Level'}='general'; |
$alllevs{'Course Level'}='general'; |
|
|
my %allparms; |
my %allparms; # hash parameter name -> parameter title |
my %allparts; |
my %allparts; # hash parameter part -> part title |
# ------------------------------------------------------------------------------ |
# ------------------------------------------------------------------------------ |
|
|
# |
# |
Line 2651 sub assessparms {
|
Line 2812 sub assessparms {
|
$symbp{'0.0'} = ''; |
$symbp{'0.0'} = ''; |
|
|
# ---------------------------------------------------------- Anything to store? |
# ---------------------------------------------------------- Anything to store? |
if ($env{'form.pres_marker'}) { |
if ($env{'form.pres_marker'} && $parm_permission->{'edit'}) { |
my @markers=split(/\&\&\&/,$env{'form.pres_marker'}); |
my @markers=split(/\&\&\&/,$env{'form.pres_marker'}); |
my @values=split(/\&\&\&/,$env{'form.pres_value'}); |
my @values=split(/\&\&\&/,$env{'form.pres_value'}); |
my @types=split(/\&\&\&/,$env{'form.pres_type'}); |
my @types=split(/\&\&\&/,$env{'form.pres_type'}); |
Line 2812 sub assessparms {
|
Line 2973 sub assessparms {
|
} |
} |
} |
} |
#----------------------------------------------- if all selected, fill in array |
#----------------------------------------------- if all selected, fill in array |
if ($pscat[0] eq "all") {@pscat = (keys(%allparms));} |
if ($pscat[0] eq "all") { |
if (!@pscat) { @pscat=('duedate','opendate','answerdate','weight','maxtries','type','problemstatus') }; |
@pscat = (keys(%allparms)); |
if ($psprt[0] eq "all" || !@psprt) {@psprt = (keys(%allparts));} |
} |
|
if (!@pscat) { |
|
@pscat=('duedate','opendate','answerdate','weight','maxtries','type','problemstatus') |
|
}; |
|
if ($psprt[0] eq "all" || !@psprt) { |
|
@psprt = (keys(%allparts)); |
|
} |
# ------------------------------------------------------------------ Start page |
# ------------------------------------------------------------------ Start page |
|
|
my $crstype = &Apache::loncommon::course_type(); |
my $crstype = &Apache::loncommon::course_type(); |
&startpage($r,$pssymb,$crstype); |
&startpage($r,$pssymb,$crstype); |
|
|
foreach my $item ('tolerance','date_default','date_start','date_end', |
foreach my $item ('tolerance','date_default','date_start','date_end', |
'date_interval','int','float','string') { |
'date_interval','int','float','string') { |
$r->print('<input type="hidden" value="'. |
$r->print('<input type="hidden" value="'. |
&HTML::Entities::encode($env{'form.recent_'.$item},'"&<>'). |
&HTML::Entities::encode($env{'form.recent_'.$item},'"&<>'). |
'" name="recent_'.$item.'" />'); |
'" name="recent_'.$item.'" />'); |
} |
} |
|
|
# ----- Start Parameter Selection |
# ----- Start Parameter Selection |
Line 2834 sub assessparms {
|
Line 3001 sub assessparms {
|
<script type="text/javascript"> |
<script type="text/javascript"> |
// <![CDATA[ |
// <![CDATA[ |
function parmsel_show() { |
function parmsel_show() { |
document.getElementById('parmsel').style.display = ""; |
document.getElementById('parmsel').style.display = ""; |
document.getElementById('parmsellink').style.display = "none"; |
document.getElementById('parmsellink').style.display = "none"; |
} |
} |
// ]]> |
// ]]> |
</script> |
</script> |
ENDPARMSELSCRIPT |
ENDPARMSELSCRIPT |
|
|
if (!$pssymb) { |
if (!$pssymb) { |
|
# No single resource selected, print forms to select things (hidden after first selection) |
my $parmselhiddenstyle=' style="display:none"'; |
my $parmselhiddenstyle=' style="display:none"'; |
if($env{'form.hideparmsel'} eq 'hidden') { |
if($env{'form.hideparmsel'} eq 'hidden') { |
$r->print('<div id="parmsel"'.$parmselhiddenstyle.'>'); |
$r->print('<div id="parmsel"'.$parmselhiddenstyle.'>'); |
Line 2937 ENDPARMSELSCRIPT
|
Line 3105 ENDPARMSELSCRIPT
|
my @catmarker=map { tr|.|_|; 'parameter_'.$_; } @pscat; |
my @catmarker=map { tr|.|_|; 'parameter_'.$_; } @pscat; |
my $csuname=$env{'user.name'}; |
my $csuname=$env{'user.name'}; |
my $csudom=$env{'user.domain'}; |
my $csudom=$env{'user.domain'}; |
|
my $readonly = 1; |
|
if ($parm_permission->{'edit'}) { |
|
undef($readonly); |
|
} |
|
|
if ($parmlev eq 'full') { |
if ($parmlev eq 'full') { |
# |
# |
Line 3120 ENDTABLEHEADFOUR
|
Line 3292 ENDTABLEHEADFOUR
|
&print_row($r,$item,\%part,\%name,\%symbp,$rid,\%default, |
&print_row($r,$item,\%part,\%name,\%symbp,$rid,\%default, |
\%type,\%display,$defbgone,$defbgtwo, |
\%type,\%display,$defbgone,$defbgtwo, |
$defbgthree,$parmlev,$uname,$udom,$csec, |
$defbgthree,$parmlev,$uname,$udom,$csec, |
$cgroup,\@usersgroups,$noeditgrp); |
$cgroup,\@usersgroups,$noeditgrp,$readonly); |
} |
} |
} |
} |
} |
} |
Line 3243 ENDTABLEHEADFOUR
|
Line 3415 ENDTABLEHEADFOUR
|
$r->print(&Apache::loncommon::start_data_table_row()); |
$r->print(&Apache::loncommon::start_data_table_row()); |
&print_row($r,$item,\%part,\%name,\%symbp,$mapid,\%default, |
&print_row($r,$item,\%part,\%name,\%symbp,$mapid,\%default, |
\%type,\%display,$defbgone,$defbgtwo,$defbgthree, |
\%type,\%display,$defbgone,$defbgtwo,$defbgthree, |
$parmlev,$uname,$udom,$csec,$cgroup,'',$noeditgrp); |
$parmlev,$uname,$udom,$csec,$cgroup,'',$noeditgrp, |
|
$readonly); |
} |
} |
$r->print(&Apache::loncommon::end_data_table().'</p>' |
$r->print(&Apache::loncommon::end_data_table().'</p>' |
.'</div>' |
.'</div>' |
Line 3332 ENDMAPONE
|
Line 3505 ENDMAPONE
|
foreach my $item (&keysinorder(\%name,\%keyorder)) { |
foreach my $item (&keysinorder(\%name,\%keyorder)) { |
$r->print(&Apache::loncommon::start_data_table_row()); |
$r->print(&Apache::loncommon::start_data_table_row()); |
&print_row($r,$item,\%part,\%name,\%symbp,$mapid,\%default, |
&print_row($r,$item,\%part,\%name,\%symbp,$mapid,\%default, |
\%type,\%display,$defbgone,$defbgtwo,$defbgthree, |
\%type,\%display,$defbgone,$defbgtwo,$defbgthree, |
$parmlev,$uname,$udom,$csec,$cgroup,'',$noeditgrp); |
$parmlev,$uname,$udom,$csec,$cgroup,'',$noeditgrp, |
|
$readonly); |
} |
} |
$r->print(&Apache::loncommon::end_data_table() |
$r->print(&Apache::loncommon::end_data_table() |
.'</p>' |
.'</p>' |
Line 3351 ENDMAPONE
|
Line 3525 ENDMAPONE
|
################################################## |
################################################## |
# OVERVIEW MODE |
# OVERVIEW MODE |
################################################## |
################################################## |
my $tableopen; |
|
|
|
|
my $tableopen; # boolean, true if HTML table is already opened |
|
|
|
# Returns HTML with the HTML table start tag and header, unless the table is already opened. |
|
# @param {boolean} $readonly - true if values cannot be edited (otherwise more columns are added) |
|
# @returns {string} |
sub tablestart { |
sub tablestart { |
my ($readonly) = @_; |
my ($readonly) = @_; |
if ($tableopen) { |
if ($tableopen) { |
Line 3370 sub tablestart {
|
Line 3548 sub tablestart {
|
} |
} |
} |
} |
|
|
|
# Returns HTML with the HTML table end tag, unless the table is not opened. |
|
# @returns {string} |
sub tableend { |
sub tableend { |
if ($tableopen) { |
if ($tableopen) { |
$tableopen=0; |
$tableopen=0; |
Line 3379 sub tableend {
|
Line 3559 sub tableend {
|
} |
} |
} |
} |
|
|
|
# Reads course and user information. |
|
# If the context is looking for a scalar, returns the course parameters hash (result of lonnet::get_courseresdata, dump of course's resourcedata.db) with added student data from lonnet::get_userresdata (which reads the user's resourcedata.db). |
|
# The key for student data is modified with '[useropt:'.username.':'.userdomain.'].'. |
|
# If the context is looking for a list, returns a list with the scalar data and the class list. |
|
# @param {string} $crs - course number |
|
# @param {string} $dom - course domain |
|
# @returns {hash reference|Array} |
sub readdata { |
sub readdata { |
my ($crs,$dom)=@_; |
my ($crs,$dom)=@_; |
# Read coursedata |
# Read coursedata |
Line 3407 sub readdata {
|
Line 3594 sub readdata {
|
} |
} |
|
|
|
|
# Setting |
# Stores parameter data, using form parameters directly. |
|
# |
|
# Uses the following form parameters. The variable part in the names is a resourcedata key (except for a modification for user data). |
|
# set_* (except settext, setipallow, setipdeny) - set a parameter value |
|
# del_* - remove a parameter |
|
# datepointer_* - set a date parameter (value is key_* refering to a set of other form parameters) |
|
# dateinterval_* - set a date interval parameter (value refers to more form parameters) |
|
# key_* - date values |
|
# days_* - for date intervals |
|
# hours_* - for date intervals |
|
# minutes_* - for date intervals |
|
# seconds_* - for date intervals |
|
# done_* - for date intervals |
|
# typeof_* - parameter type |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
|
# @param {string} $crs - course number |
|
# @param {string} $dom - course domain |
sub storedata { |
sub storedata { |
my ($r,$crs,$dom)=@_; |
my ($r,$crs,$dom)=@_; |
# Set userlevel immediately |
# Set userlevel immediately |
Line 3431 sub storedata {
|
Line 3634 sub storedata {
|
$tkey=~s/\.\[useropt\:$tuname\:$tudom\]\./\./; |
$tkey=~s/\.\[useropt\:$tuname\:$tudom\]\./\./; |
} |
} |
if ($cmd eq 'set' || $cmd eq 'datepointer' || $cmd eq 'dateinterval') { |
if ($cmd eq 'set' || $cmd eq 'datepointer' || $cmd eq 'dateinterval') { |
my ($data, $typeof, $text, $name, $valchk, $valmatch, $namematch); |
my ($data, $typeof, $text, $name, $valchk, $valmatch, $namematch); |
if ($cmd eq 'set') { |
if ($cmd eq 'set') { |
$data=$env{$key}; |
$data=$env{$key}; |
$valmatch = ''; |
$valmatch = ''; |
$valchk = $data; |
$valchk = $data; |
$typeof=$env{'form.typeof_'.$thiskey}; |
$typeof=$env{'form.typeof_'.$thiskey}; |
$text = &mt('Saved modified parameter for'); |
$text = &mt('Saved modified parameter for'); |
if ($typeof eq 'string_questiontype') { |
if ($typeof eq 'string_questiontype') { |
$name = 'type'; |
$name = 'type'; |
} elsif ($typeof eq 'string_lenient') { |
} elsif ($typeof eq 'string_lenient') { |
$name = 'lenient'; |
$name = 'lenient'; |
my $stringmatch = &standard_string_matches($typeof); |
my $stringmatch = &standard_string_matches($typeof); |
if (ref($stringmatch) eq 'ARRAY') { |
if (ref($stringmatch) eq 'ARRAY') { |
foreach my $item (@{$stringmatch}) { |
foreach my $item (@{$stringmatch}) { |
if (ref($item) eq 'ARRAY') { |
if (ref($item) eq 'ARRAY') { |
my ($regexpname,$pattern) = @{$item}; |
my ($regexpname,$pattern) = @{$item}; |
if ($pattern ne '') { |
if ($pattern ne '') { |
if ($data =~ /$pattern/) { |
if ($data =~ /$pattern/) { |
$valmatch = $regexpname; |
$valmatch = $regexpname; |
$valchk = ''; |
$valchk = ''; |
last; |
last; |
|
} |
} |
} |
} |
} |
} |
} |
} |
} |
} |
} elsif ($typeof eq 'string_discussvote') { |
} elsif ($typeof eq 'string_discussvote') { |
$name = 'discussvote'; |
$name = 'discussvote'; |
} elsif ($typeof eq 'string_examcode') { |
} elsif ($typeof eq 'string_examcode') { |
$name = 'examcode'; |
$name = 'examcode'; |
if (&Apache::lonnet::validCODE($data)) { |
if (&Apache::lonnet::validCODE($data)) { |
$valchk = 'valid'; |
$valchk = 'valid'; |
} |
} |
} elsif ($typeof eq 'string_yesno') { |
} elsif ($typeof eq 'string_yesno') { |
if ($thiskey =~ /\.retrypartial$/) { |
if ($thiskey =~ /\.retrypartial$/) { |
$name = 'retrypartial'; |
$name = 'retrypartial'; |
|
} |
|
} |
|
} elsif ($cmd eq 'datepointer') { |
|
$data=&Apache::lonhtmlcommon::get_date_from_form($env{$key}); |
|
$typeof=$env{'form.typeof_'.$thiskey}; |
|
$text = &mt('Saved modified date for'); |
|
if ($typeof eq 'date_start') { |
|
if ($thiskey =~ /\.printstartdate$/) { |
|
$name = 'printstartdate'; |
|
if (($data) && ($data > $now)) { |
|
$valchk = 'future'; |
|
} |
} |
} |
} |
} elsif ($typeof eq 'date_end') { |
} elsif ($cmd eq 'datepointer') { |
if ($thiskey =~ /\.printenddate$/) { |
$data=&Apache::lonhtmlcommon::get_date_from_form($env{$key}); |
$name = 'printenddate'; |
$typeof=$env{'form.typeof_'.$thiskey}; |
if (($data) && ($data < $now)) { |
$text = &mt('Saved modified date for'); |
$valchk = 'past'; |
if ($typeof eq 'date_start') { |
|
if ($thiskey =~ /\.printstartdate$/) { |
|
$name = 'printstartdate'; |
|
if (($data) && ($data > $now)) { |
|
$valchk = 'future'; |
|
} |
|
} |
|
} elsif ($typeof eq 'date_end') { |
|
if ($thiskey =~ /\.printenddate$/) { |
|
$name = 'printenddate'; |
|
if (($data) && ($data < $now)) { |
|
$valchk = 'past'; |
|
} |
} |
} |
} |
} |
} |
} elsif ($cmd eq 'dateinterval') { |
} elsif ($cmd eq 'dateinterval') { |
$data=&get_date_interval_from_form($thiskey); |
$data=&get_date_interval_from_form($thiskey); |
if ($thiskey =~ /\.interval$/) { |
if ($thiskey =~ /\.interval$/) { |
$name = 'interval'; |
$name = 'interval'; |
my $intervaltype = &get_intervaltype($name); |
my $intervaltype = &get_intervaltype($name); |
my $intervalmatch = &standard_interval_matches($intervaltype); |
my $intervalmatch = &standard_interval_matches($intervaltype); |
if (ref($intervalmatch) eq 'ARRAY') { |
if (ref($intervalmatch) eq 'ARRAY') { |
foreach my $item (@{$intervalmatch}) { |
foreach my $item (@{$intervalmatch}) { |
if (ref($item) eq 'ARRAY') { |
if (ref($item) eq 'ARRAY') { |
my ($regexpname,$pattern) = @{$item}; |
my ($regexpname,$pattern) = @{$item}; |
if ($pattern ne '') { |
if ($pattern ne '') { |
if ($data =~ /$pattern/) { |
if ($data =~ /$pattern/) { |
$valmatch = $regexpname; |
$valmatch = $regexpname; |
$valchk = ''; |
$valchk = ''; |
last; |
last; |
} |
} |
} |
} |
} |
} |
} |
} |
} |
} |
} |
|
$typeof=$env{'form.typeof_'.$thiskey}; |
|
$text = &mt('Saved modified date for'); |
} |
} |
$typeof=$env{'form.typeof_'.$thiskey}; |
if ($thiskey =~ m{\.(?:sequence|page)___\(rec\)}) { |
$text = &mt('Saved modified date for'); |
$namematch = 'maplevelrecurse'; |
} |
|
if ($thiskey =~ m{\.(?:sequence|page)___\(rec\)}) { |
|
$namematch = 'maplevelrecurse'; |
|
} |
|
if (($name ne '') || ($namematch ne '')) { |
|
my ($needsrelease,$needsnewer); |
|
if ($name ne '') { |
|
$needsrelease = $Apache::lonnet::needsrelease{"parameter:$name:$valchk:$valmatch:"}; |
|
if ($needsrelease) { |
|
unless ($got_chostname) { |
|
($chostname,$cmajor,$cminor)=¶meter_release_vars(); |
|
$got_chostname = 1; |
|
} |
|
$needsnewer = ¶meter_releasecheck($name,$valchk,$valmatch,undef, |
|
$needsrelease, |
|
$cmajor,$cminor); |
|
} |
|
} |
} |
if ($namematch ne '') { |
if (($name ne '') || ($namematch ne '')) { |
if ($needsnewer) { |
my ($needsrelease,$needsnewer); |
undef($namematch); |
if ($name ne '') { |
} else { |
$needsrelease = $Apache::lonnet::needsrelease{"parameter:$name:$valchk:$valmatch:"}; |
my $currneeded; |
|
if ($needsrelease) { |
if ($needsrelease) { |
$currneeded = $needsrelease; |
|
} |
|
$needsrelease = |
|
$Apache::lonnet::needsrelease{"parameter::::$namematch"}; |
|
if (($needsrelease) && (($currneeded eq '') || ($needsrelease < $currneeded))) { |
|
unless ($got_chostname) { |
unless ($got_chostname) { |
($chostname,$cmajor,$cminor) = ¶meter_release_vars(); |
($chostname,$cmajor,$cminor)=¶meter_release_vars(); |
$got_chostname = 1; |
$got_chostname = 1; |
} |
} |
$needsnewer = ¶meter_releasecheck(undef,$valchk,$valmatch,$namematch, |
$needsnewer = ¶meter_releasecheck($name,$valchk,$valmatch,undef, |
$needsrelease,$cmajor,$cminor); |
$needsrelease, |
} else { |
$cmajor,$cminor); |
|
} |
|
} |
|
if ($namematch ne '') { |
|
if ($needsnewer) { |
undef($namematch); |
undef($namematch); |
|
} else { |
|
my $currneeded; |
|
if ($needsrelease) { |
|
$currneeded = $needsrelease; |
|
} |
|
$needsrelease = |
|
$Apache::lonnet::needsrelease{"parameter::::$namematch"}; |
|
if (($needsrelease) && |
|
(($currneeded eq '') || ($needsrelease < $currneeded))) { |
|
unless ($got_chostname) { |
|
($chostname,$cmajor,$cminor) = ¶meter_release_vars(); |
|
$got_chostname = 1; |
|
} |
|
$needsnewer = ¶meter_releasecheck(undef,$valchk,$valmatch, |
|
$namematch, $needsrelease,$cmajor,$cminor); |
|
} else { |
|
undef($namematch); |
|
} |
} |
} |
} |
} |
|
if ($needsnewer) { |
|
$r->print('<br />'.&oldversion_warning($name,$namematch,$data, |
|
$chostname,$cmajor, |
|
$cminor,$needsrelease)); |
|
next; |
|
} |
} |
} |
if ($needsnewer) { |
if (defined($data) and $$olddata{$thiskey} ne $data) { |
$r->print('<br />'.&oldversion_warning($name,$namematch,$data, |
if ($tuname) { |
$chostname,$cmajor, |
if (&Apache::lonnet::put('resourcedata',{$tkey=>$data, |
$cminor,$needsrelease)); |
$tkey.'.type' => $typeof}, |
next; |
$tudom,$tuname) eq 'ok') { |
} |
&log_parmset({$tkey=>$data,$tkey.'.type' => $typeof},0,$tuname,$tudom); |
} |
$r->print('<br />'.$text.' '. |
if (defined($data) and $$olddata{$thiskey} ne $data) { |
&Apache::loncommon::plainname($tuname,$tudom)); |
if ($tuname) { |
} else { |
if (&Apache::lonnet::put('resourcedata',{$tkey=>$data, |
$r->print('<div class="LC_error">'. |
$tkey.'.type' => $typeof}, |
&mt('Error saving parameters').'</div>'); |
$tudom,$tuname) eq 'ok') { |
} |
&log_parmset({$tkey=>$data,$tkey.'.type' => $typeof},0,$tuname,$tudom); |
&Apache::lonnet::devalidateuserresdata($tuname,$tudom); |
$r->print('<br />'.$text.' '. |
|
&Apache::loncommon::plainname($tuname,$tudom)); |
|
} else { |
} else { |
$r->print('<div class="LC_error">'. |
$newdata{$thiskey}=$data; |
&mt('Error saving parameters').'</div>'); |
$newdata{$thiskey.'.type'}=$typeof; |
} |
} |
&Apache::lonnet::devalidateuserresdata($tuname,$tudom); |
|
} else { |
|
$newdata{$thiskey}=$data; |
|
$newdata{$thiskey.'.type'}=$typeof; |
|
} |
} |
} |
|
} elsif ($cmd eq 'del') { |
} elsif ($cmd eq 'del') { |
if ($tuname) { |
if ($tuname) { |
if (&Apache::lonnet::del('resourcedata',[$tkey],$tudom,$tuname) eq 'ok') { |
if (&Apache::lonnet::del('resourcedata',[$tkey],$tudom,$tuname) eq 'ok') { |
Line 3619 sub storedata {
|
Line 3823 sub storedata {
|
} |
} |
} |
} |
|
|
|
# Returns the username and domain from a key created in readdata from a resourcedata key. |
|
# |
|
# @param {string} $key - the key |
|
# @returns {Array} |
sub extractuser { |
sub extractuser { |
my $key=shift; |
my $key=shift; |
return ($key=~/^$env{'request.course.id'}.\[useropt\:($match_username)\:($match_domain)\]\./); |
return ($key=~/^$env{'request.course.id'}.\[useropt\:($match_username)\:($match_domain)\]\./); |
} |
} |
|
|
|
# Parses a parameter key and returns the components. |
|
# |
|
# @param {string} $key - |
|
# @param {hash reference} $listdata - |
|
# @return {Array} - (student, resource, part, parameter) |
sub parse_listdata_key { |
sub parse_listdata_key { |
my ($key,$listdata) = @_; |
my ($key,$listdata) = @_; |
# split into student/section affected, and |
# split into student/section affected, and |
Line 3644 sub parse_listdata_key {
|
Line 3857 sub parse_listdata_key {
|
return ($student,$res,$part,$parm); |
return ($student,$res,$part,$parm); |
} |
} |
|
|
# Displays forms for the given data in overview mode (newoverview or overview). |
# Prints HTML with forms for the given parameter data in overview mode (newoverview or overview). |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
|
# @param {hash reference} $resourcedata - parameter data returned by readdata |
|
# @param {hash reference} $listdata - data created in secgroup_lister, course id.[section id].part.name -> 1 or course id.[section id].part.name.type -> parameter type |
|
# @param {string} $sortorder - realmstudent|studentrealm |
|
# @param {string} $caller - name of the calling sub (overview|newoverview) |
|
# @param {hash reference} $classlist - from loncoursedata::get_classlist |
|
# @param {boolean} $readonly - true if editing not allowed |
|
# @returns{integer} - number of $listdata parameters processed |
sub listdata { |
sub listdata { |
my ($r,$resourcedata,$listdata,$sortorder,$caller,$classlist)=@_; |
my ($r,$resourcedata,$listdata,$sortorder,$caller,$classlist,$readonly)=@_; |
|
|
# Start list output |
# Start list output |
|
|
Line 3710 sub listdata {
|
Line 3932 sub listdata {
|
|
|
} keys(%{$listdata})) { # foreach my $thiskey |
} keys(%{$listdata})) { # foreach my $thiskey |
|
|
my $readonly; |
|
if ($$listdata{$thiskey.'.type'}) { |
if ($$listdata{$thiskey.'.type'}) { |
my $thistype=$$listdata{$thiskey.'.type'}; |
my $thistype=$$listdata{$thiskey.'.type'}; |
if ($$resourcedata{$thiskey.'.type'}) { |
if ($$resourcedata{$thiskey.'.type'}) { |
Line 3847 sub listdata {
|
Line 4068 sub listdata {
|
return $foundkeys; |
return $foundkeys; |
} |
} |
|
|
|
# Returns a string representing the interval, directly using form data matching the given key. |
|
# The returned string may also include information related to proctored exams. |
|
# Format: seconds['_done'[':'done button title':']['_proctor'['_'proctor key]]] |
|
# |
|
# @param {string} $key - suffix for form fields related to the interval |
|
# @returns {string} |
sub get_date_interval_from_form { |
sub get_date_interval_from_form { |
my ($key) = @_; |
my ($key) = @_; |
my $seconds = 0; |
my $seconds = 0; |
Line 3879 sub get_date_interval_from_form {
|
Line 4106 sub get_date_interval_from_form {
|
} |
} |
|
|
|
|
|
# Returns HTML to enter a text value for a parameter. |
|
# |
|
# @param {string} $thiskey - parameter key |
|
# @param {string} $showval - the current value |
|
# @param {boolean} $readonly - true if the field should not be made editable |
|
# @returns {string} |
sub default_selector { |
sub default_selector { |
my ($thiskey, $showval, $readonly) = @_; |
my ($thiskey, $showval, $readonly) = @_; |
my $disabled; |
my $disabled; |
Line 3888 sub default_selector {
|
Line 4121 sub default_selector {
|
return '<input type="text" name="set_'.$thiskey.'" value="'.$showval.'"'.$disabled.' />'; |
return '<input type="text" name="set_'.$thiskey.'" value="'.$showval.'"'.$disabled.' />'; |
} |
} |
|
|
|
# Returns HTML to enter allow/deny rules related to IP addresses. |
|
# |
|
# @param {string} $thiskey - parameter key |
|
# @param {string} $showval - the current value |
|
# @param {boolean} $readonly - true if the fields should not be made editable |
|
# @returns {string} |
sub string_ip_selector { |
sub string_ip_selector { |
my ($thiskey, $showval, $readonly) = @_; |
my ($thiskey, $showval, $readonly) = @_; |
my %access = ( |
my %access = ( |
Line 3916 sub string_ip_selector {
|
Line 4155 sub string_ip_selector {
|
@{$access{'deny'}} = (''); |
@{$access{'deny'}} = (''); |
} |
} |
my ($disabled,$addmore); |
my ($disabled,$addmore); |
if ($disabled) { |
if ($readonly) { |
$disabled=' disabled="disabled"'; |
$disabled=' disabled="disabled"'; |
} else { |
} else { |
$addmore = "\n".'<button class="LC_add_ipacc_button">'.&mt('Add more').'</button>'; |
$addmore = "\n".'<button class="LC_add_ipacc_button">'.&mt('Add more').'</button>'; |
Line 4001 my %stringtypes = (
|
Line 4240 my %stringtypes = (
|
acc => 'string_ip', |
acc => 'string_ip', |
); |
); |
|
|
|
# Returns the possible values and titles for a given string type, or undef if there are none. |
|
# Used by courseprefs. |
|
# |
|
# @param {string} $string_type - a parameter type for strings |
|
# @returns {array reference} - 2D array, containing values and English titles |
sub standard_string_options { |
sub standard_string_options { |
my ($string_type) = @_; |
my ($string_type) = @_; |
if (ref($strings{$string_type}) eq 'ARRAY') { |
if (ref($strings{$string_type}) eq 'ARRAY') { |
Line 4009 sub standard_string_options {
|
Line 4253 sub standard_string_options {
|
return; |
return; |
} |
} |
|
|
|
# Returns regular expressions to match kinds of string types, or undef if there are none. |
|
# |
|
# @param {string} $string_type - a parameter type for strings |
|
# @returns {array reference} - 2D array, containing regular expression names and regular expressions |
sub standard_string_matches { |
sub standard_string_matches { |
my ($string_type) = @_; |
my ($string_type) = @_; |
if (ref($stringmatches{$string_type}) eq 'ARRAY') { |
if (ref($stringmatches{$string_type}) eq 'ARRAY') { |
Line 4017 sub standard_string_matches {
|
Line 4265 sub standard_string_matches {
|
return; |
return; |
} |
} |
|
|
|
# Returns a parameter type for a given parameter with a string type, or undef if not known. |
|
# |
|
# @param {string} $name - parameter name |
|
# @returns {string} |
sub get_stringtype { |
sub get_stringtype { |
my ($name) = @_; |
my ($name) = @_; |
if (exists($stringtypes{$name})) { |
if (exists($stringtypes{$name})) { |
Line 4025 sub get_stringtype {
|
Line 4277 sub get_stringtype {
|
return; |
return; |
} |
} |
|
|
|
# Returns HTML to edit a string parameter. |
|
# |
|
# @param {string} $thistype - parameter type |
|
# @param {string} $thiskey - parameter key |
|
# @param {string} $showval - parameter current value |
|
# @param {string} $name - parameter name |
|
# @param {boolean} $readonly - true if the values should not be made editable |
|
# @returns {string} |
sub string_selector { |
sub string_selector { |
my ($thistype, $thiskey, $showval, $name, $readonly) = @_; |
my ($thistype, $thiskey, $showval, $name, $readonly) = @_; |
|
|
Line 4190 my %intervaltypes = (
|
Line 4450 my %intervaltypes = (
|
interval => 'date_interval', |
interval => 'date_interval', |
); |
); |
|
|
|
# Returns regular expressions to match kinds of interval type, or undef if there are none. |
|
# |
|
# @param {string} $interval_type - a parameter type for intervals |
|
# @returns {array reference} - 2D array, containing regular expression names and regular expressions |
sub standard_interval_matches { |
sub standard_interval_matches { |
my ($interval_type) = @_; |
my ($interval_type) = @_; |
if (ref($intervalmatches{$interval_type}) eq 'ARRAY') { |
if (ref($intervalmatches{$interval_type}) eq 'ARRAY') { |
Line 4198 sub standard_interval_matches {
|
Line 4462 sub standard_interval_matches {
|
return; |
return; |
} |
} |
|
|
|
# Returns a parameter type for a given parameter with an interval type, or undef if not known. |
|
# |
|
# @param {string} $name - parameter name |
|
# @returns {string} |
sub get_intervaltype { |
sub get_intervaltype { |
my ($name) = @_; |
my ($name) = @_; |
if (exists($intervaltypes{$name})) { |
if (exists($intervaltypes{$name})) { |
Line 4206 sub get_intervaltype {
|
Line 4474 sub get_intervaltype {
|
return; |
return; |
} |
} |
|
|
|
# Returns the possible values and titles for a given interval type, or undef if there are none. |
|
# Used by courseprefs. |
|
# |
|
# @param {string} $interval_type - a parameter type for intervals |
|
# @returns {array reference} - 2D array, containing values and English titles |
sub standard_interval_options { |
sub standard_interval_options { |
my ($interval_type) = @_; |
my ($interval_type) = @_; |
if (ref($intervals{$interval_type}) eq 'ARRAY') { |
if (ref($intervals{$interval_type}) eq 'ARRAY') { |
Line 4214 sub standard_interval_options {
|
Line 4487 sub standard_interval_options {
|
return; |
return; |
} |
} |
|
|
|
# Returns HTML to edit a date interval parameter. |
|
# |
|
# @param {string} $thiskey - parameter key |
|
# @param {string} $name - parameter name |
|
# @param {string} $showval - parameter current value |
|
# @param {boolean} $readonly - true if the values should not be made editable |
|
# @returns {string} |
sub date_interval_selector { |
sub date_interval_selector { |
my ($thiskey, $name, $showval, $readonly) = @_; |
my ($thiskey, $name, $showval, $readonly) = @_; |
my ($result,%skipval); |
my ($result,%skipval); |
Line 4296 sub date_interval_selector {
|
Line 4576 sub date_interval_selector {
|
$currprocdisplay = 'text'; |
$currprocdisplay = 'text'; |
} |
} |
my $onclick = ' onclick="toggleSecret(this.form,'."'done_','$thiskey'".');"'; |
my $onclick = ' onclick="toggleSecret(this.form,'."'done_','$thiskey'".');"'; |
|
my $disabled; |
|
if ($readonly) { |
|
$disabled = ' disabled="disabled"'; |
|
} |
$result .= '<br /><span class="LC_nobreak">'.&mt('Include "done" button'). |
$result .= '<br /><span class="LC_nobreak">'.&mt('Include "done" button'). |
'<label><input type="radio" value="" name="done_'.$thiskey.'"'.$checkedoff.$onclick.' />'. |
'<label><input type="radio" value="" name="done_'.$thiskey.'"'.$checkedoff.$onclick.$disabled.' />'. |
&mt('No').'</label>'.(' 'x2). |
&mt('No').'</label>'.(' 'x2). |
'<label><input type="radio" value="_done" name="done_'.$thiskey.'"'.$checkedon.$onclick.' />'. |
'<label><input type="radio" value="_done" name="done_'.$thiskey.'"'.$checkedon.$onclick.$disabled.' />'. |
&mt('Yes').'</label>'.(' 'x2). |
&mt('Yes').'</label>'.(' 'x2). |
'<label><input type="radio" value="_done_proctor" name="done_'.$thiskey.'"'.$checkedproc.$onclick.' />'. |
'<label><input type="radio" value="_done_proctor" name="done_'.$thiskey.'"'.$checkedproc.$onclick.$disabled.' />'. |
&mt('Yes, with proctor key').'</label>'. |
&mt('Yes, with proctor key').'</label>'. |
'<input type="'.$currprocdisplay.'" id="done_'.$thiskey.'_proctorkey" '. |
'<input type="'.$currprocdisplay.'" id="done_'.$thiskey.'_proctorkey" '. |
'name="done_'.$thiskey.'_proctorkey" value="'.&HTML::Entities::encode($currproctorkey,'"<>&').'" /></span><br />'. |
'name="done_'.$thiskey.'_proctorkey" value="'.&HTML::Entities::encode($currproctorkey,'"<>&').'"'.$disabled.' /></span><br />'. |
'<span class="LC_nobreak">'.&mt('Button text').': '. |
'<span class="LC_nobreak">'.&mt('Button text').': '. |
'<input type="text" name="done_'.$thiskey.'_buttontext" value="'.&HTML::Entities::encode($currdonetext,'"<>&').'" /></span>'; |
'<input type="text" name="done_'.$thiskey.'_buttontext" value="'.&HTML::Entities::encode($currdonetext,'"<>&').'"'.$disabled.' /></span>'; |
} |
} |
} |
} |
unless ($readonly) { |
unless ($readonly) { |
Line 4315 sub date_interval_selector {
|
Line 4599 sub date_interval_selector {
|
return $result; |
return $result; |
} |
} |
|
|
|
# Returns HTML with a warning if a parameter requires a more recent version of LON-CAPA. |
|
# |
|
# @param {string} $name - parameter name |
|
# @param {string} $namematch - parameter level name (recognized: resourcelevel|maplevel|maplevelrecurse|courselevel) |
|
# @param {string} $value - parameter value |
|
# @param {string} $chostname - course server name |
|
# @param {integer} $cmajor - major version number |
|
# @param {integer} $cminor - minor version number |
|
# @param {string} $needsrelease - release version needed (major.minor) |
|
# @returns {string} |
sub oldversion_warning { |
sub oldversion_warning { |
my ($name,$namematch,$value,$chostname,$cmajor,$cminor,$needsrelease) = @_; |
my ($name,$namematch,$value,$chostname,$cmajor,$cminor,$needsrelease) = @_; |
my $standard_name = &standard_parameter_names($name); |
my $standard_name = &standard_parameter_names($name); |
Line 4390 sub oldversion_warning {
|
Line 4684 sub oldversion_warning {
|
} # end of block using some constants related to parameter types |
} # end of block using some constants related to parameter types |
|
|
|
|
# |
|
# Shift all start and end dates by $shift |
|
# |
|
|
|
|
# Shifts all start and end dates in the current course by $shift. |
|
# |
|
# @param {integer} $shift - time to shift, in seconds |
|
# @returns {string} - error name or 'ok' |
sub dateshift { |
sub dateshift { |
my ($shift)=@_; |
my ($shift)=@_; |
my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
Line 4425 sub dateshift {
|
Line 4720 sub dateshift {
|
return $reply; |
return $reply; |
} |
} |
|
|
|
# Overview mode UI to edit course parameters. |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
sub newoverview { |
sub newoverview { |
my ($r) = @_; |
my ($r,$parm_permission) = @_; |
|
|
my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $crs = $env{'course.'.$env{'request.course.id'}.'.num'}; |
my $crs = $env{'course.'.$env{'request.course.id'}.'.num'}; |
my $crstype = $env{'course.'.$env{'request.course.id'}.'.type'}; |
my $crstype = $env{'course.'.$env{'request.course.id'}.'.type'}; |
|
my $readonly = 1; |
|
if ($parm_permission->{'edit'}) { |
|
undef($readonly); |
|
} |
&Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=setoverview', |
&Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=setoverview', |
text=>"Overview Mode"}); |
text=>"Overview Mode"}); |
|
|
Line 4533 ENDOVER
|
Line 4835 ENDOVER
|
|
|
$r->print('<div class="LC_Box">'); |
$r->print('<div class="LC_Box">'); |
$r->print('<div>'); |
$r->print('<div>'); |
&displaymenu($r,\%allparms,\@pscat,\%keyorder); |
&displaymenu($r,\%allparms,\@pscat,\%keyorder); # FIXME: wrong parameters, could make keysindisplayorderCategory crash because $keyorder is undefined |
$r->print(&Apache::lonhtmlcommon::start_pick_box()); |
$r->print(&Apache::lonhtmlcommon::start_pick_box()); |
$r->print(&Apache::lonhtmlcommon::row_title(&mt('Select Parts to View'))); |
$r->print(&Apache::lonhtmlcommon::row_title(&mt('Select Parts to View'))); |
my $sectionselector = §ionmenu(\@selected_sections); |
my $sectionselector = §ionmenu(\@selected_sections); |
Line 4589 ENDOVER
|
Line 4891 ENDOVER
|
|
|
# List data |
# List data |
|
|
&listdata($r,$resourcedata,$listdata,$sortorder,'newoverview'); |
&listdata($r,$resourcedata,$listdata,$sortorder,'newoverview',undef,$readonly); |
} |
} |
$r->print(&tableend(). |
$r->print(&tableend()); |
((($env{'form.store'}) || ($env{'form.dis'}))?'<p><input type="submit" name="store" value="'.&mt('Save').'" /></p>':''). |
unless ($readonly) { |
'</form>'); |
$r->print( ((($env{'form.store'}) || ($env{'form.dis'}))?'<p><input type="submit" name="store" value="'.&mt('Save').'" /></p>':'') ); |
|
} |
|
$r->print('</form>'); |
&endSettingsScreen($r); |
&endSettingsScreen($r); |
$r->print(&Apache::loncommon::end_page()); |
$r->print(&Apache::loncommon::end_page()); |
} |
} |
|
|
|
# Fills $listdata with parameter information. |
|
# Keys use the format course id.[section id].part.name and course id.[section id].part.name.type. |
|
# The non-type value is always 1. |
|
# |
|
# @param {string} $cat - parameter name |
|
# @param {string} $pschp - selected map pc, or 'all' |
|
# @param {string} $parmlev - selected level value (full|map|general), or '' |
|
# @param {hash reference} $listdata - the parameter data that will be modified |
|
# @param {array reference} $psprt - selected parts |
|
# @param {array reference} $selections - selected sections |
|
# @param {hash reference} $defkeytype - hash parameter name -> parameter type |
|
# @param {hash reference} $allmaps - hash map pc -> map src |
|
# @param {array reference} $ids - resource and map ids |
|
# @param {hash reference} $symbp - hash map pc or resource/map id -> map src.'___(all)' or resource symb |
sub secgroup_lister { |
sub secgroup_lister { |
my ($cat,$pschp,$parmlev,$listdata,$psprt,$selections,$defkeytype,$allmaps,$ids,$symbp) = @_; |
my ($cat,$pschp,$parmlev,$listdata,$psprt,$selections,$defkeytype,$allmaps,$ids,$symbp) = @_; |
foreach my $item (@{$selections}) { |
foreach my $item (@{$selections}) { |
Line 4636 sub secgroup_lister {
|
Line 4954 sub secgroup_lister {
|
} |
} |
} |
} |
|
|
# Display all existing parameter settings. |
# UI to edit parameter settings starting with a list of all existing parameters. |
|
# (called by setoverview action) |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
sub overview { |
sub overview { |
my ($r) = @_; |
my ($r,$parm_permission) = @_; |
my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $crs = $env{'course.'.$env{'request.course.id'}.'.num'}; |
my $crs = $env{'course.'.$env{'request.course.id'}.'.num'}; |
my $crstype = $env{'course.'.$env{'request.course.id'}.'.type'}; |
my $crstype = $env{'course.'.$env{'request.course.id'}.'.type'}; |
|
my $readonly = 1; |
|
if ($parm_permission->{'edit'}) { |
|
undef($readonly); |
|
} |
my $js = '<script type="text/javascript">'."\n". |
my $js = '<script type="text/javascript">'."\n". |
'// <![CDATA['."\n". |
'// <![CDATA['."\n". |
&toggleparmtextbox_js()."\n". |
&toggleparmtextbox_js()."\n". |
Line 4664 sub overview {
|
Line 4989 sub overview {
|
|
|
# Store modified |
# Store modified |
|
|
&storedata($r,$crs,$dom); |
unless ($readonly) { |
|
&storedata($r,$crs,$dom); |
|
} |
|
|
# Read modified data |
# Read modified data |
|
|
Line 4675 sub overview {
|
Line 5002 sub overview {
|
unless ($sortorder) { $sortorder='realmstudent'; } |
unless ($sortorder) { $sortorder='realmstudent'; } |
&sortmenu($r,$sortorder); |
&sortmenu($r,$sortorder); |
|
|
|
my $submitbutton = '<input type="submit" value="'.&mt('Save').'" />'; |
|
|
|
if ($readonly) { |
|
$r->print('<p>'.$submitbutton.'</p>'); |
|
} |
|
|
# List data |
# List data |
|
|
my $foundkeys=&listdata($r,$resourcedata,$resourcedata,$sortorder,'overview',$classlist); |
my $foundkeys=&listdata($r,$resourcedata,$resourcedata,$sortorder,'overview',$classlist,$readonly); |
$r->print(&tableend().'<p>'. |
$r->print(&tableend().'<p>'); |
($foundkeys?'<input type="submit" value="'.&mt('Save').'" />':'<span class="LC_info">'.&mt('There are no parameters.').'</span>').'</p></form>'. |
if ($foundkeys) { |
&Apache::loncommon::end_page()); |
unless ($readonly) { |
|
$r->print('<p>'.$submitbutton.'</p>'); |
|
} |
|
} else { |
|
$r->print('<p class="LC_info">'.&mt('There are no parameters.').'</p>'); |
|
} |
|
$r->print('</form>'.&Apache::loncommon::end_page()); |
} |
} |
|
|
# Unused sub. |
# Unused sub. |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
sub clean_parameters { |
sub clean_parameters { |
my ($r) = @_; |
my ($r) = @_; |
my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
Line 4772 ENDOVER
|
Line 5113 ENDOVER
|
$r->print(&Apache::loncommon::end_page()); |
$r->print(&Apache::loncommon::end_page()); |
} |
} |
|
|
# Overview mode, UI to shift all dates. |
# UI to shift all dates (called by dateshift1 action). |
|
# Used by overview mode. |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
sub date_shift_one { |
sub date_shift_one { |
my ($r) = @_; |
my ($r) = @_; |
my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
Line 4801 sub date_shift_one {
|
Line 5145 sub date_shift_one {
|
$r->print(&Apache::loncommon::end_page()); |
$r->print(&Apache::loncommon::end_page()); |
} |
} |
|
|
# Overview mode, UI to shift all dates (second form). |
# UI to shift all dates (second form). |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
sub date_shift_two { |
sub date_shift_two { |
my ($r) = @_; |
my ($r) = @_; |
my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
Line 4829 sub date_shift_two {
|
Line 5175 sub date_shift_two {
|
$r->print(&Apache::loncommon::end_page()); |
$r->print(&Apache::loncommon::end_page()); |
} |
} |
|
|
|
# Returns the different components of a resourcedata key. |
|
# Keys: scope_type, scope, realm_type, realm, realm_title, |
|
# realm_exists, parameter_part, parameter_name. |
|
# Was used by clean_parameters (which is unused). |
|
# |
|
# @param {string} $key - the parameter key |
|
# @returns {hash} |
sub parse_key { |
sub parse_key { |
my ($key) = @_; |
my ($key) = @_; |
my %data; |
my %data; |
Line 4869 sub parse_key {
|
Line 5222 sub parse_key {
|
} |
} |
|
|
|
|
|
# Calls loncommon::start_page with the "Settings" title. |
sub header { |
sub header { |
return &Apache::loncommon::start_page('Settings'); |
return &Apache::loncommon::start_page('Settings'); |
} |
} |
Line 4879 sub header {
|
Line 5233 sub header {
|
# MAIN MENU |
# MAIN MENU |
################################################## |
################################################## |
|
|
|
# Content and problem settings main menu. |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
|
# @param {boolean} $parm_permission - true if the user has permission to edit the current course or section |
sub print_main_menu { |
sub print_main_menu { |
my ($r,$parm_permission)=@_; |
my ($r,$parm_permission)=@_; |
# |
# |
Line 4898 ENDMAINFORMHEAD
|
Line 5256 ENDMAINFORMHEAD
|
my $vgr = &Apache::lonnet::allowed('vgr',$env{'request.course.id'}); |
my $vgr = &Apache::lonnet::allowed('vgr',$env{'request.course.id'}); |
my $mgr = &Apache::lonnet::allowed('mgr',$env{'request.course.id'}); |
my $mgr = &Apache::lonnet::allowed('mgr',$env{'request.course.id'}); |
my $dcm = &Apache::lonnet::allowed('dcm',$env{'request.course.id'}); |
my $dcm = &Apache::lonnet::allowed('dcm',$env{'request.course.id'}); |
|
my $vcb = &Apache::lonnet::allowed('vcb',$env{'request.course.id'}); |
|
my $vpa = &Apache::lonnet::allowed('vpa',$env{'request.course.id'}); |
if ((!$dcm) && ($env{'request.course.sec'} ne '')) { |
if ((!$dcm) && ($env{'request.course.sec'} ne '')) { |
$dcm = &Apache::lonnet::allowed('dcm',$env{'request.course.id'}. |
$dcm = &Apache::lonnet::allowed('dcm',$env{'request.course.id'}. |
'/'.$env{'request.course.sec'}); |
'/'.$env{'request.course.sec'}); |
} |
} |
|
if ((!$vcb) && ($env{'request.course.sec'} ne '')) { |
|
$vcb = &Apache::lonnet::allowed('vcb',$env{'request.course.id'}. |
|
'/'.$env{'request.course.sec'}); |
|
} |
|
my (%linktext,%linktitle,%url); |
|
if ($parm_permission->{'edit'}) { |
|
%linktext = ( |
|
newoverview => 'Edit Resource Parameters - Overview Mode', |
|
settable => 'Edit Resource Parameters - Table Mode', |
|
setoverview => 'Modify Resource Parameters - Overview Mode', |
|
); |
|
%linktitle = ( |
|
newoverview => 'Set/Modify resource parameters in overview mode.', |
|
settable => 'Set/Modify resource parameters in table mode.', |
|
setoverview => 'Set/Modify existing resource parameters in overview mode.', |
|
); |
|
} else { |
|
%linktext = ( |
|
newoverview => 'View Resource Parameters - Overview Mode', |
|
settable => 'View Resource Parameters - Table Mode', |
|
setoverview => 'View Resource Parameters - Overview Mode', |
|
); |
|
%linktitle = ( |
|
newoverview => 'Display resource parameters in overview mode.', |
|
settable => 'Display resource parameters in table mode.', |
|
setoverview => 'Display existing resource parameters in overview mode.', |
|
); |
|
} |
|
if ($mgr) { |
|
$linktext{'resettimes'} = 'Reset Student Access Times'; |
|
$linktitle{'resettimes'} = "Reset access times for folders/maps, resources or the $lc_crstype."; |
|
$url{'resettimes'} = '/adm/helper/resettimes.helper'; |
|
} elsif ($vgr) { |
|
$linktext{'resettimes'} = 'Display Student Access Times', |
|
$linktitle{'resettimes'} = "Display access times for folders/maps, resources or the $lc_crstype.", |
|
$url{'resettimes'} = '/adm/accesstimes'; |
|
} |
my @menu = |
my @menu = |
( { categorytitle=>"Content Settings for this $crstype", |
( { categorytitle=>"Content Settings for this $crstype", |
items => [ |
items => [ |
{ linktext => 'Portfolio Metadata', |
{ linktext => 'Portfolio Metadata', |
url => '/adm/parmset?action=setrestrictmeta', |
url => '/adm/parmset?action=setrestrictmeta', |
permission => $parm_permission, |
permission => $parm_permission->{'setrestrictmeta'}, |
linktitle => "Restrict metadata for this $lc_crstype." , |
linktitle => "Restrict metadata for this $lc_crstype." , |
icon =>'contact-new.png' , |
icon =>'contact-new.png' , |
}, |
}, |
{ linktext => 'Reset Student Access Times', |
{ linktext => $linktext{'resettimes'}, |
url => '/adm/helper/resettimes.helper', |
url => $url{'resettimes'}, |
permission => $mgr, |
permission => ($vgr || $mgr), |
linktitle => "Reset access times for folders/maps, resources or the $lc_crstype." , |
linktitle => $linktitle{'resettimes'}, |
icon => 'start-here.png' , |
icon => 'start-here.png', |
}, |
}, |
{ linktext => 'Blocking Communication/Resource Access', |
{ linktext => 'Blocking Communication/Resource Access', |
url => '/adm/setblock', |
url => '/adm/setblock', |
permission => $dcm, |
permission => ($vcb || $dcm), |
linktitle => 'Configure blocking of communication/collaboration and access to resources during an exam', |
linktitle => 'Configure blocking of communication/collaboration and access to resources during an exam', |
icon => 'comblock.png', |
icon => 'comblock.png', |
}, |
}, |
{ linktext => 'Set Parameter Setting Default Actions', |
{ linktext => 'Set Parameter Setting Default Actions', |
url => '/adm/parmset?action=setdefaults', |
url => '/adm/parmset?action=setdefaults', |
permission => $parm_permission, |
permission => $parm_permission->{'setdefaults'}, |
linktitle =>'Set default actions for parameters.' , |
linktitle =>'Set default actions for parameters.' , |
icon => 'folder-new.png' , |
icon => 'folder-new.png' , |
}]}, |
}]}, |
Line 4934 ENDMAINFORMHEAD
|
Line 5330 ENDMAINFORMHEAD
|
items => [ |
items => [ |
{ linktext => 'Edit Resource Parameters - Helper Mode', |
{ linktext => 'Edit Resource Parameters - Helper Mode', |
url => '/adm/helper/parameter.helper', |
url => '/adm/helper/parameter.helper', |
permission => $parm_permission, |
permission => $parm_permission->{'helper'}, |
linktitle =>'Set/Modify resource parameters in helper mode.' , |
linktitle =>'Set/Modify resource parameters in helper mode.' , |
icon => 'dialog-information.png' , |
icon => 'dialog-information.png' , |
#help => 'Parameter_Helper', |
#help => 'Parameter_Helper', |
}, |
}, |
{ linktext => 'Edit Resource Parameters - Overview Mode', |
{ linktext => $linktext{'newoverview'}, |
url => '/adm/parmset?action=newoverview', |
url => '/adm/parmset?action=newoverview', |
permission => $parm_permission, |
permission => $parm_permission->{'newoverview'}, |
linktitle =>'Set/Modify resource parameters in overview mode.' , |
linktitle => $linktitle{'newoverview'}, |
icon => 'edit-find.png' , |
icon => 'edit-find.png', |
#help => 'Parameter_Overview', |
#help => 'Parameter_Overview', |
}, |
}, |
{ linktext => 'Edit Resource Parameters - Table Mode', |
{ linktext => $linktext{'settable'}, |
url => '/adm/parmset?action=settable', |
url => '/adm/parmset?action=settable', |
permission => $parm_permission, |
permission => $parm_permission->{'settable'}, |
linktitle =>'Set/Modify resource parameters in table mode.' , |
linktitle => $linktitle{'settable'}, |
icon => 'edit-copy.png' , |
icon => 'edit-copy.png', |
#help => 'Table_Mode', |
#help => 'Table_Mode', |
}]}, |
}]}, |
{ categorytitle => 'Existing Parameter Settings for Resources', |
{ categorytitle => 'Existing Parameter Settings for Resources', |
items => [ |
items => [ |
{ linktext => 'Modify Resource Parameters - Overview Mode', |
{ linktext => $linktext{'setoverview'},, |
url => '/adm/parmset?action=setoverview', |
url => '/adm/parmset?action=setoverview', |
permission => $parm_permission, |
permission => $parm_permission->{'setoverview'}, |
linktitle =>'Set/Modify existing resource parameters in overview mode.' , |
linktitle => $linktitle{'setoverview'}, |
icon => 'preferences-desktop-wallpaper.png' , |
icon => 'preferences-desktop-wallpaper.png', |
#help => 'Parameter_Overview', |
#help => 'Parameter_Overview', |
}, |
}, |
{ linktext => 'Change Log', |
{ linktext => 'Change Log', |
url => '/adm/parmset?action=parameterchangelog', |
url => '/adm/parmset?action=parameterchangelog', |
permission => $parm_permission, |
permission => $parm_permission->{'parameterchangelog'}, |
linktitle =>"View parameter and $lc_crstype blog posting/user notification change log." , |
linktitle =>"View parameter and $lc_crstype blog posting/user notification change log." , |
icon => 'document-properties.png', |
icon => 'document-properties.png', |
}]} |
}]} |
Line 4982 ENDMAINFORMHEAD
|
Line 5378 ENDMAINFORMHEAD
|
# PORTFOLIO METADATA |
# PORTFOLIO METADATA |
################################################## |
################################################## |
|
|
|
# Prints HTML to edit an item of portfolio metadata. The HTML contains several td elements (no tr). |
|
# It looks like field titles are not localized. |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
|
# @param {string} $field_name - metadata field name |
|
# @param {string} $field_text - metadata field title, in English unless manually added |
|
# @param {boolean} $added_flag - true if the field was manually added |
sub output_row { |
sub output_row { |
my ($r, $field_name, $field_text, $added_flag) = @_; |
my ($r, $field_name, $field_text, $added_flag) = @_; |
my $output; |
my $output; |
Line 5039 sub output_row {
|
Line 5442 sub output_row {
|
|
|
|
|
# UI to order portfolio metadata fields. |
# UI to order portfolio metadata fields. |
|
# Currently useless because addmetafield does not work. |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
sub order_meta_fields { |
sub order_meta_fields { |
my ($r)=@_; |
my ($r)=@_; |
my $idx = 1; |
my $idx = 1; |
Line 5129 sub order_meta_fields {
|
Line 5535 sub order_meta_fields {
|
} |
} |
|
|
|
|
|
# Returns HTML with a Continue button redirecting to the initial portfolio metadata screen. |
|
# @returns {string} |
sub continue { |
sub continue { |
my $output; |
my $output; |
$output .= '<form action="" method="post">'; |
$output .= '<form action="" method="post">'; |
Line 5138 sub continue {
|
Line 5546 sub continue {
|
} |
} |
|
|
|
|
|
# UI to add a metadata field. |
|
# Currenly does not work because of an HTML error (the field is not visible). |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
sub addmetafield { |
sub addmetafield { |
my ($r)=@_; |
my ($r)=@_; |
&Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=addmetadata', |
&Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=addmetadata', |
Line 5182 sub addmetafield {
|
Line 5594 sub addmetafield {
|
$r->print('<input type="submit" name="undelete" value="Undelete" />'); |
$r->print('<input type="submit" name="undelete" value="Undelete" />'); |
$r->print('</form>'); |
$r->print('</form>'); |
} |
} |
$r->print('<hr /><strong>Or</strong> you may enter a new metadata field name.<form method="post" action="/adm/parmset?action=addmetadata"'); |
$r->print('<hr /><strong>Or</strong> you may enter a new metadata field name.<form method="post" action="/adm/parmset?action=addmetadata"'); # FIXME: HTML error, input will not be displayed ! |
$r->print('<input type="text" name="fieldname" /><br />'); |
$r->print('<input type="text" name="fieldname" /><br />'); |
$r->print('<input type="submit" value="Add Metadata Field" />'); |
$r->print('<input type="submit" value="Add Metadata Field" />'); |
} |
} |
Line 5193 sub addmetafield {
|
Line 5605 sub addmetafield {
|
|
|
|
|
# Display or save portfolio metadata. |
# Display or save portfolio metadata. |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
sub setrestrictmeta { |
sub setrestrictmeta { |
my ($r)=@_; |
my ($r)=@_; |
my $next_meta; |
my $next_meta; |
Line 5268 ENDButtons
|
Line 5682 ENDButtons
|
my $added_flag = 1; |
my $added_flag = 1; |
foreach my $field (sort(keys(%$added_metadata_fields))) { |
foreach my $field (sort(keys(%$added_metadata_fields))) { |
$row_alt = $row_alt ? 0 : 1; |
$row_alt = $row_alt ? 0 : 1; |
$output.= &output_row($r, $field, $$added_metadata_fields{$field},$added_flag, $row_alt); |
$output.= &output_row($r, $field, $$added_metadata_fields{$field},$added_flag, $row_alt); # FIXME: wrong parameters |
} |
} |
$output .= &Apache::loncommon::end_data_table(); |
$output .= &Apache::loncommon::end_data_table(); |
$r->print(<<ENDenv); |
$r->print(<<ENDenv); |
Line 5283 ENDenv
|
Line 5697 ENDenv
|
} |
} |
|
|
|
|
|
# Returns metadata fields that have been manually added. |
|
# |
|
# @param {string} $cid - course id |
|
# @returns {hash reference} - hash field name -> field title (not localized) |
sub get_added_meta_fieldnames { |
sub get_added_meta_fieldnames { |
my ($cid) = @_; |
my ($cid) = @_; |
my %fields; |
my %fields; |
Line 5297 sub get_added_meta_fieldnames {
|
Line 5715 sub get_added_meta_fieldnames {
|
} |
} |
|
|
|
|
|
# Returns metadata fields that have been manually added and deleted. |
|
# |
|
# @param {string} $cid - course id |
|
# @returns {hash reference} - hash field name -> field title (not localized) |
sub get_deleted_meta_fieldnames { |
sub get_deleted_meta_fieldnames { |
my ($cid) = @_; |
my ($cid) = @_; |
my %fields; |
my %fields; |
Line 5318 sub get_deleted_meta_fieldnames {
|
Line 5740 sub get_deleted_meta_fieldnames {
|
################################################## |
################################################## |
|
|
# UI to change parameter setting default actions |
# UI to change parameter setting default actions |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
sub defaultsetter { |
sub defaultsetter { |
my ($r) = @_; |
my ($r) = @_; |
|
|
Line 5411 sub defaultsetter {
|
Line 5835 sub defaultsetter {
|
push @datedisplay,&mt('Automatically set earlier than ').$tempkey; |
push @datedisplay,&mt('Automatically set earlier than ').$tempkey; |
} |
} |
} |
} |
$r->print(&mt('Manual setting rules apply to all interfaces.').'<br />'. |
$r->print(&mt('Manual setting rules apply to all interfaces.').'<br />'. |
&mt('Automatic setting rules apply to table mode interfaces only.')); |
&mt('Automatic setting rules apply to table mode interfaces only.')); |
$r->print("\n".&Apache::loncommon::start_data_table(). |
$r->print("\n".&Apache::loncommon::start_data_table(). |
&Apache::loncommon::start_data_table_header_row(). |
&Apache::loncommon::start_data_table_header_row(). |
"<th>".&mt('Rule for parameter').'</th><th>'. |
"<th>".&mt('Rule for parameter').'</th><th>'. |
Line 5456 $r->print(&mt('Manual setting rules appl
|
Line 5880 $r->print(&mt('Manual setting rules appl
|
<input name="$tempkey\_hours" type="text" size="4" value="$hours" />$lt{'hours'}<br /> |
<input name="$tempkey\_hours" type="text" size="4" value="$hours" />$lt{'hours'}<br /> |
<input name="$tempkey\_min" type="text" size="4" value="$min" />$lt{'min'}<br /> |
<input name="$tempkey\_min" type="text" size="4" value="$min" />$lt{'min'}<br /> |
<input name="$tempkey\_sec" type="text" size="4" value="$sec" />$lt{'sec'} |
<input name="$tempkey\_sec" type="text" size="4" value="$sec" />$lt{'sec'} |
ENDINPUTDATE |
ENDINPUTDATE |
} elsif ($defkeytype{$tempkey} eq 'string_yesno') { |
} elsif ($defkeytype{$tempkey} eq 'string_yesno') { |
my $yeschecked=''; |
my $yeschecked=''; |
my $nochecked=''; |
my $nochecked=''; |
Line 5466 $r->print(&mt('Manual setting rules appl
|
Line 5890 $r->print(&mt('Manual setting rules appl
|
$r->print(<<ENDYESNO); |
$r->print(<<ENDYESNO); |
<label><input type="radio" name="$tempkey\_value" value="yes"$yeschecked /> $lt{'yes'}</label><br /> |
<label><input type="radio" name="$tempkey\_value" value="yes"$yeschecked /> $lt{'yes'}</label><br /> |
<label><input type="radio" name="$tempkey\_value" value="no"$nochecked /> $lt{'no'}</label> |
<label><input type="radio" name="$tempkey\_value" value="no"$nochecked /> $lt{'no'}</label> |
ENDYESNO |
ENDYESNO |
} else { |
} else { |
$r->print('<input type="text" size="20" name="'.$tempkey.'_value" value="'.&rulescache($tempkey.'_value').'" />'); |
$r->print('<input type="text" size="20" name="'.$tempkey.'_value" value="'.&rulescache($tempkey.'_value').'" />'); |
} |
} |
Line 5484 $r->print(&mt('Manual setting rules appl
|
Line 5908 $r->print(&mt('Manual setting rules appl
|
# PARAMETER CHANGES LOG |
# PARAMETER CHANGES LOG |
################################################## |
################################################## |
|
|
|
# Returns some info for a parameter log entry. |
|
# Returned entries: |
|
# $realm - HTML title for the parameter level and resource |
|
# $section - parameter section |
|
# $name - parameter name |
|
# $part - parameter part |
|
# $what - $part.'.'.$name |
|
# $middle - resource symb ? |
|
# $uname - user name (same as given) |
|
# $udom - user domain (same as given) |
|
# $issection - section or group name |
|
# $realmdescription - title for the parameter level and resource (without using HTML) |
|
# |
|
# FIXME: remove unused fields. |
|
# |
|
# @param {string} $key - parameter log key |
|
# @param {string} $uname - user name |
|
# @param {string} $udom - user domain |
|
# @param {string} $exeuser - unused |
|
# @param {string} $exedomain - unused |
|
# @param {boolean} $typeflag - .type log entry |
|
# @returns {Array} |
sub components { |
sub components { |
my ($key,$uname,$udom,$exeuser,$exedomain,$typeflag)=@_; |
my ($key,$uname,$udom,$exeuser,$exedomain,$typeflag)=@_; |
|
|
Line 5532 sub components {
|
Line 5978 sub components {
|
$what,$middle,$uname,$udom,$issection,$realmdescription); |
$what,$middle,$uname,$udom,$issection,$realmdescription); |
} |
} |
|
|
my %standard_parms; |
my %standard_parms; # hash parameter name -> parameter title (not localized) |
my %standard_parms_types; |
my %standard_parms_types; # hash parameter name -> parameter type |
|
|
|
# Reads parameter info from packages.tab into %standard_parms. |
sub load_parameter_names { |
sub load_parameter_names { |
open(my $config,"<$Apache::lonnet::perlvar{'lonTabDir'}/packages.tab"); |
open(my $config,"<$Apache::lonnet::perlvar{'lonTabDir'}/packages.tab"); |
while (my $configline=<$config>) { |
while (my $configline=<$config>) { |
Line 5553 sub load_parameter_names {
|
Line 6000 sub load_parameter_names {
|
$standard_parms{'int_zero_pos'} = 'Positive Integer or Zero'; |
$standard_parms{'int_zero_pos'} = 'Positive Integer or Zero'; |
} |
} |
|
|
|
# Returns a parameter title for standard parameters, the name for others. |
|
# |
|
# @param {string} $name - parameter name |
|
# @returns {string} |
sub standard_parameter_names { |
sub standard_parameter_names { |
my ($name)=@_; |
my ($name)=@_; |
if (!%standard_parms) { |
if (!%standard_parms) { |
Line 5565 sub standard_parameter_names {
|
Line 6016 sub standard_parameter_names {
|
} |
} |
} |
} |
|
|
|
# Returns a parameter type for standard parameters, undef for others. |
|
# |
|
# @param {string} $name - parameter name |
|
# @returns {string} |
sub standard_parameter_types { |
sub standard_parameter_types { |
my ($name)=@_; |
my ($name)=@_; |
if (!%standard_parms_types) { |
if (!%standard_parms_types) { |
Line 5576 sub standard_parameter_types {
|
Line 6031 sub standard_parameter_types {
|
return; |
return; |
} |
} |
|
|
|
# Returns a parameter level title (not localized) from the parameter level name. |
|
# |
|
# @param {string} $name - parameter level name (recognized: resourcelevel|maplevel|maplevelrecurse|courselevel) |
|
# @returns {string} |
sub standard_parameter_levels { |
sub standard_parameter_levels { |
my ($name)=@_; |
my ($name)=@_; |
my %levels = ( |
my %levels = ( |
Line 5591 sub standard_parameter_levels {
|
Line 6050 sub standard_parameter_levels {
|
} |
} |
|
|
# Display log for parameter changes, blog postings, user notification changes. |
# Display log for parameter changes, blog postings, user notification changes. |
|
# |
|
# @param {Apache2::RequestRec} $r - the Apache request |
sub parm_change_log { |
sub parm_change_log { |
my ($r)=@_; |
my ($r,$parm_permission)=@_; |
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
my $crstype = $env{'course.'.$env{'request.course.id'}.'.type'} |
my $crstype = $env{'course.'.$env{'request.course.id'}.'.type'}; |
&Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=settable', |
&Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=settable', |
text=>"Parameter Change Log"}); |
text=>"Parameter Change Log"}); |
my $js = '<script type="text/javascript">'."\n". |
my $js = '<script type="text/javascript">'."\n". |
Line 5624 sub parm_change_log {
|
Line 6085 sub parm_change_log {
|
'<input type="submit" value="'.&mt('Display').'" />'. |
'<input type="submit" value="'.&mt('Display').'" />'. |
'</form></fieldset></div><br clear="all" />'); |
'</form></fieldset></div><br clear="all" />'); |
|
|
|
my $readonly = 1; |
|
if ($parm_permission->{'edit'}) { |
|
undef($readonly); |
|
} |
my $courseopt=&Apache::lonnet::get_courseresdata($cnum,$cdom); |
my $courseopt=&Apache::lonnet::get_courseresdata($cnum,$cdom); |
$r->print(&Apache::loncommon::start_data_table().&Apache::loncommon::start_data_table_header_row(). |
$r->print(&Apache::loncommon::start_data_table().&Apache::loncommon::start_data_table_header_row(). |
'<th>'.&mt('Time').'</th><th>'.&mt('User').'</th><th>'.&mt('Extent').'</th><th>'.&mt('Users').'</th><th>'. |
'<th>'.&mt('Time').'</th><th>'.&mt('User').'</th><th>'.&mt('Extent').'</th><th>'.&mt('Users').'</th><th>'. |
&mt('Parameter').'</th><th>'.&mt('Part').'</th><th>'.&mt('New Value').'</th><th>'.&mt('Announce').'</th>'. |
&mt('Parameter').'</th><th>'.&mt('Part').'</th><th>'.&mt('New Value').'</th>'); |
&Apache::loncommon::end_data_table_header_row()); |
unless ($readonly) { |
|
$r->print('<th>'.&mt('Announce').'</th>'); |
|
} |
|
$r->print(&Apache::loncommon::end_data_table_header_row()); |
my $shown=0; |
my $shown=0; |
my $folder=''; |
my $folder=''; |
if ($env{'form.displayfilter'} eq 'currentfolder') { |
if ($env{'form.displayfilter'} eq 'currentfolder') { |
Line 5660 sub parm_change_log {
|
Line 6128 sub parm_change_log {
|
$parmlog{$id}{'exe_uname'}, |
$parmlog{$id}{'exe_uname'}, |
$parmlog{$id}{'exe_udom'}); |
$parmlog{$id}{'exe_udom'}); |
my $send_msg_link=''; |
my $send_msg_link=''; |
if ((($parmlog{$id}{'exe_uname'} ne $env{'user.name'}) |
if ((!$readonly) && |
|
(($parmlog{$id}{'exe_uname'} ne $env{'user.name'}) |
|| ($parmlog{$id}{'exe_udom'} ne $env{'user.domain'}))) { |
|| ($parmlog{$id}{'exe_udom'} ne $env{'user.domain'}))) { |
$send_msg_link ='<br />'. |
$send_msg_link ='<br />'. |
&Apache::loncommon::messagewrapper(&mt('Send message'), |
&Apache::loncommon::messagewrapper(&mt('Send message'), |
Line 5737 sub parm_change_log {
|
Line 6206 sub parm_change_log {
|
} |
} |
} |
} |
} |
} |
$output .= '</td><td>'; |
$output .= '</td>'; |
|
|
if ($stillactive) { |
unless ($readonly) { |
my $parmitem = &standard_parameter_names($parmname); |
$output .= '<td>'; |
$parmitem = &mt($parmitem); |
if ($stillactive) { |
my $title=&mt('Changed [_1]',$parmitem); |
my $parmitem = &standard_parameter_names($parmname); |
my $description=&mt('Changed [_1] for [_2] to [_3]', |
$parmitem = &mt($parmitem); |
$parmitem,$realmdescription, |
my $title=&mt('Changed [_1]',$parmitem); |
(&isdateparm($istype{$parmname})?&Apache::lonlocal::locallocaltime($value):$value)); |
my $description=&mt('Changed [_1] for [_2] to [_3]', |
if (($uname) && ($udom)) { |
$parmitem,$realmdescription, |
$output .= |
(&isdateparm($istype{$parmname})?&Apache::lonlocal::locallocaltime($value):$value)); |
&Apache::loncommon::messagewrapper('Notify User', |
if (($uname) && ($udom)) { |
$uname,$udom,$title, |
$output .= |
$description); |
&Apache::loncommon::messagewrapper('Notify User', |
} else { |
$uname,$udom,$title, |
$output .= |
$description); |
&Apache::lonrss::course_blog_link($id,$title, |
} else { |
$description); |
$output .= |
|
&Apache::lonrss::course_blog_link($id,$title, |
|
$description); |
|
} |
} |
} |
|
$output .= '</td>'; |
} |
} |
$output .= '</td>'.&Apache::loncommon::end_data_table_row(); |
$output .= &Apache::loncommon::end_data_table_row(); |
} |
} |
if ($env{'form.displayfilter'} eq 'containing') { |
if ($env{'form.displayfilter'} eq 'containing') { |
my $wholeentry=$about_me_link.':'. |
my $wholeentry=$about_me_link.':'. |
Line 5785 sub parm_change_log {
|
Line 6258 sub parm_change_log {
|
# MISC ! |
# MISC ! |
################################################## |
################################################## |
|
|
|
# Stores slot information. |
# Used by table UI |
# Used by table UI |
|
# FIXME: I don't understand how this can work when the symb is not defined (if only a map was selected) |
|
# |
|
# @param {string} $slot_name - slot name |
|
# @param {string} $cdom - course domain |
|
# @param {string} $cnum - course number |
|
# @param {string} $symb - resource symb |
|
# @param {string} $uname - user name |
|
# @param {string} $udom - user domain |
|
# @returns {string} - 'ok' or error name |
sub update_slots { |
sub update_slots { |
my ($slot_name,$cdom,$cnum,$symb,$uname,$udom) = @_; |
my ($slot_name,$cdom,$cnum,$symb,$uname,$udom) = @_; |
my %slot=&Apache::lonnet::get_slot($slot_name); |
my %slot=&Apache::lonnet::get_slot($slot_name); |
Line 5839 sub update_slots {
|
Line 6322 sub update_slots {
|
return $success; |
return $success; |
} |
} |
|
|
|
# Deletes a slot reservation. |
# Used by table UI |
# Used by table UI |
|
# FIXME: I don't understand how this can work when the symb is not defined (if only a map was selected) |
|
# |
|
# @param {string} $slot_name - slot name |
|
# @param {string} $cdom - course domain |
|
# @param {string} $cnum - course number |
|
# @param {string} $uname - user name |
|
# @param {string} $udom - user domain |
|
# @param {string} $symb - resource symb |
|
# @returns {string} - 'ok' or error name |
sub delete_slots { |
sub delete_slots { |
my ($slot_name,$cdom,$cnum,$uname,$udom,$symb) = @_; |
my ($slot_name,$cdom,$cnum,$uname,$udom,$symb) = @_; |
my $delresult; |
my $delresult; |
Line 5875 sub delete_slots {
|
Line 6368 sub delete_slots {
|
return $delresult; |
return $delresult; |
} |
} |
|
|
|
# Returns true if there is a current course. |
# Used by handler |
# Used by handler |
|
# |
|
# @returns {boolean} |
sub check_for_course_info { |
sub check_for_course_info { |
my $navmap = Apache::lonnavmaps::navmap->new(); |
my $navmap = Apache::lonnavmaps::navmap->new(); |
return 1 if ($navmap); |
return 1 if ($navmap); |
return 0; |
return 0; |
} |
} |
|
|
|
# Returns the current course host and host LON-CAPA version. |
|
# |
|
# @returns {Array} - (course hostname, major version number, minor version number) |
sub parameter_release_vars { |
sub parameter_release_vars { |
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $chome = $env{'course.'.$env{'request.course.id'}.'.home'}; |
my $chome = $env{'course.'.$env{'request.course.id'}.'.home'}; |
Line 5891 sub parameter_release_vars {
|
Line 6390 sub parameter_release_vars {
|
return ($chostname,$cmajor,$cminor); |
return ($chostname,$cmajor,$cminor); |
} |
} |
|
|
|
# Checks if the course host version can handle a parameter required version, |
|
# and if it does, stores the release needed for the course. |
|
# |
|
# @param {string} $name - parameter name |
|
# @param {string} $value - parameter value |
|
# @param {string} $valmatch - name of the test used for checking the value |
|
# @param {string} $namematch - name of the test used for checking the name |
|
# @param {string} $needsrelease - version needed by the parameter, major.minor |
|
# @param {integer} $cmajor - course major version number |
|
# @param {integer} $cminor - course minor version number |
|
# @returns {boolean} - true if a newer version is needed |
sub parameter_releasecheck { |
sub parameter_releasecheck { |
my ($name,$value,$valmatch,$namematch,$needsrelease,$cmajor,$cminor) = @_; |
my ($name,$value,$valmatch,$namematch,$needsrelease,$cmajor,$cminor) = @_; |
my $needsnewer; |
my $needsnewer; |
Line 5910 sub parameter_releasecheck {
|
Line 6420 sub parameter_releasecheck {
|
return $needsnewer; |
return $needsnewer; |
} |
} |
|
|
|
sub get_permission { |
|
my %permission; |
|
my $allowed = 0; |
|
return (\%permission,$allowed) unless ($env{'request.course.id'}); |
|
if ((&Apache::lonnet::allowed('opa',$env{'request.course.id'})) || |
|
(&Apache::lonnet::allowed('opa',$env{'request.course.id'}.'/'. |
|
$env{'request.course.sec'}))) { |
|
%permission= ( |
|
'edit' => 1, |
|
'set' => 1, |
|
'setoverview' => 1, |
|
'addmetadata' => 1, |
|
'ordermetadata' => 1, |
|
'setrestrictmeta' => 1, |
|
'newoverview' => 1, |
|
'setdefaults' => 1, |
|
'settable' => 1, |
|
'parameterchangelog' => 1, |
|
'cleanparameters' => 1, |
|
'dateshift1' => 1, |
|
'dateshift2' => 1, |
|
'helper' => 1, |
|
); |
|
} elsif ((&Apache::lonnet::allowed('vpa',$env{'request.course.id'})) || |
|
(&Apache::lonnet::allowed('vpa',$env{'request.course.id'}.'/'. |
|
$env{'request.course.sec'}))) { |
|
%permission = ( |
|
'set' => 1, |
|
'settable' => 1, |
|
'newoverview' => 1, |
|
'setoverview' => 1, |
|
'parameterchangelog' => 1, |
|
); |
|
} |
|
foreach my $perm (values(%permission)) { |
|
if ($perm) { $allowed=1; last; } |
|
} |
|
return (\%permission,$allowed); |
|
} |
|
|
################################################## |
################################################## |
# HANDLER |
# HANDLER |
################################################## |
################################################## |
Line 5958 sub handler {
|
Line 6508 sub handler {
|
'Parameter_Manager,Course_Environment,Parameter_Helper,Parameter_Overview,Table_Mode'}); |
'Parameter_Manager,Course_Environment,Parameter_Helper,Parameter_Overview,Table_Mode'}); |
|
|
# ----------------------------------------------------- Needs to be in a course |
# ----------------------------------------------------- Needs to be in a course |
my $parm_permission = |
my ($parm_permission,$allowed) = &get_permission(); |
(&Apache::lonnet::allowed('opa',$env{'request.course.id'}) || |
|
&Apache::lonnet::allowed('opa',$env{'request.course.id'}.'/'. |
|
$env{'request.course.sec'})); |
|
my $exists = &check_for_course_info(); |
my $exists = &check_for_course_info(); |
|
|
if ($env{'request.course.id'} && $parm_permission && $exists) { |
if ($env{'request.course.id'} && $allowed && $exists) { |
# |
# |
# Main switch on form.action and form.state, as appropriate |
# Main switch on form.action and form.state, as appropriate |
# |
# |
# Check first if coming from someone else headed directly for |
# Check first if coming from someone else headed directly for |
# the table mode |
# the table mode |
if ((($env{'form.command'} eq 'set') && ($env{'form.url'}) |
if (($parm_permission->{'set'}) && |
&& (!$env{'form.dis'})) || ($env{'form.symb'})) { |
((($env{'form.command'} eq 'set') && ($env{'form.url'}) |
&assessparms($r); |
&& (!$env{'form.dis'})) || ($env{'form.symb'}))) { |
|
&assessparms($r,$parm_permission); |
} elsif (! exists($env{'form.action'})) { |
} elsif (! exists($env{'form.action'})) { |
&print_main_menu($r,$parm_permission); |
&print_main_menu($r,$parm_permission); |
|
} elsif (!$parm_permission->{$env{'form.action'}}) { |
|
&print_main_menu($r,$parm_permission); |
} elsif ($env{'form.action'} eq 'setoverview') { |
} elsif ($env{'form.action'} eq 'setoverview') { |
&overview($r); |
&overview($r,$parm_permission); |
} elsif ($env{'form.action'} eq 'addmetadata') { |
} elsif ($env{'form.action'} eq 'addmetadata') { |
&addmetafield($r); |
&addmetafield($r); |
} elsif ($env{'form.action'} eq 'ordermetadata') { |
} elsif ($env{'form.action'} eq 'ordermetadata') { |
Line 5984 sub handler {
|
Line 6534 sub handler {
|
} elsif ($env{'form.action'} eq 'setrestrictmeta') { |
} elsif ($env{'form.action'} eq 'setrestrictmeta') { |
&setrestrictmeta($r); |
&setrestrictmeta($r); |
} elsif ($env{'form.action'} eq 'newoverview') { |
} elsif ($env{'form.action'} eq 'newoverview') { |
&newoverview($r); |
&newoverview($r,$parm_permission); |
} elsif ($env{'form.action'} eq 'setdefaults') { |
} elsif ($env{'form.action'} eq 'setdefaults') { |
&defaultsetter($r); |
&defaultsetter($r); |
} elsif ($env{'form.action'} eq 'settable') { |
} elsif ($env{'form.action'} eq 'settable') { |
&assessparms($r); |
&assessparms($r,$parm_permission); |
} elsif ($env{'form.action'} eq 'parameterchangelog') { |
} elsif ($env{'form.action'} eq 'parameterchangelog') { |
&parm_change_log($r); |
&parm_change_log($r,$parm_permission); |
} elsif ($env{'form.action'} eq 'cleanparameters') { |
} elsif ($env{'form.action'} eq 'cleanparameters') { |
&clean_parameters($r); |
&clean_parameters($r); |
} elsif ($env{'form.action'} eq 'dateshift1') { |
} elsif ($env{'form.action'} eq 'dateshift1') { |