4 * printer_friendly_bottom.php
6 * with javascript on, it is the bottom frame of printer_friendly_main.php
7 * else, it is alone in a new window
9 * - this is the page that does all the work, really.
11 * @copyright © 1999-2006 The SquirrelMail Project Team
12 * @license http://opensource.org/licenses/gpl-license.php GNU Public License
14 * @package squirrelmail
18 * Include the SquirrelMail initialization file.
20 require('../include/init.php');
22 /* SquirrelMail required files. */
23 require_once(SM_PATH
. 'functions/imap_general.php');
24 require_once(SM_PATH
. 'functions/imap_messages.php');
25 require_once(SM_PATH
. 'functions/date.php');
26 require_once(SM_PATH
. 'functions/mime.php');
27 require_once(SM_PATH
. 'functions/url_parser.php');
29 /* get some of these globals */
30 sqgetGlobalVar('passed_id', $passed_id, SQ_GET
);
31 sqgetGlobalVar('mailbox', $mailbox, SQ_GET
);
33 if (! sqgetGlobalVar('passed_ent_id', $passed_ent_id, SQ_GET
) ) {
36 sqgetGlobalVar('show_html_default', $show_html_default, SQ_FORM
);
39 $imapConnection = sqimap_login($username, false, $imapServerAddress, $imapPort, 0);
40 $mbx_response = sqimap_mailbox_select($imapConnection, $mailbox);
41 if (isset($messages[$mbx_response['UIDVALIDITY']][$passed_id])) {
42 $message = $messages[$mbx_response['UIDVALIDITY']][$passed_id];
44 $message = sqimap_get_message($imapConnection, $passed_id, $mailbox);
47 $message = $message->getEntity($passed_ent_id);
50 /* --start display setup-- */
52 $rfc822_header = $message->rfc822_header
;
53 /* From and Date are usually fine as they are... */
54 $from = $rfc822_header->getAddr_s('from');
55 $date = getLongDateString($rfc822_header->date
);
56 $subject = trim($rfc822_header->subject
);
58 /* we can clean these up if the list is too long... */
59 $cc = $rfc822_header->getAddr_s('cc');
60 $to = $rfc822_header->getAddr_s('to');
62 if ($show_html_default == 1) {
63 $ent_ar = $message->findDisplayEntity(array());
65 $ent_ar = $message->findDisplayEntity(array(), array('text/plain'));
68 if ($ent_ar[0] != '') {
69 for ($i = 0; $i < count($ent_ar); $i++
) {
70 $body .= formatBody($imapConnection, $message, $color, $wrap_at, $ent_ar[$i], $passed_id, $mailbox, TRUE);
71 $body .= '<hr style="height: 1px;" />';
73 $hookResults = do_hook('message_body', $body);
74 $body = $hookResults[1];
76 $body = _("Message not printable");
79 /* now we clean up the display a bit... */
81 $num_leading_spaces = 9; // nine leading spaces for indentation
83 // sometimes I see ',,' instead of ',' separating addresses *shrug*
84 $cc = pf_clean_string(str_replace(',,', ',', $cc), $num_leading_spaces);
85 $to = pf_clean_string(str_replace(',,', ',', $to), $num_leading_spaces);
87 // clean up everything else...
88 $subject = pf_clean_string($subject, $num_leading_spaces);
89 $from = pf_clean_string($from, $num_leading_spaces);
90 $date = pf_clean_string($date, $num_leading_spaces);
94 $to = decodeHeader($to);
95 $cc = decodeHeader($cc);
96 $from = decodeHeader($from);
97 $subject = decodeHeader($subject);
99 $attachments = pf_show_attachments($message,$ent_ar,$mailbox,$passed_id);
101 // --end display setup--
104 /* --start browser output-- */
105 displayHtmlHeader( $subject, '', FALSE );
107 echo '<body text="#000000" bgcolor="#FFFFFF" link="#000000" vlink="#000000" alink="#000000">'."\n" .
108 /* headers (we use table because translations are not all the same width) */
109 html_tag( 'table', '', 'center', '', 'cellspacing="0" cellpadding="0" border="0" width="100%"' ) .
111 html_tag( 'td', '<b>'._("From").':</b> ', 'left' ,'','valign="top"') .
112 html_tag( 'td', $from, 'left' )
115 html_tag( 'td', '<b>'._("Subject").':</b> ', 'left','','valign="top"' ) .
116 html_tag( 'td', $subject, 'left' )
119 html_tag( 'td', '<b>'._("Date").':</b> ', 'left' ) .
120 html_tag( 'td', htmlspecialchars($date), 'left' )
123 html_tag( 'td', '<b>'._("To").':</b> ', 'left','','valign="top"' ) .
124 html_tag( 'td', $to, 'left' )
126 if ( strlen($cc) > 0 ) { /* only show Cc: if it's there... */
128 html_tag( 'td', '<b>'._("Cc").':</b> ', 'left','','valign="top"' ) .
129 html_tag( 'td', $cc, 'left' )
134 html_tag( 'td', '<hr style="height: 1px;" /><br />' . "\n" . $body, 'left', '', 'colspan="2"' )
137 if (! empty($attachments)) {
140 html_tag( 'td','<b>'._("Attachments:").'</b>', 'left', '', 'colspan="2"' )
142 // list of attachments
144 html_tag( 'td',$attachments, 'left', '', 'colspan="2"' )
146 // add separator line
148 html_tag( 'td', '<hr style="height: 1px;" />', 'left', '', 'colspan="2"' )
152 echo '</table>' . "\n";
153 $oTemplate->display('footer.tpl');
155 /* --end browser output-- */
158 /* --start pf-specific functions-- */
161 * Function should clean layout of printed messages when user
162 * enables "Printer Friendly Clean Display" option.
163 * For example: $string = pf_clean_string($string, 9);
165 * @param string unclean_string
166 * @param integer num_leading_spaces
170 function pf_clean_string ( $unclean_string, $num_leading_spaces ) {
171 global $data_dir, $username;
172 $unclean_string = str_replace(' ',' ',$unclean_string);
173 $wrap_at = getPref($data_dir, $username, 'wrap_at', 86);
174 $wrap_at = $wrap_at - $num_leading_spaces; /* header stuff */
176 $leading_spaces = '';
177 while ( strlen($leading_spaces) < $num_leading_spaces )
178 $leading_spaces .= ' ';
181 while ( strlen($unclean_string) > $wrap_at )
183 $this_line = substr($unclean_string, 0, $wrap_at);
184 if ( strrpos( $this_line, "\n" ) ) /* this should NEVER happen with anything but the $body */
186 $clean_string .= substr( $this_line, 0, strrpos( $this_line, "\n" ));
187 $clean_string .= $leading_spaces;
188 $unclean_string = substr($unclean_string, strrpos( $this_line, "\n" ));
192 $i = strrpos( $this_line, ' ');
193 $clean_string .= substr( $this_line, 0, $i);
194 $clean_string .= "\n" . $leading_spaces;
195 $unclean_string = substr($unclean_string, 1+
$i);
198 $clean_string .= $unclean_string;
200 return $clean_string;
201 } /* end pf_clean_string() function */
204 * Displays attachment information
206 * Stripped version of formatAttachments() function from functions/mime.php.
207 * @param object $message SquirrelMail message object
208 * @param array $exclude_id message parts that are not attachments.
209 * @param string $mailbox mailbox name
210 * @param integer $id message id
211 * @return string html formated attachment information.
213 function pf_show_attachments($message, $exclude_id, $mailbox, $id) {
214 global $where, $what, $startMessage, $color, $passed_ent_id;
216 $att_ar = $message->getAttachments($exclude_id);
218 if (!count($att_ar)) return '';
222 $urlMailbox = urlencode($mailbox);
224 foreach ($att_ar as $att) {
225 $ent = $att->entity_id
;
226 $header = $att->header
;
227 $type0 = strtolower($header->type0
);
228 $type1 = strtolower($header->type1
);
231 if ($type0 =='message' && $type1 == 'rfc822') {
232 $rfc822_header = $att->rfc822_header
;
233 $filename = $rfc822_header->subject
;
234 if (trim( $filename ) == '') {
235 $filename = 'untitled-[' . $ent . ']' ;
237 $from_o = $rfc822_header->from
;
238 if (is_object($from_o)) {
239 $from_name = decodeHeader($from_o->getAddress(true));
241 $from_name = _("Unknown sender");
243 $description = '<tr>'.
244 html_tag( 'td',_("From:"), 'right') .
245 html_tag( 'td',$from_name, 'left') .
248 $filename = $att->getFilename();
249 if ($header->description
) {
250 $description = '<tr>'.
251 html_tag( 'td',_("Info:"), 'right') .
252 html_tag( 'td',decodeHeader($header->description
), 'left') .
259 $display_filename = $filename;
261 // TODO: maybe make it nicer?
262 $attachments .= '<table cellpadding="1" cellspacing="0" width="100%" border="1"><tr><th colspan="2">'.decodeHeader($display_filename).'</th></tr>' .
264 html_tag( 'td',_("Size:"), 'right', '', 'width="25%"') .
265 html_tag( 'td',show_readable_size($header->size
), 'left', '', 'width="75%"') .
267 html_tag( 'td',_("Type:"), 'right', '', 'width="25%"') .
268 html_tag( 'td',htmlspecialchars($type0).'/'.htmlspecialchars($type1), 'left', '', 'width="75%"') .
270 if (! empty($description)) {
271 $attachments .= $description;
273 $attachments .= "</table>\n";
279 /* --end pf-specific functions */