--- loncom/interface/lonpreferences.pm 2005/02/17 08:29:43 1.53 +++ loncom/interface/lonpreferences.pm 2005/03/22 17:15:22 1.58 @@ -1,7 +1,7 @@ # The LearningOnline Network # Preferences # -# $Id: lonpreferences.pm,v 1.53 2005/02/17 08:29:43 albertel Exp $ +# $Id: lonpreferences.pm,v 1.58 2005/03/22 17:15:22 matthew Exp $ # # Copyright Michigan State University Board of Trustees # @@ -172,7 +172,101 @@ sub verify_and_change_languages { $message='Reset preferred language'; } $r->print(< +$message +ENDVCSCREEN +} + +################################################################ +# Tex Engine Change Subroutines # +################################################################ +sub texenginechanger { + my $r = shift; + my $user = $ENV{'user.name'}; + my $domain = $ENV{'user.domain'}; + my %userenv = &Apache::lonnet::get('environment',['texengine']); + my $texengine=$userenv{'texengine'}; + + my $pref=&mt('Preferred method to display Math'); + my %mathchoices=('' => 'No Preference', + 'tth' => 'TeX to HTML', + 'ttm' => 'TeX to MathML', + 'jsMath' => 'jsMath', + 'mimetex' => 'Convert to Images' + ); + my $selectionbox=&Apache::loncommon::select_form($texengine,'texengine', + %mathchoices); + my $mathexample='$$\int\left(\frac{a+b}{c^6*d}\right)$$'; + my $jsMath_example=&Apache::lontexconvert::jsMath_converted(\$mathexample); + $mathexample='$$\int\left(\frac{a+b}{c^6*d}\right)$$'; + my $tth_example=&Apache::lontexconvert::tth_converted(\$mathexample); + $mathexample='$$\int\left(\frac{a+b}{c^6*d}\right)$$'; + my $mimetex_example=&Apache::lontexconvert::mimetex_converted(\$mathexample); + my $change=&mt('Change'); + $r->print(< + +

$pref: $selectionbox

+

+ +Examples: +

TeX to HTML
$tth_example

+ + +

jsMath
+ + + +$jsMath_example

+

Convert to Images
$mimetex_example

+ENDLSCREEN + if ($ENV{'environment.texengine'} ne 'jsMath') { + $r->print(''); + } +} + + +sub verify_and_change_texengine { + my $r = shift; + my $user = $ENV{'user.name'}; + my $domain = $ENV{'user.domain'}; +# Screenname + my $newtexengine = $ENV{'form.texengine'}; + $newtexengine=~s/[^\-\w]//g; + if ($newtexengine eq 'ttm') { + &Apache::lonnet::appenv('browser.mathml' => 1); + } else { + if ($ENV{'environment.texengine'} eq 'ttm') { + &Apache::lonnet::appenv('browser.mathml' => 0); + } + } + my $message=''; + if ($newtexengine) { + &Apache::lonnet::put('environment',{'texengine' => $newtexengine}); + &Apache::lonnet::appenv('environment.texengine' => $newtexengine); + $message='Set new preferred math display to '.$newtexengine; + } else { + &Apache::lonnet::del('environment',['texengine']); + &Apache::lonnet::delenv('environment\.texengine'); + $message='Reset preferred math display.'; + } + + + $r->print(<print(< $message ENDRPSCREEN } @@ -310,7 +403,6 @@ sub verify_and_change_screenname { } $r->print(< $message ENDVCSCREEN } @@ -400,7 +492,6 @@ sub verify_and_change_msgforward { $message.='Reset critical message notification
'; } $r->print(< $message ENDVCMSG } @@ -523,7 +614,6 @@ sub verify_and_change_colors { } } $r->print(< $message
@@ -878,7 +968,6 @@ sub verify_and_change_discussion { } } $r->print(< $message ENDVCSCREEN } @@ -1048,6 +1137,22 @@ sub handler { 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{'user.name'} =~ /^(albertel|fox|foxr|koretemey|korte|hallmat3|turtle)$/) { push (@Options,({ action => 'debugtoggle', @@ -1126,10 +1231,7 @@ ENDHEADER $r->print('
'. &mt('Return').''); } - $r->print(< - -ENDFOOTER + $r->print(&Apache::loncommon::endbodytag().''); return OK; }