diff options
author | alecpl <alec@alec.pl> | 2010-07-30 16:58:27 +0000 |
---|---|---|
committer | alecpl <alec@alec.pl> | 2010-07-30 16:58:27 +0000 |
commit | 7b808b585bc80f25bc9565cc5737bfb1293a1d7c (patch) | |
tree | b4d9fe5253d33f3b79772d0ee101a19b7d587f6c /program/steps/mail/func.inc | |
parent | 851b2a98111ee3b3f2b7d28b3e0e9c325d2504b0 (diff) |
- Fix bgcolor attribute of message body handling
Diffstat (limited to 'program/steps/mail/func.inc')
-rw-r--r-- | program/steps/mail/func.inc | 28 |
1 files changed, 21 insertions, 7 deletions
diff --git a/program/steps/mail/func.inc b/program/steps/mail/func.inc index c96f442c7..55ca8eb46 100644 --- a/program/steps/mail/func.inc +++ b/program/steps/mail/func.inc @@ -986,8 +986,14 @@ function rcmail_message_body($attrib) $body = rcmail_print_body($part, array('safe' => $safe_mode, 'plain' => !$CONFIG['prefer_html'])); - if ($part->ctype_secondary == 'html') - $out .= html::div('message-htmlpart', rcmail_html4inline($body, $attrib['id'], 'div.rcmBody')); + if ($part->ctype_secondary == 'html') { + $body = rcmail_html4inline($body, $attrib['id'], 'rcmBody', $color); + $div_attr = array('class' => 'message-htmlpart'); + if ($color) + $div_attr['style'] = 'background-color: '.$color; + + $out .= html::div($div_attr, $body); + } else $out .= html::div('message-part', $body); } @@ -1046,7 +1052,7 @@ function rcmail_resolve_base($body) /** * modify a HTML message that it can be displayed inside a HTML page */ -function rcmail_html4inline($body, $container_id, $body_id='') +function rcmail_html4inline($body, $container_id, $body_id='', &$body_color='') { $last_style_pos = 0; $body_lc = strtolower($body); @@ -1057,7 +1063,8 @@ function rcmail_html4inline($body, $container_id, $body_id='') $pos = strpos($body_lc, '>', $pos)+1; // replace all css definitions with #container [def] - $styles = rcmail_mod_css_styles(substr($body, $pos, $pos2-$pos), $container_id.($body_id ? ' '.$body_id : '')); + $styles = rcmail_mod_css_styles(substr($body, $pos, $pos2-$pos), + $container_id.($body_id ? ' div.'.$body_id : '')); $body = substr($body, 0, $pos) . $styles . substr($body, $pos2); $body_lc = strtolower($body); @@ -1093,15 +1100,22 @@ function rcmail_html4inline($body, $container_id, $body_id='') '<!--\\1-->', '<?', '?>', - '<div class="rcmBody"\\1>', + '<div class="'.$body_id.'"\\1>', '</div>', ), $body); + // Get rcmBody's bgcolor attribute, we'll set the color to the body container + // as background-color, bgcolor doesn't work with a div + if (preg_match('/<div class="' . preg_quote($body_id, '/') . '" ([^>]+)>/', $out, $m)) { + if (preg_match('/bgcolor=["\']*([a-z0-9#]+)["\']*/', $m[0], $mb)) { + $body_color = $mb[1]; + } + } // make sure there's 'rcmBody' div, we need it for proper css modification // its name is hardcoded in rcmail_message_body() also - if (!preg_match('/<div class="rcmBody"/', $out)) - $out = '<div class="rcmBody">' . $out . '</div>'; + else + $out = '<div class="' . $body_id . '">' . $out . '</div>'; return $out; } |