--- loncom/interface/lonpreferences.pm 2002/09/13 19:32:09 1.14 +++ loncom/interface/lonpreferences.pm 2003/04/30 15:12:29 1.22 @@ -1,7 +1,7 @@ # The LearningOnline Network # Preferences # -# $Id: lonpreferences.pm,v 1.14 2002/09/13 19:32:09 www Exp $ +# $Id: lonpreferences.pm,v 1.22 2003/04/30 15:12:29 matthew Exp $ # # Copyright Michigan State University Board of Trustees # @@ -148,7 +148,7 @@ sub verify_and_change_screenname { } # Nickname $message.='<br />'; - my $newscreen = $ENV{'form.nickname'}; + $newscreen = $ENV{'form.nickname'}; $newscreen=~s/[^ \w]//g; if ($newscreen) { &Apache::lonnet::put('environment',{'nickname' => $newscreen}); @@ -181,8 +181,10 @@ sub msgforwardchanger { my $domain = $ENV{'user.domain'}; my %userenv = &Apache::lonnet::get('environment',['msgforward']); my $msgforward=$userenv{'msgforward'}; + my $notification=$userenv{'notification'}; + my $critnotification=$userenv{'critnotification'}; my $bodytag=&Apache::loncommon::bodytag( - 'Change Your Message Forwarding'); + 'Change Your Message Forwarding and Notification'); $r->print(<<ENDMSG); <html> $bodytag @@ -190,7 +192,11 @@ $bodytag <form name="server" action="/adm/preferences" method="post"> <input type="hidden" name="action" value="verify_and_change_msgforward" /> New Forwarding Address(es) (<tt>user:domain,user:domain,...</tt>): -<input type="text" size="40" value="$msgforward" name="msgforward" /> +<input type="text" size="40" value="$msgforward" name="msgforward" /><hr /> +New Message Notification Email Address(es) (<tt>joe\@doe.com,jane\@doe.edu,...</tt>): +<input type="text" size="40" value="$notification" name="notification" /><hr /> +New Critical Message Notification Email Address(es) (<tt>joe\@doe.com,jane\@doe.edu,...</tt>): +<input type="text" size="40" value="$critnotification" name="critnotification" /><hr /> <input type="submit" value="Change" /> </form> </body> @@ -220,14 +226,36 @@ sub verify_and_change_msgforward { if ($newscreen) { &Apache::lonnet::put('environment',{'msgforward' => $newscreen}); &Apache::lonnet::appenv('environment.msgforward' => $newscreen); - $message.='Set new message forwarding to '.$newscreen; + $message.='Set new message forwarding to '.$newscreen.'<br />'; } else { &Apache::lonnet::del('environment',['msgforward']); &Apache::lonnet::delenv('environment\.msgforward'); - $message.='Reset message forwarding'; + $message.='Reset message forwarding<br />'; + } + my $notification=$ENV{'form.notification'}; + $notification=~s/\s//gs; + if ($notification) { + &Apache::lonnet::put('environment',{'notification' => $notification}); + &Apache::lonnet::appenv('environment.notification' => $notification); + $message.='Set message notification address to '.$notification.'<br />'; + } else { + &Apache::lonnet::del('environment',['notification']); + &Apache::lonnet::delenv('environment\.notification'); + $message.='Reset message notification<br />'; + } + my $critnotification=$ENV{'form.critnotification'}; + $critnotification=~s/\s//gs; + if ($critnotification) { + &Apache::lonnet::put('environment',{'critnotification' => $critnotification}); + &Apache::lonnet::appenv('environment.critnotification' => $critnotification); + $message.='Set critical message notification address to '.$critnotification; + } else { + &Apache::lonnet::del('environment',['critnotification']); + &Apache::lonnet::delenv('environment\.critnotification'); + $message.='Reset critical message notification<br />'; } my $bodytag=&Apache::loncommon::bodytag( - 'Change Your Message Forwarding'); + 'Change Your Message Forwarding and Notifications'); $r->print(<<ENDVCMSG); <html> $bodytag @@ -237,6 +265,151 @@ $message ENDVCMSG } +################################################################ +# Colors # +################################################################ + +sub colorschanger { + my $r = shift; + my $bodytag=&Apache::loncommon::bodytag( + 'Change Color Scheme for Current Role Type','', + 'onUnload="pclose();"'); +# figure out colors + my $function='student'; + if ($ENV{'request.role'}=~/^(cc|in|ta|ep)/) { + $function='coordinator'; + } + if ($ENV{'request.role'}=~/^(su|dc|ad|li)/) { + $function='admin'; + } + if (($ENV{'request.role'}=~/^(au|ca)/) || + ($ENV{'REQUEST_URI'}=~/^(\/priv|\~)/)) { + $function='author'; + } + my $domain=&Apache::loncommon::determinedomain(); + my %colortypes=('pgbg' => 'Page Background', + 'tabbg' => 'Header Background', + 'sidebg'=> 'Header Border', + 'font' => 'Font', + 'link' => 'Un-Visited Link', + 'vlink' => 'Visited Link', + 'alink' => 'Active Link'); + my $chtable=''; + foreach my $item (sort(keys(%colortypes))) { + my $curcol=&Apache::loncommon::designparm($function.'.'.$item,$domain); + $chtable.='<tr><td>'.$colortypes{$item}.'</td><td bgcolor="'.$curcol. + '"> </td><td><input name="'.$item. + '" size="10" value="'.$curcol. +'" /></td><td><a href="javascript:pjump('."'color_custom','".$colortypes{$item}. +"','".$curcol."','" + .$item."','parmform.pres','psub'".');">Select</a></td></tr>'; + } + $r->print(<<ENDCOL); +<html> +<script> + + function pclose() { + parmwin=window.open("/adm/rat/empty.html","LONCAPAparms", + "height=350,width=350,scrollbars=no,menubar=no"); + parmwin.close(); + } + + function pjump(type,dis,value,marker,ret,call) { + parmwin=window.open("/adm/rat/parameter.html?type="+escape(type) + +"&value="+escape(value)+"&marker="+escape(marker) + +"&return="+escape(ret) + +"&call="+escape(call)+"&name="+escape(dis),"LONCAPAparms", + "height=350,width=350,scrollbars=no,menubar=no"); + + } + + function psub() { + pclose(); + if (document.parmform.pres_marker.value!='') { + if (document.parmform.pres_type.value!='') { + eval('document.server.'+ + document.parmform.pres_marker.value+ + '.value=document.parmform.pres_value.value;'); + } + } else { + document.parmform.pres_value.value=''; + document.parmform.pres_marker.value=''; + } + } + + +</script> +$bodytag +<form name="parmform"> +<input type="hidden" name="pres_marker" /> +<input type="hidden" name="pres_type" /> +<input type="hidden" name="pres_value" /> +</form> +<form name="server" action="/adm/preferences" method="post"> +<input type="hidden" name="action" value="verify_and_change_colors" /> +<table border="2"> +$chtable +</table> +<input type="submit" value="Change Custom Colors" /> +<input type="submit" name="resetall" value="Reset All Colors to Default" /> +</form> +</body> +</html> +ENDCOL +} + +sub verify_and_change_colors { + my $r = shift; +# figure out colors + my $function='student'; + if ($ENV{'request.role'}=~/^(cc|in|ta|ep)/) { + $function='coordinator'; + } + if ($ENV{'request.role'}=~/^(su|dc|ad|li)/) { + $function='admin'; + } + if (($ENV{'request.role'}=~/^(au|ca)/) || + ($ENV{'REQUEST_URI'}=~/^(\/priv|\~)/)) { + $function='author'; + } + my $domain=&Apache::loncommon::determinedomain(); + my %colortypes=('pgbg' => 'Page Background', + 'tabbg' => 'Header Background', + 'sidebg'=> 'Header Border', + 'font' => 'Font', + 'link' => 'Un-Visited Link', + 'vlink' => 'Visited Link', + 'alink' => 'Active Link'); + + my $message=''; + foreach my $item (keys %colortypes) { + my $color=$ENV{'form.'.$item}; + my $entry='color.'.$function.'.'.$item; + if (($color=~/^\#[0-9A-Fa-f]{6}$/) && (!$ENV{'form.resetall'})) { + &Apache::lonnet::put('environment',{$entry => $color}); + &Apache::lonnet::appenv('environment.'.$entry => $color); + $message.='Set '.$colortypes{$item}.' to '.$color.'<br />'; + } else { + &Apache::lonnet::del('environment',[$entry]); + &Apache::lonnet::delenv('environment\.'.$entry); + $message.='Reset '.$colortypes{$item}.'<br />'; + } + } + my $bodytag=&Apache::loncommon::bodytag( + 'Change Color Scheme for Current Role Type'); + $r->print(<<ENDVCCOL); +<html> +$bodytag +</p> +$message +<form name="client" action="/adm/preferences" method="post"> +<input type="hidden" name="action" value="changecolors" /> +<input type="submit" value="Revise color scheme again" /> +</form> +</body></html> +ENDVCCOL +} + ###################################################### # password handler subroutines # ###################################################### @@ -394,9 +567,9 @@ ENDERROR } my ($ckey,$n1key,$n2key)=split(/&/,$tmpinfo); # - my $currentpass = &des_decrypt($ckey ,$currentpass); - my $newpass1 = &des_decrypt($n1key,$newpass1); - my $newpass2 = &des_decrypt($n2key,$newpass2); + $currentpass = &des_decrypt($ckey ,$currentpass); + $newpass1 = &des_decrypt($n1key,$newpass1); + $newpass2 = &des_decrypt($n2key,$newpass2); # if ($newpass1 ne $newpass2) { &passwordchanger($r, @@ -478,6 +651,18 @@ sub handler { &msgforwardchanger($r); } elsif ($ENV{'form.action'} eq 'verify_and_change_msgforward') { &verify_and_change_msgforward($r); + } elsif ($ENV{'form.action'} eq 'changecolors') { + &colorschanger($r); + } elsif ($ENV{'form.action'} eq 'verify_and_change_colors') { + &verify_and_change_colors($r); + } elsif ($ENV{'form.action'} eq 'debugtoggle') { + if ($ENV{'user.name'} eq 'albertel' ) { + if ($ENV{'user.debug'}) { + &Apache::lonnet::delenv('user\.debug'); + } else { + &Apache::lonnet::appenv('user.debug' => 1); + } + } } else { $r->print(<<ENDHEADER); <html> @@ -507,19 +692,35 @@ ENDSCREENNAMEFORM $r->print(<<ENDMSGFORWARDFORM); <form name="client" action="/adm/preferences" method="post"> <input type="hidden" name="action" value="changemsgforward" /> -<input type="submit" value="Change message forwarding address" /> +<input type="submit" value="Change message forwarding and notification addresses" /> </form> ENDMSGFORWARDFORM # The "about me" page - my $aboutmeaction= - '/adm/'.$ENV{'user.domain'}.'/'.$ENV{'user.name'}.'/aboutme'; - $r->print(<<ENDABOUTME); + my $aboutmeaction= + '/adm/'.$ENV{'user.domain'}.'/'.$ENV{'user.name'}.'/aboutme'; + $r->print(<<ENDABOUTME); <form name="client" action="$aboutmeaction" method="post"> <input type="hidden" name="action" value="changescreenname" /> -<input type="submit" value="Edit the 'About Me' Personal Information Screen" /> +<input type="submit" value="Edit the 'About Me' personal information screen" /> </form> ENDABOUTME - # Other preference setting code should be added here + $r->print(<<ENDCOLORFORM); +<form name="client" action="/adm/preferences" method="post"> +<input type="hidden" name="action" value="changecolors" /> +<input type="submit" value="Change color scheme" /> +</form> +ENDCOLORFORM + + if ($ENV{'user.name'} eq 'albertel') { + $r->print(<<ENDDEBUG); +<form name="client" action="/adm/preferences" method="post"> +<input type="hidden" name="action" value="debugtoggle" /> +<input type="submit" value="Toggle Debug" /> +Current Debug status is -$ENV{'user.debug'}-. +</form> +ENDDEBUG + } + # Other preference setting code should be added here } $r->print(<<ENDFOOTER); </body>