');
+ 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,31 +150,43 @@ 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);