version 1.462, 2006/10/10 21:57:31
|
version 1.471, 2006/11/20 21:00:47
|
Line 386 sub selectstudent_link {
|
Line 386 sub selectstudent_link {
|
} |
} |
|
|
sub coursebrowser_javascript { |
sub coursebrowser_javascript { |
my ($domainfilter)=@_; |
my ($domainfilter,$sec_element,$formname)=@_; |
my $crs_or_grp_alert = &mt('Please select the type of LON-CAPA entity - Course or Group - for which you wish to add/modify a user role'); |
my $crs_or_grp_alert = &mt('Please select the type of LON-CAPA entity - Course or Group - for which you wish to add/modify a user role'); |
return (<<ENDSTDBRW); |
my $output = ' |
<script type="text/javascript" language="Javascript" > |
<script type="text/javascript" language="Javascript" > |
var stdeditbrowser; |
var stdeditbrowser;'."\n"; |
|
$output .= <<"ENDSTDBRW"; |
function opencrsbrowser(formname,uname,udom,desc,extra_element,multflag,crstype) { |
function opencrsbrowser(formname,uname,udom,desc,extra_element,multflag,crstype) { |
var url = '/adm/pickcourse?'; |
var url = '/adm/pickcourse?'; |
var filter; |
var domainfilter = ''; |
if (filter != null) { |
var formid = getFormIdByName(formname); |
if (filter != '') { |
if (formid > -1) { |
url += 'filter='+filter+'&'; |
var domid = getIndexByName(formid,udom); |
} |
if (domid > -1) { |
|
if (document.forms[formid].elements[domid].type == 'select-one') { |
|
domainfilter=document.forms[formid].elements[domid].options[document.forms[formid].elements[domid].selectedIndex].value; |
|
} |
|
if (document.forms[formid].elements[domid].type == 'hidden') { |
|
domainfilter=document.forms[formid].elements[domid].value; |
|
} |
|
} |
} |
} |
var domainfilter='$domainfilter'; |
|
if (domainfilter != null) { |
if (domainfilter != null) { |
if (domainfilter != '') { |
if (domainfilter != '') { |
url += 'domainfilter='+domainfilter+'&'; |
url += 'domainfilter='+domainfilter+'&'; |
Line 408 sub coursebrowser_javascript {
|
Line 415 sub coursebrowser_javascript {
|
url += 'form=' + formname + '&cnumelement='+uname+ |
url += 'form=' + formname + '&cnumelement='+uname+ |
'&cdomelement='+udom+ |
'&cdomelement='+udom+ |
'&cnameelement='+desc; |
'&cnameelement='+desc; |
if (extra_element !=null && extra_element != '' && formname == 'rolechoice') { |
if (extra_element !=null && extra_element != '') { |
url += '&roleelement='+extra_element; |
if (formname == 'rolechoice') { |
if (domainfilter == null || domainfilter == '') { |
url += '&roleelement='+extra_element; |
url += '&domainfilter='+extra_element; |
if (domainfilter == null || domainfilter == '') { |
|
url += '&domainfilter='+extra_element; |
|
} |
} |
} |
|
else { |
|
if (formname == 'portform') { |
|
url += '&setroles='+extra_element; |
|
} |
|
} |
} |
} |
if (multflag !=null && multflag != '') { |
if (multflag !=null && multflag != '') { |
url += '&multiple='+multflag; |
url += '&multiple='+multflag; |
Line 435 sub coursebrowser_javascript {
|
Line 449 sub coursebrowser_javascript {
|
stdeditbrowser = open(url,title,options,'1'); |
stdeditbrowser = open(url,title,options,'1'); |
stdeditbrowser.focus(); |
stdeditbrowser.focus(); |
} |
} |
</script> |
|
|
function getFormIdByName(formname) { |
|
for (var i=0;i<document.forms.length;i++) { |
|
if (document.forms[i].name == formname) { |
|
return i; |
|
} |
|
} |
|
return -1; |
|
} |
|
|
|
function getIndexByName(formid,item) { |
|
for (var i=0;i<document.forms[formid].elements.length;i++) { |
|
if (document.forms[formid].elements[i].name == item) { |
|
return i; |
|
} |
|
} |
|
return -1; |
|
} |
ENDSTDBRW |
ENDSTDBRW |
|
if ($sec_element ne '') { |
|
$output .= &setsec_javascript($sec_element,$formname); |
|
} |
|
$output .= ' |
|
</script>'; |
|
return $output; |
|
} |
|
|
|
sub setsec_javascript { |
|
my ($sec_element,$formname) = @_; |
|
my $setsections = qq| |
|
function setSect(sectionlist) { |
|
var sectionsArray = sectionlist.split(","); |
|
var numSections = sectionsArray.length; |
|
document.$formname.$sec_element.length = 0; |
|
if (numSections == 0) { |
|
document.$formname.$sec_element.multiple=false; |
|
document.$formname.$sec_element.size=1; |
|
document.$formname.$sec_element.options[0] = new Option('No existing sections','',false,false) |
|
} else { |
|
if (numSections == 1) { |
|
document.$formname.$sec_element.multiple=false; |
|
document.$formname.$sec_element.size=1; |
|
document.$formname.$sec_element.options[0] = new Option('Select','',true,true); |
|
document.$formname.$sec_element.options[1] = new Option('No section','',false,false) |
|
document.$formname.$sec_element.options[2] = new Option(sectionsArray[0],sectionsArray[0],false,false); |
|
} else { |
|
for (var i=0; i<numSections; i++) { |
|
document.$formname.$sec_element.options[i] = new Option(sectionsArray[i],sectionsArray[i],false,false) |
|
} |
|
document.$formname.$sec_element.multiple=true |
|
if (numSections < 3) { |
|
document.$formname.$sec_element.size=numSections; |
|
} else { |
|
document.$formname.$sec_element.size=3; |
|
} |
|
document.$formname.$sec_element.options[0].selected = false |
|
} |
|
} |
} |
} |
|
|; |
|
return $setsections; |
|
} |
|
|
|
|
sub selectcourse_link { |
sub selectcourse_link { |
my ($form,$unameele,$udomele,$desc,$extra_element,$multflag,$selecttype)=@_; |
my ($form,$unameele,$udomele,$desc,$extra_element,$multflag,$selecttype)=@_; |
Line 2067 sub getnames {
|
Line 2141 sub getnames {
|
} |
} |
} |
} |
|
|
|
sub getemails { |
|
my ($uname,$udom)=@_; |
|
if ($udom eq 'public' && $uname eq 'public') { |
|
return; |
|
} |
|
if (!$udom) { $udom=$env{'user.domain'}; } |
|
if (!$uname) { $uname=$env{'user.name'}; } |
|
my $id=$uname.':'.$udom; |
|
my ($names,$cached)=&Apache::lonnet::is_cached_new('emailscache',$id); |
|
if ($cached) { |
|
return %{$names}; |
|
} else { |
|
my %loadnames=&Apache::lonnet::get('environment', |
|
['notification','critnotification', |
|
'permanentemail'], |
|
$udom,$uname); |
|
&Apache::lonnet::do_cache_new('emailscache',$id,\%loadnames); |
|
return %loadnames; |
|
} |
|
} |
|
|
# ------------------------------------------------------------------ Screenname |
# ------------------------------------------------------------------ Screenname |
|
|
=pod |
=pod |
Line 2596 sub submlink {
|
Line 2691 sub submlink {
|
my ($text,$uname,$udom,$symb,$target)=@_; |
my ($text,$uname,$udom,$symb,$target)=@_; |
if (!($uname && $udom)) { |
if (!($uname && $udom)) { |
(my $cursymb, my $courseid,$udom,$uname)= |
(my $cursymb, my $courseid,$udom,$uname)= |
&Apache::lonxml::whichuser($symb); |
&Apache::lonnet::whichuser($symb); |
if (!$symb) { $symb=$cursymb; } |
if (!$symb) { $symb=$cursymb; } |
} |
} |
if (!$symb) { $symb=&Apache::lonnet::symbread(); } |
if (!$symb) { $symb=&Apache::lonnet::symbread(); } |
Line 2642 sub pprmlink {
|
Line 2737 sub pprmlink {
|
my ($text,$uname,$udom,$symb,$target)=@_; |
my ($text,$uname,$udom,$symb,$target)=@_; |
if (!($uname && $udom)) { |
if (!($uname && $udom)) { |
(my $cursymb, my $courseid,$udom,$uname)= |
(my $cursymb, my $courseid,$udom,$uname)= |
&Apache::lonxml::whichuser($symb); |
&Apache::lonnet::whichuser($symb); |
if (!$symb) { $symb=$cursymb; } |
if (!$symb) { $symb=$cursymb; } |
} |
} |
if (!$symb) { $symb=&Apache::lonnet::symbread(); } |
if (!$symb) { $symb=&Apache::lonnet::symbread(); } |
Line 3173 sub standard_css {
|
Line 3268 sub standard_css {
|
my $mono = 'monospace'; |
my $mono = 'monospace'; |
my $data_table_head = $tabbg; |
my $data_table_head = $tabbg; |
my $data_table_light = '#EEEEEE'; |
my $data_table_light = '#EEEEEE'; |
my $data_table_dark = '#DDD'; |
my $data_table_dark = '#DDDDDD'; |
my $data_table_darker = '#CCC'; |
my $data_table_darker = '#CCCCCC'; |
my $data_table_highlight = '#FFFF00'; |
my $data_table_highlight = '#FFFF00'; |
my $mail_new = '#FFBB77'; |
my $mail_new = '#FFBB77'; |
my $mail_new_hover = '#DD9955'; |
my $mail_new_hover = '#DD9955'; |
Line 3259 table#LC_title_bar td.LC_title_bar_who {
|
Line 3354 table#LC_title_bar td.LC_title_bar_who {
|
font: small $sans; |
font: small $sans; |
text-align: right; |
text-align: right; |
} |
} |
|
span.LC_metadata { |
|
font-family: $sans; |
|
} |
span.LC_title_bar_title { |
span.LC_title_bar_title { |
font: bold x-large $sans; |
font: bold x-large $sans; |
} |
} |
Line 3388 table.LC_whatsnew tr.LC_empty_row td {
|
Line 3486 table.LC_whatsnew tr.LC_empty_row td {
|
text-align: center; |
text-align: center; |
padding: 8px; |
padding: 8px; |
} |
} |
|
table.LC_whatsnew tr.LC_empty_row td { |
|
padding: 4ex |
|
} |
|
|
|
|
table.LC_whatsnew { |
table.LC_whatsnew { |
} |
} |
Line 3728 Inputs: $title - optional title for the
|
Line 3830 Inputs: $title - optional title for the
|
bgcolor -> override the default page bgcolor |
bgcolor -> override the default page bgcolor |
no_auto_mt_title |
no_auto_mt_title |
-> prevent &mt()ing the title arg |
-> prevent &mt()ing the title arg |
|
|
=back |
=back |
|
|
=cut |
=cut |
Line 4100 sub simple_error_page {
|
Line 4203 sub simple_error_page {
|
$css_class = (join(' ',$css_class,$add_class)); |
$css_class = (join(' ',$css_class,$add_class)); |
return '<tr class="'.$css_class.'">'."\n";; |
return '<tr class="'.$css_class.'">'."\n";; |
} |
} |
|
|
|
sub continue_data_table_row { |
|
my ($add_class) = @_; |
|
my $css_class = ($row_count % 2)?'':'LC_even_row'; |
|
$css_class = (join(' ',$css_class,$add_class)); |
|
return '<tr class="'.$css_class.'">'."\n";; |
|
} |
|
|
sub end_data_table_row { |
sub end_data_table_row { |
return '</tr>'."\n";; |
return '</tr>'."\n";; |
Line 4676 sub get_env_multiple {
|
Line 4786 sub get_env_multiple {
|
|
|
=pod |
=pod |
|
|
=back |
=back |
|
|
=head1 CSV Upload/Handling functions |
=head1 CSV Upload/Handling functions |
|
|
Line 6004 sub escape_url {
|
Line 6114 sub escape_url {
|
|
|
# -------------------------------------------------------- Initliaze user login |
# -------------------------------------------------------- Initliaze user login |
sub init_user_environment { |
sub init_user_environment { |
my ($r, $username, $domain, $authhost, $form, $extra_env) = @_; |
my ($r, $username, $domain, $authhost, $form, $args) = @_; |
my $lonids=$Apache::lonnet::perlvar{'lonIDsDir'}; |
my $lonids=$Apache::lonnet::perlvar{'lonIDsDir'}; |
|
|
my $public=($username eq 'public' && $domain eq 'public'); |
my $public=($username eq 'public' && $domain eq 'public'); |
Line 6032 sub init_user_environment {
|
Line 6142 sub init_user_environment {
|
} |
} |
if (!$cookie) { $cookie="publicuser_$oldest"; } |
if (!$cookie) { $cookie="publicuser_$oldest"; } |
} else { |
} else { |
opendir(DIR,$lonids); |
# if this isn't a robot, kill any existing non-robot sessions |
while ($filename=readdir(DIR)) { |
if (!$args->{'robot'}) { |
if ($filename=~/^$username\_\d+\_$domain\_$authhost\.id$/) { |
opendir(DIR,$lonids); |
unlink($lonids.'/'.$filename); |
while ($filename=readdir(DIR)) { |
|
if ($filename=~/^$username\_\d+\_$domain\_$authhost\.id$/) { |
|
unlink($lonids.'/'.$filename); |
|
} |
} |
} |
|
closedir(DIR); |
} |
} |
closedir(DIR); |
|
|
|
# Give them a new cookie |
# Give them a new cookie |
|
my $id = ($args->{'robot'} ? 'robot'.$args->{'robot'} |
$cookie="$username\_$now\_$domain\_$authhost"; |
: $now); |
|
$cookie="$username\_$id\_$domain\_$authhost"; |
|
|
# Initialize roles |
# Initialize roles |
|
|
Line 6136 sub init_user_environment {
|
Line 6249 sub init_user_environment {
|
&_add_to_env(\%disk_env,\%initial_env); |
&_add_to_env(\%disk_env,\%initial_env); |
&_add_to_env(\%disk_env,\%userenv,'environment.'); |
&_add_to_env(\%disk_env,\%userenv,'environment.'); |
&_add_to_env(\%disk_env,$userroles); |
&_add_to_env(\%disk_env,$userroles); |
&_add_to_env(\%disk_env,$extra_env); |
if (ref($args->{'extra_env'})) { |
|
&_add_to_env(\%disk_env,$args->{'extra_env'}); |
|
} |
untie(%disk_env); |
untie(%disk_env); |
} else { |
} else { |
&Apache::lonnet::logthis("<font color=\"blue\">WARNING: ". |
&Apache::lonnet::logthis("<font color=\"blue\">WARNING: ". |