<?php
- /**
- ** addrbook_search.php
- **
- ** Handle addressbook searching with pure html. This file is included from compose.php
- **
- **/
-
- session_start();
-
- if (!isset($config_php))
- include("../config/config.php");
- if (!isset($strings_php))
- include("../functions/strings.php");
- if (!isset($page_header_php))
- include("../functions/page_header.php");
- if (!isset($imap_php))
- include("../functions/imap.php");
- if (!isset($date_php))
- include("../functions/date.php");
- if (!isset($mime_php))
- include("../functions/mime.php");
- if (!isset($smtp_php))
- include("../functions/smtp.php");
- if (!isset($display_messages_php))
- include("../functions/display_messages.php");
- if (!isset($addressbook_php))
- include("../functions/addressbook.php");
-
- include("../src/load_prefs.php");
-
-
- echo "<HTML><BODY TEXT=\"$color[8]\" BGCOLOR=\"$color[4]\" LINK=\"$color[7]\" VLINK=\"$color[7]\" ALINK=\"$color[7]\">\n";
- displayPageHeader($color, "None");
- //<form method=post action="compose.php?html_addr_search=true">
-
-
- $body = stripslashes($body);
- $send_to = stripslashes($send_to);
- $send_to_cc = stripslashes($send_to_cc);
- $send_to_bcc = stripslashes($send_to_bcc);
- $subject = stripslashes($subject);
-
- echo "<center>";
- echo "<form method=post action=\"compose.php?html_addr_search=true\">";
- echo " <input type=text value=\"$query\"name=query>";
- echo " <input type=submit value=Submit>";
- echo " <input type=hidden value=\"$body\" name=body>";
- echo " <input type=hidden value=\"$subject\" name=subject>";
- echo " <input type=hidden value=\"$send_to\" name=send_to>";
- echo " <input type=hidden value=\"$send_to_cc\" name=send_to_cc>";
- echo " <input type=hidden value=\"$send_to_bcc\" name=send_to_bcc>";
- echo "</form>";
- echo "</center>";
-
- echo "<tt>".nl2br($body)."</tt>";
-
- if(!empty($query)) {
- $abook = addressbook_init();
- $res = $abook->s_search($query);
-
- if(!is_array($res)) {
- printf("<P ALIGN=center><BR>%s:<br>%s</P>\n</BODY></HTML>\n",
- _("Your search failed with the following error(s)"),
- $abook->error);
- exit;
- }
-
- if(sizeof($res) == 0) {
- printf("<P ALIGN=center><BR>%s.</P>\n</BODY></HTML>\n",
- _("No persons matching your search was found"));
- exit;
- }
-
- // List search results
- $line = 0;
- print "<table border=0 width=\"98%\" align=center>";
- printf("<tr bgcolor=\"$color[9]\"><TH align=left> ".
- "<TH align=left> %s<TH align=left> %s".
- "<TH align=left> %s<TH align=left width=\"10%%\">".
- " %s</tr>\n",
- _("Name"), _("E-mail"), _("Info"), _("Source"));
-
- ?>
- <form method=post action"compose.php?html_addr_search_done=true">
- <?
- echo " <input type=hidden value=\"$body\" name=body>";
- echo " <input type=hidden value=\"$subject\" name=subject>";
- echo " <input type=hidden value=\"$send_to\" name=send_to>";
- echo " <input type=hidden value=\"$send_to_cc\" name=send_to_cc>";
- echo " <input type=hidden value=\"$send_to_bcc\" name=send_to_bcc>";
-
- while(list($key, $row) = each($res)) {
- printf("<tr%s nowrap><td nowrap align=center width=\"5%%\">".
- "<input type=checkbox name=send_to_search[] value=\"%s\"> To".
- "<input type=checkbox name=send_to_cc_search[] value=\"%s\"> Cc ".
- "<td nowrap> %s <td nowrap> ".
- "<a href=\"compose.php?send_to_search=%s\">%s</A> ".
- "<td nowrap> %s <td nowrap> %s</tr>\n",
- ($line % 2) ? " bgcolor=\"$color[0]\"" : "", $row["email"],
- $row["email"], $row["name"], $row["email"], $row["email"],
- $row["label"], $row["source"]);
- $line++;
- }
- print "</TABLE>";
- echo "<input type=hidden value=1 name=html_addr_search_done>";
- echo "<center><input type=submit value=addr_search_done name=\"Use Addresses\"></center>";
- echo "</form>";
+
+/**
+ * addrbook_search_html.php
+ *
+ * Copyright (c) 1999-2002 The SquirrelMail Project Team
+ * Licensed under the GNU GPL. For full terms see the file COPYING.
+ *
+ * Handle addressbook searching with pure html.
+ *
+ * This file is included from compose.php
+ *
+ * NOTE: A lot of this code is similar to the code in
+ * addrbook_search.html -- If you change one, change
+ * the other one too!
+ *
+ * $Id$
+ */
+
+require_once('../src/validate.php');
+require_once('../functions/date.php');
+require_once('../functions/smtp.php');
+require_once('../functions/display_messages.php');
+require_once('../functions/addressbook.php');
+require_once('../functions/plugin.php');
+require_once('../functions/strings.php');
+require_once('../functions/html.php');
+
+/* Insert hidden data */
+function addr_insert_hidden() {
+ global $body, $subject, $send_to, $send_to_cc, $send_to_bcc, $mailbox,
+ $identity, $session;
+
+ echo '<input type=hidden value="';
+ if (substr($body, 0, 1) == "\r") {
+ echo "\n";
+ }
+ echo htmlspecialchars($body) . '" name=body>' . "\n" .
+ '<input type=hidden value="' . $session . '" name=session>' . "\n" .
+ '<input type=hidden value="' . htmlspecialchars($subject) .
+ '" name=subject>' . "\n" .
+ '<input type=hidden value="' . htmlspecialchars($send_to) .
+ '" name=send_to>' . "\n" .
+ '<input type=hidden value="' . htmlspecialchars($send_to_cc) .
+ '" name=send_to_cc>' . "\n" .
+ '<input type=hidden value="' . htmlspecialchars($send_to_bcc) .
+ '" name=send_to_bcc>' . "\n" .
+ '<input type=hidden value="' . htmlspecialchars($identity) .
+ '" name=identity>' . "\n" .
+ '<input type=hidden name=mailbox value="' . htmlspecialchars($mailbox) .
+ "\">\n" . '<input type=hidden value="true" name=from_htmladdr_search>' .
+ "\n";
}
+
+/* List search results */
+function addr_display_result($res, $includesource = true) {
+ global $color, $javascript_on, $PHP_SELF;
+
+ if (sizeof($res) <= 0) return;
+
+ echo '<form method=post action="' . $PHP_SELF . '" name="addrbook">'."\n" .
+ '<input type=hidden name="html_addr_search_done" value="true">' . "\n";
+ addr_insert_hidden();
+ $line = 0;
+
+if ($javascript_on) {
+ print
+ '<script language="JavaScript" type="text/javascript">' .
+ "\n<!-- \n" .
+ "function CheckAll(ch) {\n" .
+ " for (var i = 0; i < document.addrbook.elements.length; i++) {\n" .
+ " if( document.addrbook.elements[i].type == 'checkbox' &&\n" .
+ " document.addrbook.elements[i].name.substr(0,16) == 'send_to_search['+ch ) {\n" .
+ " document.addrbook.elements[i].checked = !(document.addrbook.elements[i].checked);\n".
+ " }\n" .
+ " }\n" .
+ "}\n" .
+ "//-->\n" .
+ "</script>\n";
+ $chk_all = '<a href="#" onClick="CheckAll(\'T\');">' . _("All") . '</a> <font color="'.$color[9].'">To</font>'.
+ ' '.
+ '<a href="#" onClick="CheckAll(\'C\');">' . _("All") . '</a> <font color="'.$color[9].'">Cc</font>'.
+ ' '.
+ '<a href="#" onClick="CheckAll(\'B\');">' . _("All") . '</a>';
+ }
+ echo html_tag( 'table', '', 'center', '', 'border="0" width="98%"' ) .
+ html_tag( 'tr', '', '', $color[9] ) .
+ html_tag( 'th', ' ' . $chk_all, 'left' ) .
+ html_tag( 'th', ' ' . _("Name"), 'left' ) .
+ html_tag( 'th', ' ' . _("E-mail"), 'left' ) .
+ html_tag( 'th', ' ' . _("Info"), 'left' );
+
+ if ($includesource) {
+ echo html_tag( 'th', ' ' . _("Source"), 'left', '', 'width="10%"' );
+ }
+
+ echo "</tr>\n";
+
+ foreach ($res as $row) {
+ $tr_bgcolor = '';
+ $email = AddressBook::full_address($row);
+ if ($line % 2) { $tr_bgcolor = $color[0]; }
+ echo html_tag( 'tr', '', '', $tr_bgcolor, 'nowrap' ) .
+ html_tag( 'td',
+ '<input type=checkbox name="send_to_search[T' . $line . ']" value = "' .
+ htmlspecialchars($email) . '"> ' . _("To") . ' ' .
+ '<input type=checkbox name="send_to_search[C' . $line . ']" value = "' .
+ htmlspecialchars($email) . '"> ' . _("Cc") . ' ' .
+ '<input type=checkbox name="send_to_search[B' . $line . ']" value = "' .
+ htmlspecialchars($email) . '"> ' . _("Bcc") . ' ' ,
+ 'center', '', 'width="5%" nowrap' ) .
+ html_tag( 'td', ' ' . $row['name'] . ' ', 'left', '', 'nowrap' ) .
+ html_tag( 'td', ' ' . $row['email'] . ' ', 'left', '', 'nowrap' ) .
+ html_tag( 'td', ' ' . $row['label'] . ' ', 'left', '', 'nowrap' );
+
+ if ($includesource) {
+ echo html_tag( 'td', ' ' . $row['source'] . ' ', 'left', '', 'nowrap' );
+ }
+ echo "</tr>\n";
+ $line ++;
+ }
+ if ($includesource) { $td_colspan = '5'; } else { $td_colspan = '4'; }
+ echo html_tag( 'tr',
+ html_tag( 'td',
+ '<INPUT TYPE=submit NAME="addr_search_done" VALUE="' .
+ _("Use Addresses") . '">' ,
+ 'center', '', 'colspan="'. $td_colspan .'"' )
+ ) .
+ '</TABLE>' .
+ '<INPUT TYPE=hidden VALUE=1 NAME="html_addr_search_done">' .
+ '</FORM>';
+}
+
+/* --- End functions --- */
+
+global $mailbox;
+if ($compose_new_win == '1') {
+ compose_Header($color, $mailbox);
+}
+else {
+ displayPageHeader($color, $mailbox);
+}
+/* Initialize addressbook */
+$abook = addressbook_init();
+
+
+echo '<br>' .
+html_tag( 'table',
+ html_tag( 'tr',
+ html_tag( 'td', '<b>' . _("Address Book Search") . '</b>', 'center', $color[0] )
+ ) ,
+'center', '', 'width="95%" cellpadding="2" cellspacing="2" border="0"' );
+
+
+/* Search form */
+echo '<center>' .
+ html_tag( 'table', '', 'center', '', 'border="0"' ) .
+ html_tag( 'tr' ) .
+ html_tag( 'td', '', 'left', '', 'nowrap valign="middle"' ) . "\n" .
+ '<FORM METHOD=post NAME=f ACTION="' . $PHP_SELF .
+ '?html_addr_search=true">' . "\n<CENTER>\n" .
+ ' <nobr><STRONG>' . _("Search for") . "</STRONG>\n";
+addr_insert_hidden();
+if (! isset($addrquery))
+ $addrquery = '';
+echo ' <INPUT TYPE=text NAME=addrquery VALUE="' .
+ htmlspecialchars($addrquery) . "\" SIZE=26>\n";
+
+/* List all backends to allow the user to choose where to search */
+if (!isset($backend)) { $backend = ''; }
+if ($abook->numbackends > 1) {
+ echo '<STRONG>' . _("in") . '</STRONG> <SELECT NAME=backend>' . "\n" .
+ '<OPTION VALUE=-1';
+ if ($backend == -1) { echo ' SELECTED'; }
+ echo '>' . _("All address books") . "\n";
+ $ret = $abook->get_backend_list();
+ while (list($undef,$v) = each($ret)) {
+ echo '<OPTION VALUE=' . $v->bnum;
+ if ($backend == $v->bnum) { echo ' SELECTED'; }
+ echo '>' . $v->sname . "\n";
+ }
+ echo "</SELECT>\n";
+} else {
+ echo '<INPUT TYPE=hidden NAME=backend VALUE=-1>' . "\n";
+}
+if (isset($session)) {
+ echo "<input type=hidden name=\"session\" value=\"$session\">";
+}
+
+echo '<INPUT TYPE=submit VALUE="' . _("Search") . '">' .
+ ' | <INPUT TYPE=submit VALUE="' . _("List all") .
+ '" NAME=listall>' . "\n" .
+ '</FORM></center></TD></TR></TABLE>' . "\n";
+addr_insert_hidden();
+echo '</center>';
+do_hook('addrbook_html_search_below');
+/* End search form */
+
+/* Show personal addressbook */
+
+if ( !empty( $listall ) ){
+ $addrquery = '*';
+}
+
+if ($addrquery == '' && empty($listall)) {
+
+ if (! isset($backend) || $backend != -1 || $addrquery == '') {
+ if ($addrquery == '') {
+ $backend = $abook->localbackend;
+ }
+
+ /* echo '<H3 ALIGN=center>' . $abook->backends[$backend]->sname) . "</H3>\n"; */
+
+ $res = $abook->list_addr($backend);
+
+ if (is_array($res)) {
+ usort($res,'alistcmp');
+ addr_display_result($res, false);
+ } else {
+ echo html_tag( 'p', '<strong><br>' .
+ sprintf(_("Unable to list addresses from %s"),
+ $abook->backends[$backend]->sname) . "</strong>\n" ,
+ 'center' );
+ }
+
+ } else {
+ $res = $abook->list_addr();
+ usort($res,'alistcmp');
+ addr_display_result($res, true);
+ }
+ exit;
+}
+else {
+
+ /* Do the search */
+ if (!empty($addrquery)) {
+
+ if ($backend == -1) {
+ $res = $abook->s_search($addrquery);
+ } else {
+ $res = $abook->s_search($addrquery, $backend);
+ }
+
+ if (!is_array($res)) {
+ echo html_tag( 'p', '<b><br>' .
+ _("Your search failed with the following error(s)") .
+ ':<br>' . $abook->error . "</b>\n" ,
+ 'center' ) .
+ "\n</BODY></HTML>\n";
+ } else {
+ if (sizeof($res) == 0) {
+ echo html_tag( 'p', '<br><b>' .
+ _("No persons matching your search was found") . "</b>\n" ,
+ 'center' ) .
+ "\n</BODY></HTML>\n";
+ } else {
+ addr_display_result($res);
+ }
+ }
+ }
+}
+
+if ($addrquery == '' || sizeof($res) == 0) {
+ /* printf('<center><FORM METHOD=post NAME=k ACTION="compose.php">'."\n", $PHP_SELF); */
+ echo '<center><FORM METHOD=post NAME=k ACTION="compose.php">' . "\n";
+ addr_insert_hidden();
+ echo '<INPUT TYPE=submit VALUE="' . _("Return") . '" NAME=return>' . "\n" .
+ '</form></center></nobr>';
+}
+
?>
+</body></html>