+
+/* List search results */
+function addr_display_result($res, $includesource = true) {
+ global $color, $PHP_SELF;
+
+ if (sizeof($res) <= 0) return;
+
+ echo '<form method=post action="' . $PHP_SELF . "\">\n" .
+ '<input type=hidden name="html_addr_search_done" value="true">' . "\n";
+ addr_insert_hidden();
+ $line = 0;
+
+ echo '<TABLE BORDER=0 WIDTH="98%" ALIGN=center>' .
+ '<TR BGCOLOR="' . $color[9] . '"><TH ALIGN=left> ' .
+ '<TH ALIGN=left> ' . _("Name") .
+ '<TH ALIGN=left> ' . _("E-mail") .
+ '<TH ALIGN=left> ' . _("Info");
+
+ if ($includesource) {
+ echo '<TH ALIGN=left WIDTH="10%"> ' . _("Source");
+ }
+
+ echo "</TR>\n";
+
+ foreach ($res as $row) {
+ echo '<tr';
+ if ($line % 2) { echo ' bgcolor="' . $color[0] . '"'; }
+ echo ' nowrap><td nowrap align=center width="5%">' .
+ '<input type=checkbox name="send_to_search[T' . $line . ']" value = "' .
+ htmlspecialchars($row['email']) . '"> ' . _("To") . ' ' .
+ '<input type=checkbox name="send_to_search[C' . $line . ']" value = "' .
+ htmlspecialchars($row['email']) . '"> ' . _("Cc") . ' ' .
+ '<input type=checkbox name="send_to_search[B' . $line . ']" value = "' .
+ htmlspecialchars($row['email']) . '"> ' . _("Bcc") . ' ' .
+ '</td><td nowrap> ' . $row['name'] . ' </td>' .
+ '<td nowrap> ' . $row['email'] . ' </td>' .
+ '<td nowrap> ' . $row['label'] . ' </td>';
+ if ($includesource) {
+ echo '<td nowrap> ' . $row['source'] . ' </td>';
+ }
+ echo "</tr>\n";
+ $line ++;
+ }
+ echo '<TR><TD ALIGN=center COLSPAN=';
+ if ($includesource) { echo '4'; } else { echo '5'; }
+ echo '><INPUT TYPE=submit NAME="addr_search_done" VALUE="' .
+ _("Use Addresses") . '"></TD></TR>' .
+ '</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();
+
+?>
+
+<br>
+<table width="95%" align=center cellpadding=2 cellspacing=2 border=0>
+<tr><td bgcolor="<?php echo $color[0] ?>">
+ <center><b><?php echo _("Address Book Search") ?></b></center>
+</td></tr></table>
+
+<?php
+
+/* Search form */
+echo "<CENTER>\n<TABLE BORDER=0><TR><TD 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";
+}
+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 '<P ALIGN=center><STRONG>' .
+ sprintf(_("Unable to list addresses from %s"),
+ $abook->backends[$backend]->sname) .
+ "</STRONG></P>\n";
+ }
+
+ } 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 '<P ALIGN=center><B><BR>' .
+ _("Your search failed with the following error(s)") . ':<br>' .
+ $abook->error . "</B></P>\n</BODY></HTML>\n";
+ } else {
+ if (sizeof($res) == 0) {
+ echo '<P ALIGN=center><BR><B>' .
+ _("No persons matching your search was found") .
+ ".</B></P>\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>';
+}
+