--- loncom/interface/lontemplate.pm 2010/04/27 02:44:57 1.44 +++ loncom/interface/lontemplate.pm 2013/05/09 05:47:57 1.48 @@ -1,7 +1,7 @@ # The LearningOnline Network # "Template" Functions to generate html output # -# $Id: lontemplate.pm,v 1.44 2010/04/27 02:44:57 faziophi Exp $ +# $Id: lontemplate.pm,v 1.48 2013/05/09 05:47:57 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -115,8 +115,12 @@ sub print_template { } sub print_start_template { - my ($r,$topic,$boxclass) = @_; - $r->print('
'); + my ($r,$topic,$boxclass,$id,$display) = @_; + my $idattrib; + if ($id ne '') { + $idattrib = ' id="'.$id.'"'; + } + $r->print('
'); $r->print('

'.$topic.'

'); } @@ -128,9 +132,9 @@ sub print_end_template { sub print_editbox_template { my ($r,$content,$field) = @_; $r->print('
'); + &HTML::Entities::encode($content,'"&<>'). + '
'."\n"); + &print_saveall_template($r); } sub print_textarea_template { @@ -146,38 +150,54 @@ sub print_saveall_template { } sub print_template_fields { - my ($r, $data_ref, $fields_ref, $target, $allowed, $default_rich_text, $custom_handlers_ref, $group) = @_; + my ($r, $data_ref, $fields_ref, $target, $allowed, $default_rich_text, $custom_handlers_ref, $group, + $displayref,$noshowref) = @_; my @html_ids = (); my %data = %{$data_ref}; my %fields = %{$fields_ref}; my %custom_handlers = %{$custom_handlers_ref}; - + my (%displays,%noshow); + if (ref($displayref) eq 'HASH') { + %displays = %{$displayref}; + } + if (ref($noshowref) eq 'HASH') { + %noshow = %{$noshowref}; + } foreach my $field (sort(keys(%fields))) { my $message = $data{$field} if (($data{$field}=~/\w/) || ($allowed)); my $legacy = 1; + my $display = $displays{$field}; + my $hidden; + unless ($allowed) { + next if ($noshow{$field}); + } 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); + $custom_handlers{$field}->($r, $field, $message, $group, $data_ref, $fields_ref, $target, $allowed, $display); } 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'); + &Apache::lontemplate::print_start_template($r,$fields{$field},'LC_Box','box_'.$field,$display); $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); + &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)); + if ($fields{$field}=~/\w/) { + $r->print(&Apache::lonxml::xmlparse($r,'tex','

'.$fields{$field}.'

')); + } else { + $r->print(&Apache::lonxml::xmlparse($r,'tex','
')); + } + $r->print(&Apache::lonxml::xmlparse($r,'tex',$message)); } push(@html_ids,$field); }