+ } // End of included JavaScript
+
+
+ // List search results
+ function display_result($res, $includesource = true) {
+ global $color;
+
+ if(sizeof($res) <= 0) return;
+
+ insert_javascript();
+
+ $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",
+ _("Name"), _("E-mail"), _("Info"));
+
+ if($includesource)
+ printf("<TH ALIGN=left WIDTH=\"10%%\"> %s", _("Source"));
+
+ print "</TR>\n";
+
+ while(list($undef, $row) = each($res)) {
+ printf("<tr%s nowrap><td valign=top nowrap align=center width=\"5%%\">".
+ "<small><a href=\"javascript:to_address('%s');\">To</A> | ".
+ "<a href=\"javascript:cc_address('%s');\">Cc</A> | ".
+ "<a href=\"javascript:bcc_address('%s');\">Bcc</A></small>".
+ "<td nowrap valign=top> %s <td nowrap valign=top>".
+ " <a href=\"javascript:to_and_close('%s');\">%s</A> ".
+ "<td valign=top> %s ",
+ ($line % 2) ? " bgcolor=\"$color[0]\"" : "",
+ $row["email"], $row["email"], $row["email"],
+ $row["name"], $row["email"], $row["email"],
+ $row["label"]);
+
+ if($includesource)
+ printf("<td nowrap valign=top> %s", $row["source"]);
+
+ print "</TR>\n";
+ $line++;
+ }
+ print '</TABLE>';
+ }
+
+ /* ================= End of functions ================= */
+
+ include('../functions/array.php');
+ include('../functions/strings.php');
+ include('../functions/addressbook.php');
+
+ displayHtmlHeader();
+
+ // Initialize vars
+ if(!isset($query)) $query = "";
+ if(!isset($show)) $show = "";
+
+ // Choose correct colors for top and bottom frame
+ if($show == 'form') {
+ echo "<BODY BGCOLOR=\"$color[3]\" TEXT=\"$color[6]\" ";
+ echo "LINK=\"$color[6]\" VLINK=\"$color[6]\" ALINK=\"$color[6]\" ";
+ echo 'OnLoad="document.sform.query.focus();">';
+ } else {
+ echo "<BODY TEXT=\"$color[8]\" BGCOLOR=\"$color[4]\" ";
+ echo "LINK=\"$color[7]\" VLINK=\"$color[7]\" ALINK=\"$color[7]\">\n";
+ }
+
+ // Empty search
+ if(empty($query) && empty($show) && empty($listall)) {
+ printf("<P ALIGN=center><BR>%s</P>\n</BODY></HTML>\n",
+ _("No persons matching your search was found"));
+ exit;
+ }
+
+ // Initialize addressbook
+ $abook = addressbook_init();
+
+ // Create search form
+ if($show == 'form') {
+ printf("<FORM NAME=sform TARGET=abookres ACTION=\"%s\" METHOD=\"POST\">\n",
+ $PHP_SELF);
+ print('<TABLE BORDER="0" WIDTH="100%" HEIGHT="100%">');
+ print("<TR><TD NOWRAP VALIGN=middle>\n");
+ printf(" <STRONG>%s</STRONG>\n", _("Search for"));
+ printf(" <INPUT TYPE=text NAME=query VALUE=\"%s\" SIZE=26>\n",
+ htmlspecialchars($query));
+
+ // List all backends to allow the user to choose where to search
+ if($abook->numbackends > 1) {
+ printf("<STRONG>%s</STRONG> <SELECT NAME=backend>\n",
+ _("in"));
+ printf("<OPTION VALUE=-1 SELECTED>%s\n",
+ _("All address books"));
+ $ret = $abook->get_backend_list();
+ while(list($undef,$v) = each($ret))
+ printf("<OPTION VALUE=%d>%s\n", $v->bnum, $v->sname);
+ print "</SELECT>\n";
+ } else {
+ print "<INPUT TYPE=hidden NAME=backend VALUE=-1>\n";
+ }
+
+ printf("<INPUT TYPE=submit VALUE=\"%s\">",
+ _("Search"));
+ printf(" | <INPUT TYPE=submit VALUE=\"%s\" NAME=listall>\n",
+ _("List all"));
+ print "</TD><TD ALIGN=right>\n";
+ printf("<INPUT TYPE=button VALUE=\"%s\" onclick=\"parent.close();\">\n",
+ _("Close window"));
+ print "</TD></TR></TABLE></FORM>\n";
+ } else
+
+ // Show personal addressbook
+ if($show == 'blank' || !empty($listall)) {
+
+ if($backend != -1 || $show == 'blank') {
+ if($show == 'blank')
+ $backend = $abook->localbackend;
+
+ //printf("<H3 ALIGN=center>%s</H3>\n", $abook->backends[$backend]->sname);
+
+ $res = $abook->list_addr($backend);
+
+ if(is_array($res)) {
+ display_result($res, false);
+ } else {
+ printf("<P ALIGN=center><STRONG>"._("Unable to list addresses from %s").
+ "</STRONG></P>\n", $abook->backends[$backend]->sname);
+ }
+
+ } else {
+ $res = $abook->list_addr();
+ display_result($res, true);
+ }
+
+ } else