better default for printer_friendly option
[squirrelmail.git] / src / compose.php
CommitLineData
59177427 1<?php
9487c2ff 2 /**
f7b1b3b1 3 * compose.php
4 *
5 * Copyright (c) 1999-2000 The SquirrelMail development team
6 * Licensed under the GNU GPL. For full terms see the file COPYING.
7 *
8 * This code sends a mail.
9 *
10 * There are 4 modes of operation:
11 * - Start new mail
12 * - Add an attachment
13 * - Send mail
14 * - Save As Draft
15 *
16 * $Id$
df15de21 17 **/
f7fb20fe 18
ff8a98e7 19 require_once('../src/validate.php');
20 require_once('../functions/imap.php');
21 require_once('../functions/date.php');
22 require_once('../functions/mime.php');
23 require_once('../functions/smtp.php');
24 require_once('../functions/display_messages.php');
25 require_once('../functions/plugin.php');
8467bf00 26
79be8a0b 27 if (!isset($attachments))
f972eb46 28 {
79be8a0b 29 $attachments = array();
f972eb46 30 session_register('attachments');
31 }
a98bed68 32
d7981cd8 33
4ba45d11 34 // This function is used when not sending or adding attachments
df15de21 35 function newMail () {
36 global $forward_id, $imapConnection, $msg, $ent_num, $body_ary, $body,
0a17f9dd 37 $reply_id, $send_to, $send_to_cc, $mailbox, $send_to_bcc, $editor_size,
38 $draft_id, $use_signature;
e39d73e5 39
d51894be 40 $send_to = decodeHeader($send_to);
41 $send_to_cc = decodeHeader($send_to_cc);
42 $send_to_bcc = decodeHeader($send_to_bcc);
a53e5469 43
429f8906 44 if ($forward_id)
45 $id = $forward_id;
3b5b889f 46 elseif ($reply_id)
429f8906 47 $id = $reply_id;
48
0a17f9dd 49 if ($draft_id){
50 $id = $draft_id;
51 $use_signature = FALSE;
52 }
1195c340 53
245a6892 54 if (isset($id)) {
813eba2f 55 sqimap_mailbox_select($imapConnection, $mailbox);
429f8906 56 $message = sqimap_get_message($imapConnection, $id, $mailbox);
8d8ab69a 57 $orig_header = $message->header;
1195c340 58 if ($ent_num)
59 $message = getEntity($message, $ent_num);
429f8906 60
9487c2ff 61 if ($message->header->type0 == 'text' || $message->header->type1 == 'message') {
1195c340 62 if ($ent_num)
63 $body = decodeBody(mime_fetch_body($imapConnection, $id, $ent_num), $message->header->encoding);
64 else
65 $body = decodeBody(mime_fetch_body($imapConnection, $id, 1), $message->header->encoding);
429f8906 66 } else {
67 $body = "";
df15de21 68 }
9487c2ff 69
429f8906 70 if ($message->header->type1 == "html")
71 $body = strip_tags($body);
f82d9be2 72
9487c2ff 73 sqUnWordWrap($body);
a794e82c 74 $body_ary = explode("\n", $body);
fb6ce88e 75 $i = count($body_ary) - 1;
3bc5ef2d 76 while ($i >= 0 && ereg("^[>\\s]*$", $body_ary[$i])) {
fb6ce88e 77 unset($body_ary[$i]);
78 $i --;
441f2d33 79 }
a794e82c 80 $body = "";
3bc5ef2d 81 for ($i=0; isset($body_ary[$i]); $i++) {
0a17f9dd 82 if ($reply_id)
01aab860 83 {
59a29c4b 84 if (ereg('^[ >]+', $body_ary[$i]))
01aab860 85 {
86 $body_ary[$i] = '>' . $body_ary[$i];
87 }
88 else
89 {
90 $body_ary[$i] = '> ' . $body_ary[$i];
91 }
92 }
a951522b 93 if (!$draft_id) {
94 sqWordWrap($body_ary[$i], $editor_size - 1);
95 }
01aab860 96 $body .= $body_ary[$i] . "\n";
f923b93d 97 unset($body_ary[$i]);
a794e82c 98 }
01aab860 99 if ($forward_id)
100 {
101 $bodyTop = "-------- " . _("Original Message") . " --------\n";
9487c2ff 102 $bodyTop .= _("Subject") . ": " . $orig_header->subject . "\n";
103 $bodyTop .= _("From") . ": " . $orig_header->from . "\n";
104 $bodyTop .= _("To") . ": " . $orig_header->to[0] . "\n";
01aab860 105 if (count($orig_header->to) > 1) {
106 for ($x=1; $x < count($orig_header->to); $x++) {
107 $bodyTop .= " " . $orig_header->to[$x] . "\n";
108 }
109 }
110 $bodyTop .= "\n";
111 $body = $bodyTop . $body;
856af1e0 112 } else if ($reply_id) {
9af31e64 113 $orig_from = decodeHeader($orig_header->from);
4c06e15d 114 $orig_from = trim(substr($orig_from,0,strpos($orig_from,'<')));
115 $orig_from = str_replace('"','',$orig_from);
116 $orig_from = str_replace("'",'',$orig_from);
248bfebb 117 $body = getReplyCitation($orig_from) . $body;
78509c54 118 }
9487c2ff 119
01aab860 120 return;
78509c54 121 }
429f8906 122
29d08a52 123 if (!$send_to) {
124 $send_to = sqimap_find_email($send_to);
125 }
126
df15de21 127 /** This formats a CC string if they hit "reply all" **/
128 if ($send_to_cc != "") {
a48fbf9b 129 $send_to_cc = ereg_replace( '"[^"]*"', "", $send_to_cc);
df15de21 130 $send_to_cc = ereg_replace(";", ",", $send_to_cc);
131 $sendcc = explode(",", $send_to_cc);
132 $send_to_cc = "";
9487c2ff 133
df15de21 134 for ($i = 0; $i < count($sendcc); $i++) {
135 $sendcc[$i] = trim($sendcc[$i]);
136 if ($sendcc[$i] == "")
137 continue;
9487c2ff 138
a53e5469 139 $sendcc[$i] = sqimap_find_email($sendcc[$i]);
813eba2f 140 $whofrom = sqimap_find_displayable_name($msg["HEADER"]["FROM"]);
141 $whoreplyto = sqimap_find_email($msg["HEADER"]["REPLYTO"]);
9487c2ff 142
df15de21 143 if ((strtolower(trim($sendcc[$i])) != strtolower(trim($whofrom))) &&
144 (strtolower(trim($sendcc[$i])) != strtolower(trim($whoreplyto))) &&
145 (trim($sendcc[$i]) != "")) {
146 $send_to_cc .= trim($sendcc[$i]) . ", ";
147 }
148 }
149 $send_to_cc = trim($send_to_cc);
150 if (substr($send_to_cc, -1) == ",") {
151 $send_to_cc = substr($send_to_cc, 0, strlen($send_to_cc) - 1);
152 }
153 }
154 } // function newMail()
78509c54 155
5713b4f9 156 function getAttachments($message) {
157 global $mailbox, $attachments, $attachment_dir, $imapConnection,
0a17f9dd 158 $ent_num, $forward_id, $draft_id;
159
160 if (isset($draft_id))
161 $id = $draft_id;
162 else
163 $id = $forward_id;
f972eb46 164
5713b4f9 165 if (!$message) {
166 sqimap_mailbox_select($imapConnection, $mailbox);
0a17f9dd 167 $message = sqimap_get_message($imapConnection, $id,
f923b93d 168 $mailbox);
991a059e 169 }
9487c2ff 170
991a059e 171 if (count($message->entities) == 0) {
172 if ($message->header->entity_id != $ent_num) {
173 $filename = decodeHeader($message->header->filename);
9487c2ff 174
991a059e 175 if ($filename == "")
176 $filename = "untitled-".$message->header->entity_id;
9487c2ff 177
991a059e 178 $localfilename = GenerateRandomString(32, '', 7);
f923b93d 179 while (file_exists($attachment_dir . $localfilename))
180 $localfilename = GenerateRandomString(32, '', 7);
f972eb46 181
7a813c24 182 $newAttachment = array();
f972eb46 183 $newAttachment['localfilename'] = $localfilename;
f923b93d 184 $newAttachment['remotefilename'] = $filename;
185 $newAttachment['type'] = strtolower($message->header->type0 .
186 '/' . $message->header->type1);
991a059e 187
188 // Write Attachment to file
f972eb46 189 $fp = fopen ($attachment_dir.$localfilename, 'w');
9487c2ff 190 fputs ($fp, decodeBody(mime_fetch_body($imapConnection,
0a17f9dd 191 $id, $message->header->entity_id),
f923b93d 192 $message->header->encoding));
991a059e 193 fclose ($fp);
9487c2ff 194
f972eb46 195 $attachments[] = $newAttachment;
991a059e 196 }
5713b4f9 197 } else {
991a059e 198 for ($i = 0; $i < count($message->entities); $i++) {
5713b4f9 199 getAttachments($message->entities[$i]);
9487c2ff 200 }
5713b4f9 201 }
202 return;
9487c2ff 203 }
5713b4f9 204
df15de21 205 function showInputForm () {
206 global $send_to, $send_to_cc, $reply_subj, $forward_subj, $body,
9487c2ff 207 $passed_body, $color, $use_signature, $signature, $prefix_sig,
208 $editor_size, $attachments, $subject, $newmail,
209 $use_javascript_addr_book, $send_to_bcc, $reply_id, $mailbox,
aaf9abef 210 $from_htmladdr_search, $location_of_buttons, $attachment_dir,
020abcf3 211 $username, $data_dir, $identity, $draft_id, $delete_draft,
212 $mailprio;
78509c54 213
d51894be 214 $subject = decodeHeader($subject);
2e434774 215 $reply_subj = decodeHeader($reply_subj);
216 $forward_subj = decodeHeader($forward_subj);
9487c2ff 217
3806fa52 218 if ($use_javascript_addr_book) {
219 echo "\n<SCRIPT LANGUAGE=JavaScript><!--\n";
220 echo "function open_abook() { \n";
221 echo " var nwin = window.open(\"addrbook_popup.php\",\"abookpopup\",";
222 echo "\"width=670,height=300,resizable=yes,scrollbars=yes\");\n";
223 echo " if((!nwin.opener) && (document.windows != null))\n";
224 echo " nwin.opener = document.windows;\n";
225 echo "}\n";
226 echo "// --></SCRIPT>\n\n";
227 }
5100704d 228
b3911477 229 echo "\n<FORM name=compose action=\"compose.php\" METHOD=POST ENCTYPE=\"multipart/form-data\"";
230 do_hook("compose_form");
f923b93d 231 echo ">\n";
9487c2ff 232
f7b1b3b1 233 if (isset($draft_id)) {
0a17f9dd 234 echo "<input type=\"hidden\" name=\"delete_draft\" value=\"$draft_id\">\n";
f7b1b3b1 235 }
0fe622fd 236 if (isset($delete_draft)) {
237 echo "<input type=\"hidden\" name=\"delete_draft\" value=\"$delete_draft\">\n";
238 }
0a17f9dd 239
c5d828b3 240 echo "<TABLE WIDTH=\"100%\" ALIGN=center CELLSPACING=0 BORDER=0>\n";
441f2d33 241
242 if ($location_of_buttons == 'top') showComposeButtonRow();
243
aaf9abef 244 $idents = getPref($data_dir, $username, 'identities');
248bfebb 245 if ($idents != '' && $idents > 1) {
aaf9abef 246 echo " <TR>\n";
e7db48af 247 echo " <TD BGCOLOR=\"$color[4]\" WIDTH=\"10%\" ALIGN=RIGHT>\n";
aaf9abef 248 echo _("From:");
e7db48af 249 echo " </TD><TD BGCOLOR=\"$color[4]\" WIDTH=\"90%\">\n";
248bfebb 250 echo "<select name=identity>\n";
9487c2ff 251 echo "<option value=default>" .
248bfebb 252 htmlspecialchars(getPref($data_dir, $username, 'full_name'));
253 $em = getPref($data_dir, $username, 'email_address');
254 if ($em != '')
255 echo htmlspecialchars(' <' . $em . '>') . "\n";
256 for ($i = 1; $i < $idents; $i ++) {
257 echo '<option value="' . $i . '"';
258 if (isset($identity) && $identity == $i)
259 echo ' SELECTED';
260 echo '>';
9487c2ff 261 echo htmlspecialchars(getPref($data_dir, $username, 'full_name' .
248bfebb 262 $i));
263 $em = getPref($data_dir, $username, 'email_address' . $i);
264 if ($em != '')
265 echo htmlspecialchars(' <' . $em . '>') . "\n";
266 }
267 echo "</select>\n";
aaf9abef 268 echo " </TD>\n";
269 echo " </TR>\n";
270 }
df15de21 271 echo " <TR>\n";
e7db48af 272 echo " <TD BGCOLOR=\"$color[4]\" WIDTH=\"10%\" ALIGN=RIGHT>\n";
df15de21 273 echo _("To:");
e7db48af 274 echo " </TD><TD BGCOLOR=\"$color[4]\" WIDTH=\"90%\">\n";
cf8758c7 275 printf(" <INPUT TYPE=text NAME=\"send_to\" VALUE=\"%s\" SIZE=60><BR>\n",
6e79bfe2 276 htmlspecialchars($send_to));
df15de21 277 echo " </TD>\n";
278 echo " </TR>\n";
279 echo " <TR>\n";
c5d828b3 280 echo " <TD BGCOLOR=\"$color[4]\" ALIGN=RIGHT>\n";
aae41ae9 281 echo _("CC:");
c5d828b3 282 echo " </TD><TD BGCOLOR=\"$color[4]\" ALIGN=LEFT>\n";
cf8758c7 283 printf(" <INPUT TYPE=text NAME=\"send_to_cc\" SIZE=60 VALUE=\"%s\"><BR>\n",
6e79bfe2 284 htmlspecialchars($send_to_cc));
df15de21 285 echo " </TD>\n";
286 echo " </TR>\n";
287 echo " <TR>\n";
c5d828b3 288 echo " <TD BGCOLOR=\"$color[4]\" ALIGN=RIGHT>\n";
aae41ae9 289 echo _("BCC:");
761d149e 290 echo " </TD><TD BGCOLOR=\"$color[4]\" ALIGN=LEFT>\n";
cf8758c7 291 printf(" <INPUT TYPE=text NAME=\"send_to_bcc\" VALUE=\"%s\" SIZE=60><BR>\n",
6e79bfe2 292 htmlspecialchars($send_to_bcc));
3806fa52 293 echo "</TD></TR>\n";
5100704d 294
df15de21 295 echo " <TR>\n";
c5d828b3 296 echo " <TD BGCOLOR=\"$color[4]\" ALIGN=RIGHT>\n";
df15de21 297 echo _("Subject:");
761d149e 298 echo " </TD><TD BGCOLOR=\"$color[4]\" ALIGN=LEFT>\n";
df15de21 299 if ($reply_subj) {
300 $reply_subj = str_replace("\"", "'", $reply_subj);
df15de21 301 $reply_subj = trim($reply_subj);
302 if (substr(strtolower($reply_subj), 0, 3) != "re:")
303 $reply_subj = "Re: $reply_subj";
cf8758c7 304 printf(" <INPUT TYPE=text NAME=subject SIZE=60 VALUE=\"%s\">",
6e79bfe2 305 htmlspecialchars($reply_subj));
df15de21 306 } else if ($forward_subj) {
df15de21 307 $forward_subj = trim($forward_subj);
f972eb46 308 if ((substr(strtolower($forward_subj), 0, 4) != 'fwd:') &&
309 (substr(strtolower($forward_subj), 0, 5) != '[fwd:') &&
310 (substr(strtolower($forward_subj), 0, 6) != '[ fwd:'))
df15de21 311 $forward_subj = "[Fwd: $forward_subj]";
cf8758c7 312 printf(" <INPUT TYPE=text NAME=subject SIZE=60 VALUE=\"%s\">",
6e79bfe2 313 htmlspecialchars($forward_subj));
df15de21 314 } else {
6e79bfe2 315 printf(" <INPUT TYPE=text NAME=subject SIZE=60 VALUE=\"%s\">",
316 htmlspecialchars($subject));
31f3d7c0 317 }
480feea7 318 echo "</td></tr>\n\n";
319
441f2d33 320 if ($location_of_buttons == 'between') showComposeButtonRow();
4ba45d11 321
e5b23ff2 322 echo " <TR>\n";
c5d828b3 323 echo " <TD BGCOLOR=\"$color[4]\" COLSPAN=2>\n";
cf8758c7 324 echo " &nbsp;&nbsp;<TEXTAREA NAME=body ROWS=20 COLS=\"$editor_size\" WRAP=HARD>";
441f2d33 325 echo htmlspecialchars($body);
6e79bfe2 326 if ($use_signature == true && $newmail == true && !isset($from_htmladdr_search)) {
b8163cc4 327 if ( $prefix_sig == true )
328 echo "\n\n-- \n" . htmlspecialchars($signature);
329 else
330 echo "\n\n" . htmlspecialchars($signature);
cf8758c7 331 }
332 echo "</TEXTAREA><BR>\n";
e5b23ff2 333 echo " </TD>\n";
334 echo " </TR>\n";
441f2d33 335
9487c2ff 336 if ($location_of_buttons == 'bottom')
441f2d33 337 showComposeButtonRow();
338 else {
339 echo " <TR><TD>&nbsp;</TD><TD ALIGN=LEFT><INPUT TYPE=SUBMIT NAME=send VALUE=\""._("Send")."\"></TD></TR>\n";
340 }
9487c2ff 341
4ba45d11 342 // This code is for attachments
a98bed68 343 echo " <tr>\n";
889df970 344 echo " <TD BGCOLOR=\"$color[0]\" VALIGN=MIDDLE ALIGN=RIGHT>\n";
345 echo _("Attach:");
a98bed68 346 echo " </td><td ALIGN=left BGCOLOR=\"$color[0]\">\n";
944eb785 347 echo " <INPUT NAME=\"attachfile\" SIZE=48 TYPE=\"file\">\n";
95de6c91 348 echo " &nbsp;&nbsp;<input type=\"submit\" name=\"attach\"";
349 echo " value=\"" . _("Add") ."\">\n";
469eb37b 350 echo " </td>\n";
469eb37b 351 echo " </tr>\n";
f972eb46 352 if (count($attachments))
353 {
a98bed68 354 echo "<tr><td bgcolor=\"$color[0]\" align=right>\n";
e5b23ff2 355 echo "&nbsp;";
a98bed68 356 echo "</td><td align=left bgcolor=\"$color[0]\">";
f923b93d 357 foreach ($attachments as $key => $info) {
f972eb46 358 echo "<input type=\"checkbox\" name=\"delete[]\" value=\"$key\">\n";
f923b93d 359 echo $info['remotefilename'] . " - " . $info['type'] . " (";
9487c2ff 360 echo show_readable_size(filesize($attachment_dir .
f923b93d 361 $info['localfilename'])) . ")<br>\n";
4ba45d11 362 }
9487c2ff 363
4ba45d11 364 echo "<input type=\"submit\" name=\"do_delete\" value=\""._("Delete selected attachments")."\">\n";
469eb37b 365 echo "</td></tr>";
4ba45d11 366 }
4ba45d11 367 // End of attachment code
368
ffc2ccbc 369 echo "</TABLE>\n";
9487c2ff 370 if ($reply_id) {
371 echo "<input type=hidden name=reply_id value=$reply_id>\n";
372 }
373 printf("<INPUT TYPE=hidden NAME=mailbox VALUE=\"%s\">\n", htmlspecialchars($mailbox));
df15de21 374 echo "</FORM>";
d7d3c4d4 375 do_hook("compose_bottom");
4d1d3c86 376 echo "</BODY></HTML>\n";
31f3d7c0 377 }
9487c2ff 378
441f2d33 379 function showComposeButtonRow() {
020abcf3 380 global $use_javascript_addr_book, $save_as_draft,
381 $default_use_priority, $mailprio;
9487c2ff 382
441f2d33 383 echo " <TR><td>\n </td><td>\n";
384 if ($use_javascript_addr_book) {
385 echo " <SCRIPT LANGUAGE=JavaScript><!--\n document.write(\"";
386 echo " <input type=button value=\\\""._("Addresses")."\\\" onclick='javascript:open_abook();'>\");";
387 echo " // --></SCRIPT><NOSCRIPT>\n";
388 echo " <input type=submit name=\"html_addr_search\" value=\""._("Addresses")."\">";
389 echo " </NOSCRIPT>\n";
9487c2ff 390 } else {
441f2d33 391 echo " <input type=submit name=\"html_addr_search\" value=\""._("Addresses")."\">";
9487c2ff 392 }
441f2d33 393 echo "\n <INPUT TYPE=SUBMIT NAME=send VALUE=\"". _("Send") . "\">\n";
9487c2ff 394
f7b1b3b1 395 if ($save_as_draft) {
57155fe3 396 echo '<input type="submit" name ="draft" value="' . _("Save Draft") . "\">\n";
f7b1b3b1 397 }
020abcf3 398 if ($default_use_priority) {
399 if(!isset($mailprio)) {
400 $mailprio = "3";
401 }
402 echo "\n\t". _("Priority") .":<select name=\"mailprio\">".
403 "\n\t\t<option value=1".($mailprio=="1"?" selected":"").">". _("High") ."</option>".
404 "\n\t\t<option value=3".($mailprio=="3"?" selected":"").">". _("Normal") ."</option>".
405 "\n\t\t<option value=5".($mailprio=="5"?" selected":"").">". _("Low")."</option>".
406 "\n\t</select>";
407 }
0a17f9dd 408
441f2d33 409 do_hook("compose_button_row");
410
411 echo " </TD>\n";
412 echo " </TR>\n\n";
413 }
8467bf00 414
0ad7dbda 415 function checkInput ($show) {
416 /** I implemented the $show variable because the error messages
417 were getting sent before the page header. So, I check once
418 using $show=false, and then when i'm ready to display the
419 error message, show=true **/
420 global $body, $send_to, $subject, $color;
b278172f 421
99fa2b21 422 if ($send_to == "") {
0ad7dbda 423 if ($show)
424 plain_error_message(_("You have not filled in the \"To:\" field."), $color);
df15de21 425 return false;
b278172f 426 }
df15de21 427 return true;
428 } // function checkInput()
429
3806fa52 430
056ddad7 431 // True if FAILURE
432 function saveAttachedFiles() {
433 global $HTTP_POST_FILES, $attachment_dir, $attachments;
020abcf3 434
056ddad7 435 $localfilename = GenerateRandomString(32, '', 7);
f972eb46 436 while (file_exists($attachment_dir . $localfilename))
a4fe5de0 437 $localfilename = GenerateRandomString(32, '', 7);
f972eb46 438
056ddad7 439 if (!@rename($HTTP_POST_FILES['attachfile']['tmp_name'], $attachment_dir.$localfilename)) {
440 if (!@copy($HTTP_POST_FILES['attachfile']['tmp_name'], $attachment_dir.$localfilename)) {
441 return true;
442 }
443 }
9487c2ff 444
f972eb46 445 $newAttachment['localfilename'] = $localfilename;
446 $newAttachment['remotefilename'] = $HTTP_POST_FILES['attachfile']['name'];
9487c2ff 447 $newAttachment['type'] =
f972eb46 448 strtolower($HTTP_POST_FILES['attachfile']['type']);
8ef72f33 449
450 if ($newAttachment['type'] == "")
451 $newAttachment['type'] = 'application/octet-stream';
452
f972eb46 453 $attachments[] = $newAttachment;
056ddad7 454 }
9487c2ff 455
2d367c68 456 if (!isset($mailbox) || $mailbox == '' || ($mailbox == 'None'))
dcb7f454 457 $mailbox = "INBOX";
3806fa52 458
0a17f9dd 459 if (isset($draft)) {
460 require_once ('../src/draft_actions.php');
f7b1b3b1 461 if (!saveMessageAsDraft($send_to, $send_to_cc, $send_to_bcc, $subject, $body, $reply_id)) {
0a17f9dd 462 showInputForm();
463 exit();
464 } else {
f7b1b3b1 465 $draft_message = _("Draft Email Saved");
45c4e0f2 466 /* If this is a resumed draft, then delete the original */
467 if(isset($delete_draft)) {
468 Header("Location: delete_message.php?mailbox=$draft_folder&message=$delete_draft&sort=$sort&startMessage=1");
469 exit();
470 } else {
471 Header("Location: right_main.php?mailbox=$draft_folder&sort=$sort&startMessage=1&note=$draft_message");
472 exit();
473 }
0a17f9dd 474 }
475 }
476
f972eb46 477 if (isset($send)) {
245a6892 478 if (isset($HTTP_POST_FILES['attachfile']) &&
479 $HTTP_POST_FILES['attachfile']['tmp_name'] &&
78b4216e 480 $HTTP_POST_FILES['attachfile']['tmp_name'] != 'none')
056ddad7 481 $AttachFailure = saveAttachedFiles();
a7ea7540 482 if (checkInput(false) && !isset($AttachFailure)) {
35d520d3 483 $urlMailbox = urlencode (trim($mailbox));
484 if (! isset($reply_id))
485 $reply_id = 0;
ebab5342 486 // Set $default_charset to correspond with the user's selection
f923b93d 487 // of language interface.
488 set_my_charset();
eedcdd97 489
490 // This is to change all newlines to \n
248bfebb 491 // We'll change them to \r\n later (in the sendMessage function)
492 $body = str_replace("\r\n", "\n", $body);
493 $body = str_replace("\r", "\n", $body);
9487c2ff 494
248bfebb 495 // Rewrap $body so that no line is bigger than $editor_size
496 // This should only really kick in the sqWordWrap function
497 // if the browser doesn't support "HARD" as the wrap type
498 // Or, in Opera's case, something goes wrong.
499 $body = explode("\n", $body);
500 $newBody = '';
501 foreach ($body as $line) {
502 if( $line <> '-- ' )
503 $line = rtrim($line);
504 if (strlen($line) <= $editor_size + 1)
505 $newBody .= $line . "\n";
506 else {
507 sqWordWrap($line, $editor_size) . "\n";
508 $newBody .= $line;
509 }
510 }
511 $body = $newBody;
9487c2ff 512
f923b93d 513 do_hook("compose_send");
9487c2ff 514
872c4fac 515 if (! isset($mailprio))
516 $Result = sendMessage($send_to, $send_to_cc, $send_to_bcc,
9bc3dc44 517 $subject, $body, $reply_id);
872c4fac 518 else
9bc3dc44 519 $Result = sendMessage($send_to, $send_to_cc, $send_to_bcc,
520 $subject, $body, $reply_id, $mailprio);
872c4fac 521 if (! $Result) {
9487c2ff 522 showInputForm();
248bfebb 523 exit();
524 }
0a17f9dd 525 if ( isset($delete_draft)) {
cc82b756 526 Header("Location: delete_message.php?mailbox=$draft_folder&message=$delete_draft&sort=$sort&startMessage=1");
0a17f9dd 527 exit();
528 }
529
248bfebb 530 Header("Location: right_main.php?mailbox=$urlMailbox&sort=$sort&startMessage=1");
df15de21 531 } else {
01aab860 532 //$imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0);
dcb7f454 533 displayPageHeader($color, $mailbox);
9487c2ff 534
7a813c24 535 if (isset($AttachFailure))
056ddad7 536 plain_error_message(_("Could not move/copy file. File not attached"), $color);
537
0ad7dbda 538 checkInput(true);
9487c2ff 539
df15de21 540 showInputForm();
01aab860 541 //sqimap_logout($imapConnection);
7c6cb7ca 542 }
245a6892 543 } else if (isset($html_addr_search_done)) {
dcb7f454 544 displayPageHeader($color, $mailbox);
3806fa52 545
b8796881 546 if (isset($send_to_search) && is_array($send_to_search)) {
547 foreach ($send_to_search as $k => $v) {
248bfebb 548 if (substr($k, 0, 1) == 'T') {
b8796881 549 if ($send_to)
550 $send_to .= ', ';
551 $send_to .= $v;
248bfebb 552 }
553 elseif (substr($k, 0, 1) == 'C') {
554 if ($send_to_cc)
555 $send_to_cc .= ', ';
556 $send_to_cc .= $v;
557 }
558 elseif (substr($k, 0, 1) == 'B') {
559 if ($send_to_bcc)
560 $send_to_bcc .= ', ';
561 $send_to_bcc .= $v;
562 }
e53f7484 563 }
a98bed68 564 }
9487c2ff 565
3806fa52 566 showInputForm();
245a6892 567 } else if (isset($html_addr_search)) {
f17728d1 568 if (isset($HTTP_POST_FILES['attachfile']) &&
569 $HTTP_POST_FILES['attachfile']['tmp_name'] &&
570 $HTTP_POST_FILES['attachfile']['tmp_name'] != 'none')
571 {
572 if (saveAttachedFiles())
573 plain_error_message(_("Could not move/copy file. File not attached"), $color);
574 }
591d2a88 575 // I am using an include so as to elminiate an extra unnecessary click. If you
576 // can think of a better way, please implement it.
ff8a98e7 577 include_once('./addrbook_search_html.php');
4ba45d11 578 } else if (isset($attach)) {
056ddad7 579 if (saveAttachedFiles())
22ef7536 580 plain_error_message(_("Could not move/copy file. File not attached"), $color);
21bc0570 581 displayPageHeader($color, $mailbox);
4ba45d11 582 showInputForm();
583 } else if (isset($do_delete)) {
dcb7f454 584 displayPageHeader($color, $mailbox);
fc3348ac 585
f972eb46 586 if (isset($delete) && is_array($delete))
587 {
588 foreach($delete as $index)
589 {
590 unlink ($attachment_dir.$attachments[$index]['localfilename']);
591 unset ($attachments[$index]);
f923b93d 592 }
4ba45d11 593 }
4bfed9f3 594
4ba45d11 595 showInputForm();
596 } else {
991a059e 597 // This handles the default case as well as the error case
598 // (they had the same code) --> if (isset($smtpErrors))
9487c2ff 599 $imapConnection = sqimap_login($username, $key, $imapServerAddress,
991a059e 600 $imapPort, 0);
dcb7f454 601 displayPageHeader($color, $mailbox);
fc3348ac 602
b57c4e63 603 $newmail = true;
f972eb46 604
605 ClearAttachments();
606
991a059e 607 if (isset($forward_id) && $forward_id && isset($ent_num) && $ent_num)
608 getAttachments(0);
9487c2ff 609
0a17f9dd 610 if (isset($draft_id) && $draft_id && isset($ent_num) && $ent_num)
611 getAttachments(0);
612
1220e677 613 newMail();
4ba45d11 614 showInputForm();
1195c340 615 sqimap_logout($imapConnection);
4ba45d11 616 }
9487c2ff 617
f923b93d 618 function ClearAttachments() {
f972eb46 619 global $attachments, $attachment_dir;
9487c2ff 620
f923b93d 621 foreach ($attachments as $info) {
622 if (file_exists($attachment_dir . $info['localfilename'])) {
f972eb46 623 unlink($attachment_dir . $info['localfilename']);
f923b93d 624 }
f972eb46 625 }
9487c2ff 626
f972eb46 627 $attachments = array();
628 }
cd41fc8d 629
630 function getReplyCitation($orig_from) {
631 global $reply_citation_style, $reply_citation_start, $reply_citation_end;
632
633 /* First, return an empty string when no citation style selected. */
634 if (($reply_citation_style == '') || ($reply_citation_style == 'none')) {
635 return ('');
636 }
637
638 /* Otherwise, try to select the desired citation style. */
639 switch ($reply_citation_style) {
640 case 'author_said':
641 $start = '';
642 $end = ' ' . _("said") . ':';
643 break;
644 case 'quote_who':
645 $start = '<' . _("quote") . ' ' . _("who") . '="';
646 $end = '">';
647 break;
648 case 'user-defined':
649 $start = $reply_citation_start;
650 $end = $reply_citation_end;
651 break;
652 default: return ('');
653 }
654
655 /* Build and return the citation string. */
656 return ($start . $orig_from . $end . "\n");
9487c2ff 657 }
0a17f9dd 658?>