Diff for /loncom/interface/lonpreferences.pm between versions 1.157 and 1.173

version 1.157, 2009/05/05 11:40:51 version 1.173, 2009/10/08 19:54:37
Line 135  sub verify_and_change_wysiwyg { Line 135  sub verify_and_change_wysiwyg {
     my $newsetting=$env{'form.wysiwyg'};      my $newsetting=$env{'form.wysiwyg'};
     &Apache::lonnet::put('environment',{'wysiwygeditor' => $newsetting});      &Apache::lonnet::put('environment',{'wysiwygeditor' => $newsetting});
     &Apache::lonnet::appenv({'environment.wysiwygeditor' => $newsetting});      &Apache::lonnet::appenv({'environment.wysiwygeditor' => $newsetting});
     &print_main_menu($r,'<p>'.&Apache::lonhtmlcommon::confirm_success(&mt('Setting WYSIWYG editor to:').' '      my $message=&Apache::lonhtmlcommon::confirm_success(&mt('Set [_1] to [_2]','<i>'.&mt('WYSIWYG Editor').'</i>','<tt>'.&mt($newsetting).'</tt>'));
  .&mt($newsetting)).'</p>');      $message=&Apache::loncommon::confirmwrapper($message);
       &print_main_menu($r,$message);
 }  }
   
 ################################################################  ################################################################
Line 186  sub verify_and_change_languages { Line 187  sub verify_and_change_languages {
     if ($newlanguage) {      if ($newlanguage) {
         &Apache::lonnet::put('environment',{'languages' => $newlanguage});          &Apache::lonnet::put('environment',{'languages' => $newlanguage});
         &Apache::lonnet::appenv({'environment.languages' => $newlanguage});          &Apache::lonnet::appenv({'environment.languages' => $newlanguage});
         $message=&Apache::lonhtmlcommon::confirm_success(&mt('Set new preferred languages to ').'<tt>"'.$newlanguage.'"</tt>.');          $message=&Apache::lonhtmlcommon::confirm_success(&mt('Set [_1] to [_2]','<i>'.&mt('Preferred language').'</i>','<tt>"'.$newlanguage.'"</tt>.'));
     } else {      } else {
         &Apache::lonnet::del('environment',['languages']);          &Apache::lonnet::del('environment',['languages']);
         &Apache::lonnet::delenv('environment.languages');          &Apache::lonnet::delenv('environment.languages');
         $message=&Apache::lonhtmlcommon::confirm_success(&mt('Reset preferred language.'));          $message=&Apache::lonhtmlcommon::confirm_success(&mt('Reset [_1]','<i>'.&mt('Preferred language').'</i>'));
     }      }
       $message=&Apache::loncommon::confirmwrapper($message);
     &Apache::loncommon::flush_langs_cache($user,$domain);      &Apache::loncommon::flush_langs_cache($user,$domain);
     &print_main_menu($r, $message);      &print_main_menu($r, $message);
 }  }
Line 215  sub texenginechanger { Line 217  sub texenginechanger {
      'tth' => 'tth (TeX to HTML)',       'tth' => 'tth (TeX to HTML)',
      #'ttm' => 'TeX to MathML',       #'ttm' => 'TeX to MathML',
      'jsMath' => 'jsMath',       'jsMath' => 'jsMath',
      'mimetex' => 'mimetex (Convert to Images)'       'mimetex' => 'mimetex (Convert to Images)',
                        'raw' => 'Raw (Screen Reader)'
                      );                       );
     my $selectionbox=&Apache::loncommon::select_form($texengine,'texengine',      my $selectionbox=&Apache::loncommon::select_form($texengine,'texengine',
      %mathchoices);       %mathchoices);
Line 230  sub texenginechanger { Line 233  sub texenginechanger {
       'mimetex'  => 'mimetex (Convert to Images):',        'mimetex'  => 'mimetex (Convert to Images):',
     );      );
   
       my $jsMathWarning='<p>'
                        .'<div class="LC_warning">'
                        .&mt("It looks like you don't have the TeX math fonts installed.")
                        .'</div>'
                        .'<div>'
                        .&mt('The jsMath example on this page may not look right without them. '
                            .'The [_1]jsMath Home Page[_2] has information on how to download the '
                            .'needed fonts. In the meantime, jsMath will do the best it can '
                            .'with the fonts you have, but it may not be pretty and some equations '
                            .'may not be rendered correctly.'
                            ,'<a href="http://www.math.union.edu/locate/jsMath/" target="_blank">'
                            ,'</a>')
                        .'</div>'
                        .'</p>';
   
     $r->print(<<ENDLSCREEN);      $r->print(<<ENDLSCREEN);
 <h2>$lt{'headline'}</h2>  <h2>$lt{'headline'}</h2>
 <form name="prefs" action="/adm/preferences" method="post">  <form name="prefs" action="/adm/preferences" method="post">
Line 249  $lt{'exmpl'} Line 267  $lt{'exmpl'}
 $jsMath_start  $jsMath_start
 <script type="text/javascript" language="JavaScript">  <script type="text/javascript" language="JavaScript">
 if (jsMath.nofonts == 1) {  if (jsMath.nofonts == 1) {
     document.writeln      document.writeln($jsMathWarning);
         ('<div style="padding: 10; border-style: solid; border-width:3;'  
  +' border-color: #DD0000; background-color: #FFF8F8; width: 75%; text-align: left">'  
  +'<small><font color="#AA0000"><b>Warning:</b> '  
  +'It looks like you don\\\'t have the TeX math fonts installed. '  
  +'The jsMath example on this page may not look right without them. '  
  +'The <a href="http://www.math.union.edu/locate/jsMath/" target="_blank"> '  
  +'jsMath Home Page</a> has information on how to download the '  
  +'needed fonts.  In the meantime, jsMath will do the best it can '  
  +'with the fonts you have, but it may not be pretty and some equations '  
  +'may not be rendered correctly. '  
  +'</font></small></div>');  
 }  }
 </script>  </script>
 <iframe src="/res/adm/pages/math_example.tex?inhibitmenu=yes&texengine=jsMath" width="400" height="120"></iframe>  <iframe src="/res/adm/pages/math_example.tex?inhibitmenu=yes&texengine=jsMath" width="400" height="120"></iframe>
Line 300  sub verify_and_change_texengine { Line 307  sub verify_and_change_texengine {
     if ($newtexengine) {      if ($newtexengine) {
         &Apache::lonnet::put('environment',{'texengine' => $newtexengine});          &Apache::lonnet::put('environment',{'texengine' => $newtexengine});
         &Apache::lonnet::appenv({'environment.texengine' => $newtexengine});          &Apache::lonnet::appenv({'environment.texengine' => $newtexengine});
         $message=&Apache::lonhtmlcommon::confirm_success(&mt('Set new preferred math display to ').'<tt>"'.$newtexengine.'"</tt>.');          $message=&Apache::lonhtmlcommon::confirm_success(&mt('Set [_1] to [_2]','<i>'.&mt('Preferred method to display Math').'</i>','<tt>"'.$newtexengine.'"</tt>'));
     } else {      } else {
         &Apache::lonnet::del('environment',['texengine']);          &Apache::lonnet::del('environment',['texengine']);
         &Apache::lonnet::delenv('environment.texengine');          &Apache::lonnet::delenv('environment.texengine');
         $message=&Apache::lonhtmlcommon::confirm_success(&mt('Reset preferred math display.'));          $message=&Apache::lonhtmlcommon::confirm_success(&mt('Reset [_1]','<i>'.&mt('Preferred method to display Math').'</i>'));
     }      }
       $message=&Apache::loncommon::confirmwrapper($message);
     &print_main_menu($r, $message);      &print_main_menu($r, $message);
 }  }
   
Line 364  sub rolesprefchanger { Line 372  sub rolesprefchanger {
             my $checked = "";              my $checked = "";
             my $value = $recent_roles{$role_key};              my $value = $recent_roles{$role_key};
             if ($frozen_roles{$role_key}) {              if ($frozen_roles{$role_key}) {
                 $checked = "checked=\"checked\"";                  $checked = ' checked="checked"';
             }              }
     $count++;      $count++;
             $roles_check_list .=              $roles_check_list .=
  &Apache::loncommon::start_data_table_row().   &Apache::loncommon::start_data_table_row().
  '<td class="LC_table_cell_checkbox">'.   '<td class="LC_table_cell_checkbox">'.
  "<input type=\"checkbox\" $checked name=\"freezeroles\"".   "<input type=\"checkbox\"$checked name=\"freezeroles\"".
  " id=\"freezeroles$count\" value=\"$role_key\" /></td>".   " id=\"freezeroles$count\" value=\"$role_key\" /></td>".
  "<td><label for=\"freezeroles$count\">".   "<td><label for=\"freezeroles$count\">".
  "$role_text{$role_key}</label></td>".   "$role_text{$role_key}</label></td>".
Line 382  sub rolesprefchanger { Line 390  sub rolesprefchanger {
     $r->print('      $r->print('
 <p>'.&mt('Some LON-CAPA users have a long list of '.$lc_role.'s. The Recent '.$role.'s Hotlist feature keeps track of the last N '.$lc_role.'s which have been visited and places a table of these at the top of the '.$lc_role.'s page. People with very few '.$lc_role.'s should leave this feature disabled.').'  <p>'.&mt('Some LON-CAPA users have a long list of '.$lc_role.'s. The Recent '.$role.'s Hotlist feature keeps track of the last N '.$lc_role.'s which have been visited and places a table of these at the top of the '.$lc_role.'s page. People with very few '.$lc_role.'s should leave this feature disabled.').'
 </p>  </p>
 <form name="prefs" action="/adm/preferences" method="POST">  <form name="prefs" action="/adm/preferences" method="post">
 <input type="hidden" name="action" value="verify_and_change_rolespref" />  <input type="hidden" name="action" value="verify_and_change_rolespref" />
 <br /><label>'.&mt('Enable Recent '.$role.'s Hotlist:').'  <br /><label>'.&mt('Enable Recent '.$role.'s Hotlist:').'
 <input type="checkbox" '.$checked.' name="recentroles" value="true" /></label>  <input type="checkbox"'.$checked.' name="recentroles" value="true" /></label>
 <br />'.&mt('Number of '.$role.'s in Hotlist:').'  <br />'.&mt('Number of '.$role.'s in Hotlist:').'
 <select name="recentrolesn" size="1">  <select name="recentrolesn" size="1">
 '.$options.'  '.$options.'
Line 473  sub verify_and_change_rolespref { Line 481  sub verify_and_change_rolespref {
 # Unset any roles that were previously frozen but aren't in list  # Unset any roles that were previously frozen but aren't in list
     foreach my $role_key (sort(keys(%recent_roles))) {      foreach my $role_key (sort(keys(%recent_roles))) {
         if (($frozen_roles{$role_key}) && (!exists($freeze{$role_key}))) {          if (($frozen_roles{$role_key}) && (!exists($freeze{$role_key}))) {
     $message .= "<br />".&Apache::lonhtmlcommon::confirm_success(&mt('Unfreezing '.$role.': [_1]',$role_text{$role_key}))."\n";      $message .= "<br />".&Apache::lonhtmlcommon::confirm_success(&mt('Unfreezing '.$role.': [_1]','<i>'.$role_text{$role_key}.'</i>'));
     &Apache::lonhtmlcommon::store_recent('roles',$role_key,' ',0);      &Apache::lonhtmlcommon::store_recent('roles',$role_key,' ',0);
         }          }
     }      }
Line 482  sub verify_and_change_rolespref { Line 490  sub verify_and_change_rolespref {
     foreach my $role_key (@freeze_list) {      foreach my $role_key (@freeze_list) {
         if (!$frozen_roles{$role_key}) {          if (!$frozen_roles{$role_key}) {
              $message .= "<br />".               $message .= "<br />".
              &Apache::lonhtmlcommon::confirm_success(&mt('Freezing '.$role.': [_1]',$role_text{$role_key}))."\n";               &Apache::lonhtmlcommon::confirm_success(&mt('Freezing '.$role.': [_1]','<i>'.$role_text{$role_key}.'</i>'));
              &Apache::lonhtmlcommon::store_recent('roles',               &Apache::lonhtmlcommon::store_recent('roles',
                                           $role_key,' ',1);                                            $role_key,' ',1);
         }          }
     }      }
     $message .= "<hr /><br />\n";      $message=&Apache::loncommon::confirmwrapper($message);
     &print_main_menu($r, $message);      &print_main_menu($r, $message);
 }  }
   
Line 516  sub screennamechanger { Line 524  sub screennamechanger {
     $r->print('<form name="prefs" action="/adm/preferences" method="post">'      $r->print('<form name="prefs" action="/adm/preferences" method="post">'
              .'<input type="hidden" name="action" value="verify_and_change_screenname" />'               .'<input type="hidden" name="action" value="verify_and_change_screenname" />'
              .&Apache::lonhtmlcommon::start_pick_box()               .&Apache::lonhtmlcommon::start_pick_box()
              .&Apache::lonhtmlcommon::row_title(&mt('New screenname (shown if you post anonymously)'))               .&Apache::lonhtmlcommon::row_title(&mt('Screenname').' '.&mt('(shown if you post anonymously)'))
              .'<input type="text" size="20" value="'.$screenname.'" name="screenname" />'               .'<input type="text" size="20" value="'.$screenname.'" name="screenname" />'
              .&Apache::lonhtmlcommon::row_closure()               .&Apache::lonhtmlcommon::row_closure()
              .&Apache::lonhtmlcommon::row_title(&mt('New nickname (shown if you post non-anonymously)'))               .&Apache::lonhtmlcommon::row_title(&mt('Nickname').' '.&mt('(shown if you post non-anonymously)'))
              .'<input type="text" size="20" value="'.$nickname.'" name="nickname" />'               .'<input type="text" size="20" value="'.$nickname.'" name="nickname" />'
              .&Apache::lonhtmlcommon::row_closure()               .&Apache::lonhtmlcommon::row_closure()
              .&Apache::lonhtmlcommon::row_title()               .&Apache::lonhtmlcommon::row_title()
Line 541  sub verify_and_change_screenname { Line 549  sub verify_and_change_screenname {
     if ($newscreen) {      if ($newscreen) {
         &Apache::lonnet::put('environment',{'screenname' => $newscreen});          &Apache::lonnet::put('environment',{'screenname' => $newscreen});
         &Apache::lonnet::appenv({'environment.screenname' => $newscreen});          &Apache::lonnet::appenv({'environment.screenname' => $newscreen});
         $message=&Apache::lonhtmlcommon::confirm_success(&mt('Set new screenname to ').'<tt>"'.$newscreen.'."</tt>.');          $message=&Apache::lonhtmlcommon::confirm_success(&mt('Set [_1] to [_2]','<i>'.&mt('Screenname').'</i>','<tt>"'.$newscreen.'"</tt>'));
     } else {      } else {
         &Apache::lonnet::del('environment',['screenname']);          &Apache::lonnet::del('environment',['screenname']);
         &Apache::lonnet::delenv('environment.screenname');          &Apache::lonnet::delenv('environment.screenname');
         $message=&Apache::lonhtmlcommon::confirm_success(&mt('Reset screenname.'));          $message=&Apache::lonhtmlcommon::confirm_success(&mt('Reset [_1]','<i>'.&mt('Screenname').'</i>'));
     }      }
 # Nickname  # Nickname
     $message.='<br />';      $message.='<br />';
Line 554  sub verify_and_change_screenname { Line 562  sub verify_and_change_screenname {
     if ($newscreen) {      if ($newscreen) {
         &Apache::lonnet::put('environment',{'nickname' => $newscreen});          &Apache::lonnet::put('environment',{'nickname' => $newscreen});
         &Apache::lonnet::appenv({'environment.nickname' => $newscreen});          &Apache::lonnet::appenv({'environment.nickname' => $newscreen});
         $message.=&Apache::lonhtmlcommon::confirm_success(&mt('Set new nickname to ').'<tt>"'.$newscreen.'"</tt>.');          $message.=&Apache::lonhtmlcommon::confirm_success(&mt('Set [_1] to [_2]','<i>'.&mt('Nickname').'</i>','<tt>"'.$newscreen.'"</tt>'));
     } else {      } else {
         &Apache::lonnet::del('environment',['nickname']);          &Apache::lonnet::del('environment',['nickname']);
         &Apache::lonnet::delenv('environment.nickname');          &Apache::lonnet::delenv('environment.nickname');
         $message.=&Apache::lonhtmlcommon::confirm_success(&mt('Reset nickname.'));          $message.=&Apache::lonhtmlcommon::confirm_success(&mt('Reset [_1]','<i>'.&mt('Nickname').'</i>'));
     }      }
     &Apache::lonnet::devalidate_cache_new('namescache',$user.':'.$domain);      &Apache::lonnet::devalidate_cache_new('namescache',$user.':'.$domain);
       $message=&Apache::loncommon::confirmwrapper($message);
     &print_main_menu($r, $message);      &print_main_menu($r, $message);
 }  }
   
Line 609  sub verify_and_change_icons { Line 618  sub verify_and_change_icons {
     my $r = shift;      my $r = shift;
     my $user       = $env{'user.name'};      my $user       = $env{'user.name'};
     my $domain     = $env{'user.domain'};      my $domain     = $env{'user.domain'};
     my $newicons  = $env{'form.menumode'};      my $newicons   = $env{'form.menumode'};
   
     &Apache::lonnet::put('environment',{'icons' => $newicons});      &Apache::lonnet::put('environment',{'icons' => $newicons});
     &Apache::lonnet::appenv({'environment.icons' => $newicons});      &Apache::lonnet::appenv({'environment.icons' => $newicons});
     &print_main_menu($r, &Apache::lonhtmlcommon::confirm_success(&mt('Set menu mode to [_1].',$newicons)));      my $message=&Apache::lonhtmlcommon::confirm_success(&mt('Set [_1] to [_2]','<i>'.&mt('Menu Display').'</i>','<tt>'.$newicons.'</tt>'));
       $message=&Apache::loncommon::confirmwrapper($message);
       &print_main_menu($r, $message);
 }  }
   
 ################################################################  ################################################################
Line 661  sub verify_and_change_clicker { Line 672  sub verify_and_change_clicker {
     $newclickers=~s/\,$//;      $newclickers=~s/\,$//;
     &Apache::lonnet::put('environment',{'clickers' => $newclickers});      &Apache::lonnet::put('environment',{'clickers' => $newclickers});
     &Apache::lonnet::appenv({'environment.clickers' => $newclickers});      &Apache::lonnet::appenv({'environment.clickers' => $newclickers});
     &print_main_menu($r, &Apache::lonhtmlcommon::confirm_success(&mt('Registering clickers: [_1]',$newclickers)));      my $message=&Apache::lonhtmlcommon::confirm_success(&mt('Registering clickers: [_1]',$newclickers));
       $message=&Apache::loncommon::confirmwrapper($message);
       &print_main_menu($r, $message);
 }  }
   
 ################################################################  ################################################################
Line 681  sub domcoordchanger { Line 694  sub domcoordchanger {
         ('environment',['domcoord.author']);          ('environment',['domcoord.author']);
     my $constchecked='';      my $constchecked='';
     if ($userenv{'domcoord.author'} eq 'blocked') {      if ($userenv{'domcoord.author'} eq 'blocked') {
        $constchecked='checked="checked"';         $constchecked=' checked="checked"';
     }      }
     my $text=&mt('By default, the Domain Coordinator can enter your construction space.');      my $text=&mt('By default, the Domain Coordinator can enter your construction space.');
     my $construction=&mt('Block access to construction space');      my $construction=&mt('Block access to construction space');
Line 690  sub domcoordchanger { Line 703  sub domcoordchanger {
 <form name="prefs" action="/adm/preferences" method="post">  <form name="prefs" action="/adm/preferences" method="post">
 <input type="hidden" name="action" value="verify_and_change_domcoord" />  <input type="hidden" name="action" value="verify_and_change_domcoord" />
 $text<br />  $text<br />
 <label><input type="checkbox" name="construction" $constchecked />$construction</label><br />  <label><input type="checkbox" name="construction"$constchecked />$construction</label><br />
 <input type="submit" value="$change" />  <input type="submit" value="$change" />
 </form>  </form>
 ENDSCREEN  ENDSCREEN
Line 704  sub verify_and_change_domcoord { Line 717  sub verify_and_change_domcoord {
     if ($env{'form.construction'}) { $domcoord{'domcoord.author'}='blocked'; }      if ($env{'form.construction'}) { $domcoord{'domcoord.author'}='blocked'; }
     &Apache::lonnet::put('environment',\%domcoord);      &Apache::lonnet::put('environment',\%domcoord);
     &Apache::lonnet::appenv({'environment.domcoord.author' => $domcoord{'domcoord.author'}});      &Apache::lonnet::appenv({'environment.domcoord.author' => $domcoord{'domcoord.author'}});
     &print_main_menu($r,&Apache::lonhtmlcommon::confirm_success(&mt('Registering Domain Coordinator access restrictions.')));      my $status='';
       if ($domcoord{'domcoord.author'} eq 'blocked') {
           $status=&mt('on');
       } else {
           $status=&mt('off');
       }
       my $message=&Apache::lonhtmlcommon::confirm_success(&mt('Set [_1] to [_2]','<i>'.&mt('Block access to construction space').'</i>','<tt>'.$status.'</tt>'));
       $message=&Apache::loncommon::confirmwrapper($message);
       &print_main_menu($r,$message);
 }  }
   
 #################################################################  #################################################################
Line 974  sub verify_and_change_msgforward { Line 995  sub verify_and_change_msgforward {
     if (&Apache::lonnet::homeserver($msuser,$msdomain) ne 'no_host') {      if (&Apache::lonnet::homeserver($msuser,$msdomain) ne 'no_host') {
                $newscreen.=$msuser.':'.$msdomain.',';                 $newscreen.=$msuser.':'.$msdomain.',';
    } else {     } else {
                $message.= &mt('No such user: ').'<tt>'.$msuser.':'.$msdomain.'</tt><br>';                 $message.= &mt('No such user: ').'<tt>'.$msuser.':'.$msdomain.'</tt><br />';
            }             }
         }          }
     }      }
Line 1183  sub verify_and_change_colors { Line 1204  sub verify_and_change_colors {
                      .'<br />';                       .'<br />';
  }   }
     }      }
       $message=&Apache::loncommon::confirmwrapper($message);
   
     my $now = time;      my $now = time;
     &Apache::lonnet::put('environment',{'color.timestamp' => $now});      &Apache::lonnet::put('environment',{'color.timestamp' => $now});
Line 1316  sub jscript_send { Line 1338  sub jscript_send {
                    this.document.client.elements.uname.value;                     this.document.client.elements.uname.value;
         this.document.pserver.elements.udom.value =          this.document.pserver.elements.udom.value =
                    this.document.client.elements.udom.options[this.document.client.elements.udom.selectedIndex].value;                     this.document.client.elements.udom.options[this.document.client.elements.udom.selectedIndex].value;
           this.document.pserver.elements.email.value =
                      this.document.client.elements.email.value;
 |;  |;
     }      }
     $ output .= qq|      $ output .= qq|
Line 1334  sub client_form { Line 1358  sub client_form {
                 'currentpass' => 'Current Password',                  'currentpass' => 'Current Password',
                 'newpass' => 'New Password',                  'newpass' => 'New Password',
                 'confirmpass' => 'Confirm Password',                  'confirmpass' => 'Confirm Password',
                 'changepass' => 'Save');                  'changepass' => 'Save',
       );
   
     my $output = qq|      my $output = '<form name="client">'
 <form name="client" >                  .&Apache::lonhtmlcommon::start_pick_box();
 <table>  
 |;  
     if ($caller eq 'reset_by_email') {      if ($caller eq 'reset_by_email') {
         $output .= qq|          $output .= &Apache::lonhtmlcommon::row_title(
 <tr><td class="LC_preferences_labeltext"><label for="email">$lt{'email'}</label>:</td>                         '<label for="email">'.$lt{'email'}.'</label>')
     <td><input type="text" name="email" size="30" /> </td></tr>                    .'<input type="text" name="email" size="30" />'
 <tr><td class="LC_preferences_labeltext"><label for="uname">$lt{'username'}</label>:</td>                    .&Apache::lonhtmlcommon::row_closure()
     <td>                    .&Apache::lonhtmlcommon::row_title(
      <input type="text" name="uname" size="15" />                         '<label for="uname">'.$lt{'username'}.'</label>')
      <input type="hidden" name="currentpass" value="$currentpass" />                    .'<input type="text" name="uname" size="15" />'
     </td></tr>                    .'<input type="hidden" name="currentpass" value="'.$currentpass.'" />'
 <tr><td class="LC_preferences_labeltext"><label for="udom">$lt{'domain'}</label>:</td>                    .&Apache::lonhtmlcommon::row_closure()
     <td>                    .&Apache::lonhtmlcommon::row_title(
 |;                         '<label for="udom">'.$lt{'domain'}.'</label>')
         $output .= &Apache::loncommon::select_dom_form($defdom,'udom').'                    .&Apache::loncommon::select_dom_form($defdom,'udom')
    </td>                    .&Apache::lonhtmlcommon::row_closure();
 </tr>  
 ';  
     } else {      } else {
         $output .= qq|          $output .= &Apache::lonhtmlcommon::row_title(
 <tr><td class="LC_preferences_labeltext"><label for="currentpass">$lt{'currentpass'}</label></td>                         '<label for="currentpass">'.$lt{'currentpass'}.'</label>')
     <td><input type="password" name="currentpass" size="10"/> </td></tr>                    .'<input type="password" name="currentpass" size="10"/>'
 |;                    .&Apache::lonhtmlcommon::row_closure();
     }      }
     $output .= <<"ENDFORM";      $output .= &Apache::lonhtmlcommon::row_title(
 <tr><td class="LC_preferences_labeltext"><label for="newpass_1">$lt{'newpass'}</label></td>                     '<label for="newpass_1">'.$lt{'newpass'}.'</label>')
     <td><input type="password" name="newpass_1" size="10"  /> </td></tr>                .'<input type="password" name="newpass_1" size="10" />'
 <tr><td class="LC_preferences_labeltext"><label for="newpass_2">$lt{'confirmpass'}</label></td>                .&Apache::lonhtmlcommon::row_closure()
     <td><input type="password" name="newpass_2" size="10"  /> </td></tr>                .&Apache::lonhtmlcommon::row_title(
 <tr><td colspan="2" align="center">                     '<label for="newpass_2">'.$lt{'confirmpass'}.'</label>')
     <input type="button" value="$lt{'changepass'}" onClick="send();" />                .'<input type="password" name="newpass_2" size="10" />'
 </table>                .&Apache::lonhtmlcommon::row_closure(1)
                 .&Apache::lonhtmlcommon::end_pick_box();
       $output .= '<p><input type="button" value="'.$lt{'changepass'}.'" onClick="send();" /></p>'
                 .qq|
 <input type="hidden" name="ukey_cpass"  value="$hexkey->{'ukey_cpass'}" />  <input type="hidden" name="ukey_cpass"  value="$hexkey->{'ukey_cpass'}" />
 <input type="hidden" name="lkey_cpass"  value="$hexkey->{'lkey_cpass'}" />  <input type="hidden" name="lkey_cpass"  value="$hexkey->{'lkey_cpass'}" />
 <input type="hidden" name="ukey_npass1" value="$hexkey->{'ukey_npass1'}" />  <input type="hidden" name="ukey_npass1" value="$hexkey->{'ukey_npass1'}" />
Line 1378  sub client_form { Line 1402  sub client_form {
 <input type="hidden" name="lkey_npass2" value="$hexkey->{'lkey_npass2'}" />  <input type="hidden" name="lkey_npass2" value="$hexkey->{'lkey_npass2'}" />
 </form>  </form>
 </p>  </p>
 ENDFORM  |;
     return $output;      return $output;
 }  }
   
Line 1400  sub server_form { Line 1424  sub server_form {
 <input type="hidden" name="token"   value="$mailtoken" />  <input type="hidden" name="token"   value="$mailtoken" />
 <input type="hidden" name="uname"   value="" />  <input type="hidden" name="uname"   value="" />
 <input type="hidden" name="udom"   value="" />  <input type="hidden" name="udom"   value="" />
   <input type="hidden" name="email"   value="" />
   
 |;  |;
     }      }
Line 1544  ENDERROR Line 1569  ENDERROR
     # Inform the user the password has (not?) been changed      # Inform the user the password has (not?) been changed
     my $message;      my $message;
     if ($result =~ /^ok$/) {      if ($result =~ /^ok$/) {
         $message = &Apache::lonhtmlcommon::confirm_success(&mt('The password for [_1] was successfully changed.',$user));          $message = &Apache::lonhtmlcommon::confirm_success(&mt('The password for user [_1] was successfully changed.','<i>'.$user.'</i>'));
         if ($caller eq 'reset_by_email') {          if ($caller eq 'reset_by_email') {
             $r->print($message.'<br />');              $r->print($message.'<br />');
         } else {          } else {
Line 1552  ENDERROR Line 1577  ENDERROR
         }          }
     } else {      } else {
  # error error: run in circles, scream and shout   # error error: run in circles, scream and shout
         $message = &Apache::lonhtmlcommon::confirm_success(          if ($caller eq 'reset_by_email') {
           &mt("The password for [_1] was not changed.",$user).' '.&mt('Please make sure your old password was entered correctly.'),1);              if (!$result) {
         unless ($caller eq 'reset_by_email') {                  return 1;
               } else {
                   return $result;
               }
           } else {
               $message = &Apache::lonhtmlcommon::confirm_success(
                   &mt("The password for user [_1] was not changed.",'<i>'.$user.'</i>').' '.&mt('Please make sure your old password was entered correctly.'),1);
               $message=&Apache::loncommon::confirmwrapper($message);
             &print_main_menu($r, $message);              &print_main_menu($r, $message);
         }          }
         return 1;  
     }      }
     return;      return;
 }  }
Line 1585  sub discussionchanger { Line 1616  sub discussionchanger {
         }          }
     }      }
     if (defined($userenv{'discmarkread'})) {      if (defined($userenv{'discmarkread'})) {
         unless ($userenv{'discdisplay'} eq '') {           unless ($userenv{'discmarkread'} eq '') { 
             $discmark = $userenv{'discmarkread'};              $discmark = $userenv{'discmarkread'};
         }          }
     }      }
Line 1629  sub discussionchanger { Line 1660  sub discussionchanger {
         $currmark = $lt{'ondisp'};          $currmark = $lt{'ondisp'};
         $newmark = 'onmark';          $newmark = 'onmark';
     }      }
       
     $r->print(<<"END");      $r->print(<<"END");
 <form name="prefs" action="/adm/preferences" method="post">  <form name="prefs" action="/adm/preferences" method="post">
 <input type="hidden" name="action" value="verify_and_change_discussion" />  <input type="hidden" name="action" value="verify_and_change_discussion" />
 <br />  <br />
 $lt{'sdpf'}<br /> $lt{'prca'}  <ol><li>$lt{'whpo'}</li><li>$lt{'unwh'}</li></ol>   $lt{'sdpf'}<br /> $lt{'prca'}  <ol><li>$lt{'whpo'}</li><li>$lt{'unwh'}</li></ol> 
 <br />  
 <br />  
 END  END
   
       $r->print('<p class="LC_info">'.$lt{'thde'}.'</p>');
   
     $r->print(&Apache::loncommon::start_data_table());      $r->print(&Apache::loncommon::start_data_table());
     $r->print(<<"END");      $r->print(<<"END");
        <tr>         <tr>
Line 1663  END Line 1695  END
     $r->print(&Apache::loncommon::end_data_table_row().      $r->print(&Apache::loncommon::end_data_table_row().
       &Apache::loncommon::end_data_table());        &Apache::loncommon::end_data_table());
   
     $r->print('<br /><br /><input type="submit" name="sub" value="'.&mt('Save').'" /><br /><br />'.&mt('Note').': '.$lt{'thde'}.'</form>');      $r->print('<br />'
                .'<input type="submit" name="sub" value="'.&mt('Save').'" />'
                .'</form>'
       );
 }  }
                                                                                                                                                                                                                                   
 sub verify_and_change_discussion {  sub verify_and_change_discussion {
Line 1674  sub verify_and_change_discussion { Line 1709  sub verify_and_change_discussion {
     if (defined($env{'form.discdisp'}) ) {      if (defined($env{'form.discdisp'}) ) {
         my $newdisp  = $env{'form.newdisp'};          my $newdisp  = $env{'form.newdisp'};
         if ($newdisp eq 'unread') {          if ($newdisp eq 'unread') {
             $message .=&mt('In discussions: only new posts will be displayed.').'<br />';              $message .=&Apache::lonhtmlcommon::confirm_success(&mt('In discussions: only new posts will be displayed.')).'<br />';
             &Apache::lonnet::put('environment',{'discdisplay' => $newdisp});              &Apache::lonnet::put('environment',{'discdisplay' => $newdisp});
             &Apache::lonnet::appenv({'environment.discdisplay' => $newdisp});              &Apache::lonnet::appenv({'environment.discdisplay' => $newdisp});
         } else {          } else {
             $message .= &mt('In discussions: all posts will be displayed.').'<br />';              $message .= &Apache::lonhtmlcommon::confirm_success(&mt('In discussions: all posts will be displayed.')).'<br />';
             &Apache::lonnet::del('environment',['discdisplay']);              &Apache::lonnet::del('environment',['discdisplay']);
             &Apache::lonnet::delenv('environment.discdisplay');              &Apache::lonnet::delenv('environment.discdisplay');
         }          }
Line 1695  sub verify_and_change_discussion { Line 1730  sub verify_and_change_discussion {
             &Apache::lonnet::delenv('environment.discmarkread');              &Apache::lonnet::delenv('environment.discmarkread');
         }          }
     }      }
       $message=&Apache::loncommon::confirmwrapper($message);
     &print_main_menu($r, $message);      &print_main_menu($r, $message);
 }  }
   
Line 1913  push(@{ $menu[0]->{items} }, { Line 1949  push(@{ $menu[0]->{items} }, {
     if ($env{'environment.remote'} eq 'off') {      if ($env{'environment.remote'} eq 'off') {
 push(@{ $menu[1]->{items} }, {  push(@{ $menu[1]->{items} }, {
  linktext => 'Launch Remote Control',   linktext => 'Launch Remote Control',
  url => '/adm/remote?url=/adm/preferences?action=launch',   url => '/adm/remote?url=/adm/preferences&amp;action=launch',
  permission => 'F',   permission => 'F',
  #help => '',   #help => '',
  icon => 'network-wireless.png',   icon => 'remotecontrol.png',
  linktitle => 'Launch the remote control for LON-CAPA.',   linktitle => 'Launch the remote control for LON-CAPA.',
  });   });
     }else{      }else{
 push(@{ $menu[1]->{items} }, {  push(@{ $menu[1]->{items} }, {
  linktext => 'Collapse Remote Control',   linktext => 'Collapse Remote Control',
  url => '/adm/remote?url=/adm/preferences?action=collapse',   url => '/adm/remote?url=/adm/preferences&amp;action=collapse',
  permission => 'F',   permission => 'F',
  #help => '',   #help => '',
  icon => 'network-wireless.png',   icon => 'remotecontrol.png',
  linktitle => 'Collapse the remote control for LON-CAPA.',   linktitle => 'Collapse the remote control for LON-CAPA.',
  });   });
     }      }
Line 2059  sub handler { Line 2095  sub handler {
  &print_main_menu($r);   &print_main_menu($r);
     }      }
   
     return OK;      # Properly end the HTML page of all preference pages
       # started in each sub routine
       # Exception: print_main_menu has its own end_page call
 }      unless (!exists $env{'form.action'} ||
 #remove when done              $env{'form.action'} eq 'debugtoggle') {
 #old handler routine          $r->print(&Apache::loncommon::end_page());
 sub handler2 {  
     my $r = shift;  
     my $user = $env{'user.name'};  
     my $domain = $env{'user.domain'};  
     &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;  
     #  
     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},  
                                    ['action','wysiwyg','returnurl','refpage']);  
     #  
     &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 => 'not_on_error',  
                           }));  
     }  
     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 and Notification E-mail Addresses',  
                       href     => '/adm/preferences',  
                       help     => 'Prefs_Messages',  
                       breadcrumb =>   
                           { href => '/adm/preferences?action=changemsgforward',  
                             text => 'Change Message Forwarding/Notification'},  
                       subroutine => \&msgforwardchanger,  
                       },  
                     { action => 'verify_and_change_msgforward',  
                       help   => 'Prefs_Messages',  
                       breadcrumb =>   
                           { href => '/adm/preferences?action=changemsgforward',  
                             text => 'Change Message Forwarding/Notification'},  
                       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 Personal Information Page},  
      help => 'Prefs_About_Me',  
                      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 Preferences',  
                       href => '/adm/preferences',  
       help => 'Prefs_Language',  
                       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, }  
                     ));  
     push (@Options,({ action => 'changewysiwyg',  
                       linktext => 'Change WYSIWYG Editor Preferences',  
                       href => '/adm/preferences',  
                       breadcrumb =>   
                             { href => '/adm/preferences?action=changewysiwyg',  
                               text => 'Change WYSIWYG Preferences'},  
                       subroutine => \&wysiwygchanger,  
                   },  
                     { action => 'set_wysiwyg',  
                       breadcrumb =>  
                           { href => '/adm/preferences?action=changewysiwyg',  
                             text => 'Change WYSIWYG Preferences'},  
                       printmenu => 'yes',  
                       subroutine => \&verify_and_change_wysiwyg, }  
                     ));  
     push (@Options,({ action => 'changediscussions',  
                       linktext => 'Change Discussion Display Preferences',  
                       href => '/adm/preferences',  
                       help => 'Change_Discussion_Display',  
                       breadcrumb =>   
                             { href => '/adm/preferences?action=changediscussions',  
                               text => 'Change Discussion Preferences'},  
                       subroutine => \&discussionchanger,  
                   },  
                     { action => 'verify_and_change_discussion',  
                       breadcrumb =>  
                           { href => '/adm/preferences?action=changediscussions',  
                             text => 'Change Discussion Preferences'},  
                       printmenu => 'yes',  
                       subroutine => \&verify_and_change_discussion, }  
                     ));  
   
     my $role = ($env{'user.adv'} ? 'Roles' : 'Course');  
     push (@Options,({ action   => 'changerolespref',  
                       linktext => 'Change '.$role.' Page Preferences',  
                       href     => '/adm/preferences',  
                       subroutine => \&rolesprefchanger,  
                       breadcrumb =>  
                           { href => '/adm/preferences?action=changerolespref',  
                             text => 'Change '.$role.' Page Pref'},  
                       },  
                     { action   => 'verify_and_change_rolespref',  
                       subroutine => \&verify_and_change_rolespref,  
                       breadcrumb =>  
                           { href => '/adm/preferences?action=changerolespref',  
                             text => 'Change '.$role.' Page Preferences'},  
                       printmenu => 'yes',  
                       }));  
   
     push (@Options,({ action   => 'changetexenginepref',  
                       linktext => 'Change How Math Equations Are Displayed',  
                       href     => '/adm/preferences',  
                       subroutine => \&texenginechanger,  
                       breadcrumb =>  
                           { href => '/adm/preferences?action=changetexenginepref',  
                             text => 'Change Math Pref'},  
                       },  
                     { action   => 'verify_and_change_texengine',  
                       subroutine => \&verify_and_change_texengine,  
                       breadcrumb =>  
                           { href => '/adm/preferences?action=changetexenginepref',  
                             text => 'Change Math Preferences'},  
                       printmenu => 'yes',  
                       }));  
   
     if ($env{'environment.remote'} eq 'off') {  
  push (@Options,({ action => 'launch',  
   linktext => 'Launch Remote Control',  
   href => '/adm/remote?url=/adm/preferences',  
       }));  
     } else {  
  push (@Options,({ action => 'collapse',  
   linktext => 'Collapse Remote Control',  
   href => '/adm/remote?url=/adm/preferences',  
       }));  
     }  
   
     push (@Options,({ action   => 'changeicons',  
                       linktext => 'Change How Menus are Displayed',  
                       href     => '/adm/preferences',  
                       subroutine => \&iconchanger,  
                       breadcrumb =>  
                           { href => '/adm/preferences?action=changeicons',  
                             text => 'Change Main Menu'},  
                       },  
                     { action   => 'verify_and_change_icons',  
                       subroutine => \&verify_and_change_icons,  
                       breadcrumb =>  
                           { href => '/adm/preferences?action=changeicons',  
                             text => 'Change Main Menu'},  
                       printmenu => 'yes',  
                       }));  
   
     push (@Options,({ action   => 'changeclicker',  
                       linktext => 'Register Response Devices ("Clickers")',  
                       href     => '/adm/preferences',  
                       subroutine => \&clickerchanger,  
                       breadcrumb =>  
                           { href => '/adm/preferences?action=changeclicker',  
                             text => 'Register Clicker'},  
                       },  
                     { action   => 'verify_and_change_clicker',  
                       subroutine => \&verify_and_change_clicker,  
                       breadcrumb =>  
                           { href => '/adm/preferences?action=changeclicker',  
                             text => 'Register Clicker'},  
                       printmenu => 'yes',  
                       }));  
     my %author_roles = &Apache::lonnet::get_my_roles($user,$domain,'userroles','',['au']);  
     if (keys(%author_roles) > 0) {  
       push (@Options,({ action   => 'changedomcoord',  
                         linktext => 'Restrict Domain Coordinator Access',  
                         href     => '/adm/preferences',  
                         subroutine => \&domcoordchanger,  
                         breadcrumb =>  
                             { href => '/adm/preferences?action=changedomcoord',  
                               text => 'Restrict Domain Coordinator Access'},  
                       },  
                       { action   => 'verify_and_change_domcoord',  
                         subroutine => \&verify_and_change_domcoord,  
                         breadcrumb =>  
                             { href => '/adm/preferences?action=changedomcoord',  
                               text => 'Restrict Domain Coordinator Access'},  
                         printmenu => 'yes',  
                       }));  
     }  
   
     push (@Options,({ action   => 'lockwarning',  
                       subroutine => \&lockwarning,  
                       breadcrumb =>  
                           { href => '/adm/preferences?action=lockwarning',  
                             text => 'Lock Warnings'},  
                       },  
                     { action   => 'verify_and_change_locks',  
                       subroutine => \&verify_and_change_lockwarning,  
                       breadcrumb =>  
                           { href => '/adm/preferences?action=lockwarning',  
                             text => 'Lockwarnings'},  
                       printmenu => 'yes',  
                       }));  
   
   
     if (&Apache::lonnet::allowed('whn',$env{'request.course.id'})  
  || &Apache::lonnet::allowed('whn',$env{'request.course.id'}.'/'  
     .$env{'request.course.sec'})) {  
         push (@Options,({ action => 'changecourseinit',  
                           linktext => 'Change Course Initialization Preference',  
                           href => '/adm/preferences',  
                           subroutine => \&coursedisplaychanger,  
                           breadcrumb =>  
                               { href => '/adm/preferences?action=changecourseinit',  
                                 text => 'Change Course Init. Pref.'},  
                           },  
                         { action => 'verify_and_change_coursepage',  
                           breadcrumb =>  
                           { href => '/adm/preferences?action=changecourseinit',                               text => 'Change Course Initialization Preference'},  
                         printmenu => 'yes',  
                         subroutine => \&verify_and_change_coursepage,  
                        }));  
     }  
   
     if (($env{'user.name'} =~ /^(albertel|fox|foxr|kortemey|korte|raeburn)$/)  
      && ($env{'user.domain'} =~/^(msu|gerd)$/)){  
         push (@Options,({ action => 'debugtoggle',  
                           printmenu => 'yes',  
                           subroutine => \&toggle_debug,  
                           }));  
     }  
   
     $r->print(&Apache::loncommon::start_page('Change Preferences'));  
   
     my $call = undef;  
     my $help = undef;  
     my $printmenu = 'yes';  
     foreach my $option (@Options) {  
         if ($option->{'action'} eq $env{'form.action'}) {  
             $call = $option->{'subroutine'};  
             $printmenu = $option->{'printmenu'};  
             if (exists($option->{'breadcrumb'})) {  
                 &Apache::lonhtmlcommon::add_breadcrumb  
                     ($option->{'breadcrumb'});  
             }  
     $help=$option->{'help'};  
         }  
     }  
     $r->print(&Apache::lonhtmlcommon::breadcrumbs('Change Preferences',$help));  
     my $error;  
     if (defined($call)) {  
         $error = $call->($r);  
     }  
     if ( ( ($printmenu eq 'yes')  
    || ($printmenu eq 'not_on_error' && !$error) )  
  && (!$env{'form.returnurl'})) {  
         my $optionlist = '<table cellpadding="5">';  
         if ($env{'user.name'} =~   
                          /^(albertel|kortemey|fox|foxr|korte|hallmat3|turtle|raeburn)$/  
             ) {  
             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'})) {  
  $option->{'href_args'}{'action'}=$option->{'action'};  
  $optiontext .=   
                     '<a href="'.&add_get_param($option->{'href'},  
        $option->{'href_args'}).'">'.  
                     &mt($option->{'linktext'}).'</a>';  
             }  
             if (exists($option->{'text'})) {  
                 $optiontext .= ' '.&mt($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);  
     } elsif ($env{'form.returnurl'}) {  
  $r->print('<br /><a href="'.$env{'form.returnurl'}.'"><font size="+1">'.  
   &mt('Return').'</font></a>');  
     }      }
     $r->print(&Apache::loncommon::end_page());  
     return OK;      return OK;
 }  }
   

Removed from v.1.157  
changed lines
  Added in v.1.173


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>