');
+ my ($r,$topic,$boxclass,$id,$display) = @_;
+ my $idattrib;
+ if ($id ne '') {
+ $idattrib = ' id="'.$id.'"';
+ }
+ $r->print('
');
$r->print('
'.$topic.'
');
}
@@ -127,9 +131,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 {
@@ -145,44 +149,59 @@ 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));
- if ((%custom_handlers) && ($custom_handlers{$field})) {
- $custom_handlers{$field}->($r, $field, $message, $group, $data_ref, $fields_ref, $target, $allowed);
+ my $display = $displays{$field};
+ unless ($allowed) {
+ next if ($noshow{$field});
+ }
+ if ((%custom_handlers) && ($custom_handlers{$field})) {
+ $custom_handlers{$field}->($r, $field, $message, $group, $data_ref, $fields_ref, $target, $allowed, $display);
} else {
if (($data{$field}=~/\w/) || ($allowed)) {
- if (!&Apache::lonfeedback::contains_block_html($message)) {
- &Apache::lonfeedback::newline_to_br(\$message);
- } else {
- $message = &Apache::lonfeedback::tidy_html($message);
- }
- $message=&Apache::lonhtmlcommon::raw_href_to_link($message);
- if ($allowed) {
- $message=&Apache::lonspeller::markeduptext($message);
- }
- $message=&Apache::lontexconvert::msgtexconverted($message);
+ if (!&Apache::lonfeedback::contains_block_html($message)) {
+ &Apache::lonfeedback::newline_to_br(\$message);
+ } else {
+ $message = &Apache::lonfeedback::tidy_html($message);
+ }
+ $message=&Apache::lonhtmlcommon::raw_href_to_link($message);
+ if ($allowed) {
+ $message=&Apache::lonspeller::markeduptext($message);
+ }
+ $message=&Apache::lontexconvert::msgtexconverted($message);
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);
}