--- loncom/interface/lontemplate.pm 2008/11/20 10:27:56 1.2 +++ loncom/interface/lontemplate.pm 2009/04/15 10:49:30 1.31 @@ -1,7 +1,7 @@ # The LearningOnline Network # "Template" Functions to generate html output # -# lontemplate.pm +# $Id: lontemplate.pm,v 1.31 2009/04/15 10:49:30 bisitz Exp $ # # Copyright Michigan State University Board of Trustees # @@ -34,6 +34,8 @@ use strict; use Apache::Constants qw(:common); use Apache::loncommon; use Apache::lonnet; +use Apache::lonxml; +use Apache::lonspeller; use Apache::lontexconvert; use Apache::lonfeedback; use Apache::lonrss(); @@ -42,23 +44,125 @@ use Apache::lonmsgdisplay(); use HTML::Entities(); -sub print_template -{ - my ($r,$topic,$content) = @_; - $r->print('
'); - $r->print('

'.$topic.'

'); - $r->print('
'.$content.'
'); +sub start_columnSection{ + my ($r) = @_; + $r->print('
'); +} + +sub end_columnSection{ + my ($r) = @_; + $r->print('
'); +} + +sub print_aboutme_content_template{ + my ($r,$allowed,$target,$syllabusfields_ref,$syllabus_ref) = @_; + my %syllabusfields = %{$syllabusfields_ref}; + my %syllabus = %{$syllabus_ref}; + + foreach my $field (sort(keys(%syllabusfields))) { + if (($syllabus{$field}) || ($allowed)) { + my $message=$syllabus{$field}; + &Apache::lonfeedback::newline_to_br(\$message); + $message + =~s/(http\:\/\/[^\s]+)/\\$1\<\/tt\>\<\/a\>/g; + if ($allowed) { + $message=&Apache::lonspeller::markeduptext($message); + } + $message=&Apache::lontexconvert::msgtexconverted($message); + if ($target ne 'tex') { + if($allowed){ + $r->print('

'); + } + + if($field eq 'aaa_contactinfo') { + $r->print('

 
'); + &print_template($r,$syllabusfields{$field},$message,$allowed,'LC_ContentBoxSpecial'); + } + else{ + &print_template($r,$syllabusfields{$field},$message,$allowed,'LC_ContentBoxSpecial'); + } + + } else { + $r->print('\\\\\textbf{'.$syllabusfields{$field}.'}\\\\'. + &Apache::lonxml::xmlparse($r,'tex',$message).'\\\\'); + } + if ($allowed) { + &print_editbox_template($r,$syllabus{$field},$field); + if($target ne 'tex'){ + $r->print('

'); + } + } + } + } + +} + +sub start_ContentBox{ + my ($r,$allowed) = @_; + $r->print('
'); + +} + +sub end_ContentBox{ + my ($r) = @_; $r->print('
'); } +sub send_message{ + my ($r,$cnum,$cdom) = @_; + my $s; + my $image = qq{}; + $s=&Apache::loncommon::messagewrapper($image,$cnum,$cdom).' '.&Apache::loncommon::messagewrapper(&mt('Send me a message'),$cnum,$cdom); + return $s; +} + +sub print_template +{ + my ($r,$topic,$content, $allowed,$boxclass) = @_; + $r->print('
'); + $r->print('

'.$topic.'

'); + $r->print('
' .$content . '
'); + $r->print('
'); +} +sub print_start_template +{ + my ($r,$topic,$boxclass) = @_; + $r->print('
'); + $r->print('

'.$topic.'

'); + $r->print('
' ); +} +sub print_end_template +{ + my ($r) = @_; + $r->print('
'); + $r->print('
'); +} sub print_editbox_template { my ($r,$content,$field) = @_; - $r->print('
'); + '
'); +} + +# Functionslist: List of functions +# Typically used to display a list of available functions at top of page +sub start_functionslist { + my($legendtext)=@_; + $legendtext=&mt('Functions') if !$legendtext; + return '
'.$legendtext.'' + .'
    '; +} + +sub item_functionslist { + my($content) = @_; + return '
  • '.$content.'
  • '; +} +sub end_functionslist { + my($r)=@_; + return '
'; } 1;