--- loncom/interface/lontemplate.pm 2009/12/22 06:22:12 1.42 +++ loncom/interface/lontemplate.pm 2010/04/27 02:44:57 1.44 @@ -1,7 +1,7 @@ # The LearningOnline Network # "Template" Functions to generate html output # -# $Id: lontemplate.pm,v 1.42 2009/12/22 06:22:12 faziophi Exp $ +# $Id: lontemplate.pm,v 1.44 2010/04/27 02:44:57 faziophi Exp $ # # Copyright Michigan State University Board of Trustees # @@ -26,11 +26,11 @@ # http://www.lon-capa.org/ # - package Apache::lontemplate; use strict; +use utf8; use Apache::Constants qw(:common); use Apache::loncommon; use Apache::lonnet; @@ -40,6 +40,7 @@ use Apache::lontexconvert; use Apache::lonfeedback; use Apache::lonrss(); use Apache::lonlocal; +use Apache::lonhtmlgateway; use Apache::lonmsgdisplay(); use HTML::Entities(); @@ -144,4 +145,47 @@ sub print_saveall_template { $r->print(''); } +sub print_template_fields { + my ($r, $data_ref, $fields_ref, $target, $allowed, $default_rich_text, $custom_handlers_ref, $group) = @_; + my @html_ids = (); + my %data = %{$data_ref}; + my %fields = %{$fields_ref}; + my %custom_handlers = %{$custom_handlers_ref}; + + foreach my $field (sort(keys(%fields))) { + my $message = $data{$field} if (($data{$field}=~/\w/) || ($allowed)); + my $legacy = 1; + my $gateway = Apache::lonhtmlgateway->new($target); + $message = &Encode::decode('utf8', $message); + $message = $gateway->process_outgoing_html($message, $legacy); + if ((%custom_handlers) && ($custom_handlers{$field})) { + $custom_handlers{$field}->($r, $field, $message, $group, $data_ref, $fields_ref, $target, $allowed); + } else { + if (($data{$field}=~/\w/) || ($allowed)) { + if ($target ne 'tex') { + #output of syllabusfields will be generated here. + &Apache::lontemplate::print_start_template($r,$fields{$field},'LC_Box'); + $r->print($message); + if ($allowed) { + $r->print("
"); + &Apache::lontemplate::print_textarea_template($r, $data{$field}, + $field, $default_rich_text); + &Apache::lontemplate::print_saveall_template($r); + $r->print("
"); + } + &Apache::lontemplate::print_end_template($r); + } else { + my $safeinit; + $r->print(&Apache::lonxml::xmlparse($r,'tex','

'.$fields{$field}.'

')); + $r->print(&Apache::lonxml::xmlparse($r,'tex',$message)); + } + push(@html_ids,$field); + } + } + undef $gateway; + } + + return @html_ids; +} + 1;