--- loncom/interface/lonpreferences.pm	2003/09/17 01:45:14	1.29
+++ loncom/interface/lonpreferences.pm	2004/03/16 19:13:09	1.37
@@ -1,7 +1,7 @@
 # The LearningOnline Network
 # Preferences
 #
-# $Id: lonpreferences.pm,v 1.29 2003/09/17 01:45:14 www Exp $
+# $Id: lonpreferences.pm,v 1.37 2004/03/16 19:13:09 www Exp $
 #
 # Copyright Michigan State University Board of Trustees
 #
@@ -25,16 +25,6 @@
 #
 # http://www.lon-capa.org/
 #
-# (Internal Server Error Handler
-#
-# (Login Screen
-# 5/21/99,5/22,5/25,5/26,5/31,6/2,6/10,7/12,7/14,
-# 1/14/00,5/29,5/30,6/1,6/29,7/1,11/9 Gerd Kortemeyer)
-#
-# 3/1/1 Gerd Kortemeyer)
-#
-# 3/1 Gerd Kortemeyer
-#
 # 2/13/02 2/14 2/15 Matthew Hall
 #
 # This package uses the "londes.js" javascript code. 
@@ -51,6 +41,7 @@ use Crypt::DES;
 use DynaLoader; # for Crypt::DES version
 use Apache::loncommon();
 use Apache::lonhtmlcommon();
+use Apache::lonlocal;
 
 #
 # Write lonnet::passwd to do the call below.
@@ -62,7 +53,7 @@ use Apache::lonhtmlcommon();
 ##################################################
 sub des_keys {
     # Make a new key for DES encryption.
-    # Each key has two parts which are returned seperately.
+    # Each key has two parts which are returned separately.
     # Please note:  Each key must be passed through the &hex function
     # before it is output to the web browser.  The hex versions cannot
     # be used to decrypt.
@@ -108,27 +99,25 @@ sub languagechanger {
     my $user       = $ENV{'user.name'};
     my $domain     = $ENV{'user.domain'};
     my %userenv = &Apache::lonnet::get
-        ('environment',['languages','translator']);
+        ('environment',['languages']);
     my $language=$userenv{'languages'};
-    my $translator=$userenv{'translator'};
-    my $bodytag=&Apache::loncommon::bodytag(
-              'Change Your Language Preferences');
-    $r->print(<<ENDLSCREEN);
-<html>
-$bodytag
 
+    my $pref=&mt('Preferred language');
+    my %langchoices=('' => 'No language preference');
+    foreach (&Apache::loncommon::languageids()) {
+	if (&Apache::loncommon::supportedlanguagecode($_)) {
+	    $langchoices{&Apache::loncommon::supportedlanguagecode($_)}
+	               = &Apache::loncommon::plainlanguagedescription($_);
+	}
+    }
+    my $selectionbox=&Apache::loncommon::select_form($language,'language',
+						     %langchoices);
+    $r->print(<<ENDLSCREEN);
 <form name="server" action="/adm/preferences" method="post">
 <input type="hidden" name="action" value="verify_and_change_languages" />
-<br />Preferred language:
-<input type="text" size="5" value="$language" name="language" />
+<br />$pref: $selectionbox
 ENDLSCREEN
-    if ($ENV{'user.adv'}) {
-	$r->print (<<ENDTRSC);
-<br />Willing to translate for language:
-<input type="text" size="5" value="$translator" name="translator" />
-ENDTRSC
-    }
-    $r->print('<br /><input type="submit" value="Change" /></form></body></html>');
+    $r->print('<br /><input type="submit" value="'.&mt('Change').'" />');
 }
 
 
@@ -149,29 +138,9 @@ sub verify_and_change_languages {
         &Apache::lonnet::delenv('environment\.languages');
         $message='Reset preferred language';
     }
-    if ($ENV{'user.adv'}) {
-	$message.='<br />';
-	my $newtrans  = $ENV{'form.translator'};
-	$newtrans=~s/[^\-\w]//g;
-	if ($newtrans) {
-	    &Apache::lonnet::put('environment',{'translator' => $newtrans});
-	    &Apache::lonnet::appenv('environment.translator' => $newtrans);
-	    $message.='Set translator to '.$newtrans;
-	} else {
-	    &Apache::lonnet::del('environment',['translator']);
-	    &Apache::lonnet::delenv('environment\.translator');
-	    $message.='Reset translator';
-	}
-    }
-
-    my $bodytag=&Apache::loncommon::bodytag(
-                    'Change Your Language Preferences');
     $r->print(<<ENDVCSCREEN);
-<html>
-$bodytag
 </p>
 $message
-</body></html>
 ENDVCSCREEN
 }
 
@@ -187,12 +156,7 @@ sub screennamechanger {
         ('environment',['screenname','nickname']);
     my $screenname=$userenv{'screenname'};
     my $nickname=$userenv{'nickname'};
-    my $bodytag=&Apache::loncommon::bodytag(
-              'Change Your Nickname and Anonymous Screen Name');
     $r->print(<<ENDSCREEN);
-<html>
-$bodytag
-
 <form name="server" action="/adm/preferences" method="post">
 <input type="hidden" name="action" value="verify_and_change_screenname" />
 <br />New screenname (shown if you post anonymously):
@@ -201,8 +165,6 @@ $bodytag
 <input type="text" size="20" value="$nickname" name="nickname" />
 <input type="submit" value="Change" />
 </form>
-</body>
-</html>
 ENDSCREEN
 }
 
@@ -237,14 +199,9 @@ sub verify_and_change_screenname {
         $message.='Reset nickname';
     }
 
-    my $bodytag=&Apache::loncommon::bodytag(
-                    'Change Your Nickname and Anonymous Screen Name');
     $r->print(<<ENDVCSCREEN);
-<html>
-$bodytag
 </p>
 $message
-</body></html>
 ENDVCSCREEN
 }
 
@@ -260,8 +217,6 @@ sub msgforwardchanger {
     my $msgforward=$userenv{'msgforward'};
     my $notification=$userenv{'notification'};
     my $critnotification=$userenv{'critnotification'};
-    my $bodytag=&Apache::loncommon::bodytag(
-                    'Change Your Message Forwarding and Notification');
     my $forwardingHelp = Apache::loncommon::help_open_topic("Prefs_Forwarding",
 							    "What are forwarding ".
 							    "and notification ".
@@ -270,8 +225,6 @@ sub msgforwardchanger {
 								 "What are critical messages");
 
     $r->print(<<ENDMSG);
-<html>
-$bodytag
 $forwardingHelp <br />
 <form name="server" action="/adm/preferences" method="post">
 <input type="hidden" name="action" value="verify_and_change_msgforward" />
@@ -283,8 +236,6 @@ New Critical Message Notification Email
 <input type="text" size="40" value="$critnotification" name="critnotification" />$criticalMessageHelp<hr />
 <input type="submit" value="Change" />
 </form>
-</body>
-</html>
 ENDMSG
 }
 
@@ -338,14 +289,9 @@ sub verify_and_change_msgforward {
         &Apache::lonnet::delenv('environment\.critnotification');
         $message.='Reset critical message notification<br />';
     }
-    my $bodytag=&Apache::loncommon::bodytag(
-                           'Change Your Message Forwarding and Notifications');
     $r->print(<<ENDVCMSG);
-<html>
-$bodytag
 </p>
 $message
-</body></html>
 ENDVCMSG
 }
 
@@ -355,9 +301,6 @@ ENDVCMSG
 
 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)/) {
@@ -390,7 +333,6 @@ sub colorschanger {
     }
     my $pjump_def = &Apache::lonhtmlcommon::pjump_javascript_definition();
     $r->print(<<ENDCOL);
-<html>
 <script>
 
     function pclose() {
@@ -417,7 +359,6 @@ sub colorschanger {
 
 
 </script>
-$bodytag
 <form name="parmform">
 <input type="hidden" name="pres_marker" />
 <input type="hidden" name="pres_type" />
@@ -431,8 +372,6 @@ $chtable
 <input type="submit" value="Change Custom Colors" />
 <input type="submit" name="resetall" value="Reset All Colors to Default" />
 </form>
-</body>
-</html>
 ENDCOL
 }
 
@@ -473,18 +412,12 @@ sub verify_and_change_colors {
 	    $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
 }
 
@@ -530,12 +463,7 @@ sub passwordchanger {
 	my $jsh=Apache::File->new($include."/londes.js");
 	$r->print(<$jsh>);
     }
-    my $bodytag=&Apache::loncommon::bodytag('Change Password','',
-                                         'onLoad="init();"');
     $r->print(<<ENDFORM);
-</head>
-$bodytag
-
 <script language="JavaScript">
 
     function send() {
@@ -565,7 +493,7 @@ $bodytag
 $errormessage
 
 <p>
-<!-- We seperate the forms into 'server' and 'client' in order to
+<!-- We separate the forms into 'server' and 'client' in order to
      ensure that unencrypted passwords will not be sent out by a
      crappy browser -->
 
@@ -711,109 +639,182 @@ sub handler {
     my $r = shift;
     my $user = $ENV{'user.name'};
     my $domain = $ENV{'user.domain'};
-    $r->content_type('text/html');
+    &Apache::loncommon::content_type($r,'text/html');
     # Some pages contain DES keys and should not be cached.
     &Apache::loncommon::no_cache($r);
     $r->send_http_header;
     return OK if $r->header_only;
     #
-    if ($ENV{'form.action'} eq 'changepass') {
-	&passwordchanger($r);
-    } elsif ($ENV{'form.action'} eq 'verify_and_change_pass') {
-	&verify_and_change_password($r);
-    } elsif ($ENV{'form.action'} eq 'changescreenname') {
-        &screennamechanger($r);
-    } elsif ($ENV{'form.action'} eq 'verify_and_change_screenname') {
-        &verify_and_change_screenname($r);
-    } elsif ($ENV{'form.action'} eq 'changemsgforward') {
-        &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 'changelanguages') {
-        &languagechanger($r);
-    } elsif ($ENV{'form.action'} eq 'verify_and_change_languages') {
-        &verify_and_change_languages($r);
-    } elsif ($ENV{'form.action'} eq 'debugtoggle') {
-	if (($ENV{'user.name'} eq 'albertel' ) ||
-            ($ENV{'user.name'} eq 'kortemey' ) ||
-            ($ENV{'user.name'} eq 'korte')) {
-	    if ($ENV{'user.debug'}) {
-		&Apache::lonnet::delenv('user\.debug');
-	    } else {
-		&Apache::lonnet::appenv('user.debug' => 1);
-	    }
-	}
-    } else {
-	$r->print(<<ENDHEADER);
+    &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
+                                            ['action']);
+    #
+    &Apache::lonhtmlcommon::clear_breadcrumbs();
+    &Apache::lonhtmlcommon::add_breadcrumb
+        ({href => '/adm/preferences',
+          text => 'Set User Preferences'});
+
+    my @Options;
+    # Determine current authentication method
+    my $currentauth=&Apache::lonnet::queryauthenticate($user,$domain);
+    if ($currentauth =~ /^(unix|internal):/) {
+        push (@Options,({ action   => 'changepass',
+                          linktext => 'Change password',
+                          href     => '/adm/preferences',
+                          help     => 'Change_Password',
+                          subroutine => \&passwordchanger,
+                          breadcrumb => 
+                              { href => '/adm/preferences?action=changepass',
+                                text => 'Change Password'},
+                          },
+                        { action => 'verify_and_change_pass',
+                          subroutine => \&verify_and_change_password,
+                          breadcrumb => 
+                              { href =>'/adm/preferences?action=changepass',
+                                text => 'Change Password'},
+                          printmenu => 'yes',
+                          }));
+    }
+    push (@Options,({ action   => 'changescreenname',
+                      linktext => 'Change Screen Name',
+                      href     => '/adm/preferences',
+                      help     => 'Prefs_Screen_Name_Nickname',
+                      subroutine => \&screennamechanger,
+                      breadcrumb => 
+                          { href => '/adm/preferences?action=changescreenname',
+                            text => 'Change Screen Name'},
+                      },
+                    { action   => 'verify_and_change_screenname',
+                      subroutine => \&verify_and_change_screenname,
+                      breadcrumb => 
+                          { href => '/adm/preferences?action=changescreenname',
+                            text => 'Change Screen Name'},
+                      printmenu => 'yes',
+                      }));
+
+    push (@Options,({ action   => 'changemsgforward',
+                      linktext => 'Change Message Forwarding',
+                      text     => 'and Notification Addresses',
+                      href     => '/adm/preferences',
+                      help     => 'Prefs_Forwarding',
+                      breadcrumb => 
+                          { href => '/adm/preferences?action=changemsgforward',
+                            text => 'Change Message Forwarding'},
+                      subroutine => \&msgforwardchanger,
+                      },
+                    { action => 'verify_and_change_msgforward',
+                      breadcrumb => 
+                          { href => '/adm/preferences?action=changemsgforward',
+                            text => 'Change Message Forwarding'},
+                      printmenu => 'yes',
+                      subroutine => \&verify_and_change_msgforward }));
+    my $aboutmeaction=
+        '/adm/'.$ENV{'user.domain'}.'/'.$ENV{'user.name'}.'/aboutme';
+    push (@Options,{ action => 'none', 
+                     linktext =>
+                         q{Edit the 'About Me' personal information screen},
+                     href => $aboutmeaction});
+    push (@Options,({ action => 'changecolors',
+                      linktext => 'Change Color Scheme',
+                      href => '/adm/preferences',
+                      help => 'Change_Colors',
+                      breadcrumb => 
+                          { href => '/adm/preferences?action=changecolors',
+                            text => 'Change Colors'},
+                      subroutine => \&colorschanger,
+                  },
+                    { action => 'verify_and_change_colors',
+                      breadcrumb => 
+                          { href => '/adm/preferences?action=changecolors',
+                            text => 'Change Colors'},
+                      printmenu => 'yes',
+                      subroutine => \&verify_and_change_colors,
+                      }));
+    push (@Options,({ action => 'changelanguages',
+                      linktext => 'Change Language Prefences',
+                      href => '/adm/preferences',
+                      breadcrumb=>
+                          { href => '/adm/preferences?action=changelanguages',
+                            text => 'Change Language'},
+                      subroutine =>  \&languagechanger,
+                  },
+                    { action => 'verify_and_change_languages',
+                      breadcrumb=>
+                          {href => '/adm/preferences?action=changelanguages',
+                           text => 'Change Language'},
+                      printmenu => 'yes',
+                      subroutine=>\&verify_and_change_languages, }
+                    ));
+    if ($ENV{'user.name'} =~ /^(albertel|koretemey|korte|hallmat3|turtle)$/) {
+        push (@Options,({ action => 'debugtoggle',
+                          printmenu => 'yes',
+                          subroutine => \&toggle_debug,
+                          }));
+    }
+    $r->print(<<ENDHEADER);
 <html>
 <head>
 <title>LON-CAPA Preferences</title>
 </head>
 ENDHEADER
-        $r->print(&Apache::loncommon::bodytag('Change Your Preferences'));
-	# Determine current authentication method
-	my $currentauth=&Apache::lonnet::queryauthenticate($user,$domain);
-	if ($currentauth =~ /^(unix|internal):/) {
-	    $r->print(<<ENDPASSWORDFORM);
-<form name="client" action="/adm/preferences" method="post">
-<input type="hidden" name="action" value="changepass" />
-<input type="submit" value="Change password" />
-</form>
-ENDPASSWORDFORM
+    my $call = undef;
+    my $printmenu = 'yes';
+    foreach my $option (@Options) {
+        if ($option->{'action'} eq $ENV{'form.action'}) {
+            &Apache::lonnet::logthis('got action '.$option->{'action'});
+            $call = $option->{'subroutine'};
+            $printmenu = $option->{'printmenu'};
+            if (exists($option->{'breadcrumb'})) {
+                &Apache::lonhtmlcommon::add_breadcrumb
+                    ($option->{'breadcrumb'});
+            }
         }
-# Change screen name
-	    $r->print(<<ENDSCREENNAMEFORM);
-<form name="client" action="/adm/preferences" method="post">
-<input type="hidden" name="action" value="changescreenname" />
-<input type="submit" 
-value="Change nickname and anonymous discussion screen name" />
-</form>
-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 and notification addresses" />
-</form>
-ENDMSGFORWARDFORM
-# The "about me" page
-	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" />
-</form>
-ENDABOUTME
-	    $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
-
-	    $r->print(<<ENDLANGUAGES);
-<form name="client" action="/adm/preferences" method="post">
-<input type="hidden" name="action" value="changelanguages" />
-<input type="submit" value="Change language preferences" />
-</form>
-ENDLANGUAGES
-
-	if (($ENV{'user.name'} eq 'albertel' ) ||
-            ($ENV{'user.name'} eq 'kortemey' ) ||
-            ($ENV{'user.name'} eq 'korte')) {
-	    $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(&Apache::loncommon::bodytag('Change Preferences'));
+    $r->print(&Apache::lonhtmlcommon::breadcrumbs
+              (undef,'Change Preferences'));
+    if (defined($call)) {
+        $call->($r);
+    }
+    if ($printmenu eq 'yes') {
+        my $optionlist = '<table cellpadding="5">';
+        if ($ENV{'user.name'} =~ 
+                         /^(albertel|kortemey|korte|hallmat3|turtle)$/
+            ) {
+            push (@Options,({ action => 'debugtoggle',
+                              linktext => 'Toggle Debug Messages',
+                              text => 'Current Debug status is -'.
+                                  $ENV{'user.debug'}.'-.',
+                              href => '/adm/preferences',
+                              printmenu => 'yes',
+                              subroutine => \&toggle_debug,
+                              }));
+        }
+        foreach my $option(@Options) {
+            my $optiontext = '';
+            if (exists($option->{'href'})) {
+                $optiontext .= 
+                    '<a href="'.$option->{'href'}.
+                    '?action='.$option->{'action'}.'">'.
+                    $option->{'linktext'}.'</a>';
+            }
+            if (exists($option->{'text'})) {
+                $optiontext .= ' '.$option->{'text'};
+            }
+            if ($optiontext ne '') {
+                $optiontext = '<font size="+1">'.$optiontext.'</font>'; 
+                my $helplink = '&nbsp;';
+                if (exists($option->{'help'})) {
+                    $helplink = &Apache::loncommon::help_open_topic
+                                                    ($option->{'help'});
+                }
+                $optionlist .= '<tr>'.
+                    '<td>'.$helplink.'</td>'.
+                    '<td>'.$optiontext.'</td>'.
+                    '</tr>';
+            }
+        }
+        $optionlist .= '</table>';
+        $r->print($optionlist);
     }
     $r->print(<<ENDFOOTER);
 </body>
@@ -822,5 +823,13 @@ ENDFOOTER
     return OK;
 }
 
+sub toggle_debug {
+    if ($ENV{'user.debug'}) {
+        &Apache::lonnet::delenv('user\.debug');
+    } else {
+        &Apache::lonnet::appenv('user.debug' => 1);
+    }
+}
+
 1;
 __END__