/**
* addrbook_search.php
*
- * Copyright (c) 1999-2002 The SquirrelMail Project Team
+ * Copyright (c) 1999-2005 The SquirrelMail Project Team
* Licensed under the GNU GPL. For full terms see the file COPYING.
*
* Handle addressbook searching in the popup window.
* addrbook_search_html.html -- If you change one,
* change the other one too!
*
- * $Id$
+ * @version $Id$
+ * @package squirrelmail
+ * @subpackage addressbook
*/
-/*****************************************************************/
-/*** THIS FILE NEEDS TO HAVE ITS FORMATTING FIXED!!! ***/
-/*** PLEASE DO SO AND REMOVE THIS COMMENT SECTION. ***/
-/*** + Base level indent should begin at left margin, as ***/
-/*** the require_once below looks. ***/
-/*** + All identation should consist of four space blocks ***/
-/*** + Tab characters are evil. ***/
-/*** + all comments should use "slash-star ... star-slash" ***/
-/*** style -- no pound characters, no slash-slash style ***/
-/*** + FLOW CONTROL STATEMENTS (if, while, etc) SHOULD ***/
-/*** ALWAYS USE { AND } CHARACTERS!!! ***/
-/*** + Please use ' instead of ", when possible. Note " ***/
-/*** should always be used in _( ) function calls. ***/
-/*** Thank you for your help making the SM code more readable. ***/
-/*****************************************************************/
-
-require_once('../src/validate.php');
-
- // Function to include JavaScript code
- function insert_javascript() {
-?>
-<SCRIPT LANGUAGE="Javascript"><!--
+/**
+ * Path for SquirrelMail required files.
+ * @ignore
+ */
+define('SM_PATH','../');
-function to_and_close($addr) {
- to_address($addr);
- parent.close();
-}
+/** SquirrelMail required files. */
+require_once(SM_PATH . 'include/validate.php');
+require_once(SM_PATH . 'functions/strings.php');
+require_once(SM_PATH . 'functions/global.php');
+require_once(SM_PATH . 'functions/html.php');
+require_once(SM_PATH . 'functions/forms.php');
-function to_address($addr) {
- var prefix = "";
- var pwintype = typeof parent.opener.document.compose;
+/** lets get the global vars we may need */
+sqgetGlobalVar('key', $key, SQ_COOKIE);
+sqgetGlobalVar('username', $username, SQ_SESSION);
+sqgetGlobalVar('onetimepad',$onetimepad, SQ_SESSION);
+sqgetGlobalVar('base_uri', $base_uri, SQ_SESSION);
- $addr = $addr.replace(/ {1,35}$/, "");
+sqgetGlobalVar('show' , $show);
+sqgetGlobalVar('query', $query, SQ_POST);
+sqgetGlobalVar('listall', $listall, SQ_POST);
+sqgetGlobalVar('backend', $backend, SQ_POST);
- if(pwintype != "undefined" ) {
- if ( parent.opener.document.compose.send_to.value ) {
- prefix = ", ";
- parent.opener.document.compose.send_to.value =
- parent.opener.document.compose.send_to.value + ", " + $addr;
+/**
+ * Function to include JavaScript code
+ * @return void
+ */
+function insert_javascript() {
+ ?>
+ <script language="Javascript"><!--
- } else {
- parent.opener.document.compose.send_to.value = $addr;
+ function to_and_close($addr) {
+ to_address($addr);
+ parent.close();
}
- }
-}
-function cc_address($addr) {
- var prefix = "";
- var pwintype = typeof parent.opener.document.compose;
+ function to_address($addr) {
+ var prefix = "";
+ var pwintype = typeof parent.opener.document.compose;
- $addr = $addr.replace(/ {1,35}$/, "");
+ $addr = $addr.replace(/ {1,35}$/, "");
- if(pwintype != "undefined" ) {
- if ( parent.opener.document.compose.send_to_cc.value ) {
- prefix = ", ";
- parent.opener.document.compose.send_to_cc.value =
- parent.opener.document.compose.send_to_cc.value + ", " + $addr;
- } else {
- parent.opener.document.compose.send_to_cc.value = $addr;
+ if (pwintype != "undefined") {
+ if (parent.opener.document.compose.send_to.value) {
+ prefix = ", ";
+ parent.opener.document.compose.send_to.value =
+ parent.opener.document.compose.send_to.value + ", " + $addr;
+ } else {
+ parent.opener.document.compose.send_to.value = $addr;
+ }
+ }
}
- }
-}
-function bcc_address($addr) {
- var prefix = "";
- var pwintype = typeof parent.opener.document.compose;
+ function cc_address($addr) {
+ var prefix = "";
+ var pwintype = typeof parent.opener.document.compose;
- $addr = $addr.replace(/ {1,35}$/, "");
+ $addr = $addr.replace(/ {1,35}$/, "");
- if(pwintype != "undefined" ) {
- if ( parent.opener.document.compose.send_to_bcc.value ) {
- prefix = ", ";
- parent.opener.document.compose.send_to_bcc.value =
- parent.opener.document.compose.send_to_bcc.value + ", " + $addr;
- } else {
- parent.opener.document.compose.send_to_bcc.value = $addr;
+ if (pwintype != "undefined") {
+ if (parent.opener.document.compose.send_to_cc.value) {
+ prefix = ", ";
+ parent.opener.document.compose.send_to_cc.value =
+ parent.opener.document.compose.send_to_cc.value + ", " + $addr;
+ } else {
+ parent.opener.document.compose.send_to_cc.value = $addr;
+ }
+ }
}
- }
-}
-// --></SCRIPT>
+ function bcc_address($addr) {
+ var prefix = "";
+ var pwintype = typeof parent.opener.document.compose;
-<?php
- } // End of included JavaScript
-
-
- // List search results
- function display_result($res, $includesource = true) {
- global $color;
-
- if(sizeof($res) <= 0) return;
-
- insert_javascript();
-
- $line = 0;
- echo '<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"));
-
- echo "</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"]);
-
- echo "</TR>\n";
- $line++;
+ $addr = $addr.replace(/ {1,35}$/, "");
+
+ if (pwintype != "undefined") {
+ if (parent.opener.document.compose.send_to_bcc.value) {
+ prefix = ", ";
+ parent.opener.document.compose.send_to_bcc.value =
+ parent.opener.document.compose.send_to_bcc.value + ", " + $addr;
+ } else {
+ parent.opener.document.compose.send_to_bcc.value = $addr;
+ }
}
- echo '</TABLE>';
}
- /* ================= End of functions ================= */
-
- require_once('../functions/array.php');
- require_once('../functions/strings.php');
- require_once('../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";
- }
+// --></script>
+<?php
+} /* End of included JavaScript */
+
+
+/**
+ * List search results
+ * @param array $res Array of search results
+ * @param bool $includesource [Default=true]
+ * @return void
+ */
+function display_result($res, $includesource = true) {
+ global $color;
+
+ if(sizeof($res) <= 0) return;
+
+ insert_javascript();
+
+ $line = 0;
+ echo html_tag( 'table', '', 'center', '', 'border="0" width="98%"' ) .
+ html_tag( 'tr', '', '', $color[9] ) .
+ html_tag( 'th', ' ', 'left' ) .
+ html_tag( 'th', ' ' . _("Name"), 'left' ) .
+ html_tag( 'th', ' ' . _("E-mail"), 'left' ) .
+ html_tag( 'th', ' ' . _("Info"), 'left' );
- // 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;
+ if ($includesource) {
+ echo html_tag( 'th', ' ' . _("Source"), 'left', 'width="10%"' );
}
+ echo "</tr>\n";
- // Initialize addressbook
- $abook = addressbook_init();
-
- // Create search form
- if($show == 'form') {
- echo "<FORM NAME=sform TARGET=abookres ACTION=\"$PHP_SELF\" METHOD=\"POST\">\n";
- echo '<TABLE BORDER="0" WIDTH="100%" HEIGHT="100%">';
- echo "<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";
+ while (list($undef, $row) = each($res)) {
+ $email = htmlspecialchars(addcslashes(AddressBook::full_address($row), "'"), ENT_QUOTES);
+ if ($line % 2) {
+ $tr_bgcolor = $color[12];
} else {
- print "<INPUT TYPE=hidden NAME=backend VALUE=-1>\n";
+ $tr_bgcolor = $color[4];
+ }
+ echo html_tag( 'tr', '', '', $tr_bgcolor, 'style="white-space: nowrap;"' ) .
+ html_tag( 'td',
+ '<small><a href="javascript:to_address(' .
+ "'" . $email . "');\">"._("To")."</a> | " .
+ '<a href="javascript:cc_address(' .
+ "'" . $email . "');\">"._("Cc")."</a> | " .
+ '<a href="javascript:bcc_address(' .
+ "'" . $email . "');\">"._("Bcc")."</a></small>",
+ 'center', '', 'valign="top" width="5%" style="white-space: nowrap;"' ) .
+ html_tag( 'td', ' ' . htmlspecialchars($row['name']), 'left', '', 'valign="top" style="white-space: nowrap;"' ) .
+ html_tag( 'td', ' ' .
+ '<a href="javascript:to_and_close(' .
+ "'" . $email . "');\">" . htmlspecialchars($row['email']) . '</a>'
+ , 'left', '', 'valign="top"' ) .
+ html_tag( 'td', htmlspecialchars($row['label']), 'left', '', 'valign="top" style="white-space: nowrap;"' );
+ if ($includesource) {
+ echo html_tag( 'td', ' ' . $row['source'], 'left', '', 'valign="top" style="white-space: nowrap;"' );
+ }
+
+ echo "</tr>\n";
+ $line++;
+ }
+ echo '</table>';
+}
+
+/* ================= End of functions ================= */
+
+require_once('../functions/strings.php');
+require_once('../functions/addressbook.php');
+
+displayHtmlHeader();
+
+/** set correct value of $default_charset */
+global $default_charset;
+set_my_charset();
+
+/* Initialize vars */
+if (!isset($query)) { $query = ''; }
+if (!isset($show)) { $show = ''; }
+if (!isset($backend)) { $backend = ''; }
+
+/* Choose correct colors for top and bottom frame */
+if ($show == 'form' && !isset($listall)) {
+ echo '<body text="' . $color[6] . '" bgcolor="' . $color[3] . '" ' .
+ 'link="' . $color[6] . '" vlink="' . $color[6] . '" ' .
+ 'alink="' . $color[6] . '" ' .
+ 'OnLoad="document.sform.query.focus();">';
+} else {
+ echo '<body text="' . $color[8] . '" bgcolor="' . $color[4] . '" ' .
+ 'link="' . $color[7] . '" vlink="' . $color[7] . '" ' .
+ 'alink="' . $color[7] . "\">\n";
+}
+
+/* Empty search */
+if (empty($query) && empty($show) && empty($listall)) {
+ echo html_tag( 'p', '<br />' .
+ _("No persons matching your search were found"),
+ 'center' ) .
+ "\n</body></html>\n";
+ exit;
+}
+
+/* Initialize addressbook, show init errors only in bottom frame */
+$showerr=($show=='form' ? false : true);
+$abook = addressbook_init($showerr);
+
+/* Create search form */
+if ($show == 'form' && empty($listall)) {
+ echo '<form name="sform" target="abookres" action="addrbook_search.php'.
+ '" method="post">' . "\n" .
+ html_tag( 'table', '', '', '', 'border="0" width="100%" height="100%"' ) .
+ html_tag( 'tr' ) .
+ html_tag( 'td', ' <strong>' . _("Search for") . "</strong>\n", 'left', '', 'style="white-space: nowrap;" valign="middle" width="10%"' ) .
+ html_tag( 'td', '', 'left', '', '' ) .
+ addInput('query', $query, 28);
+
+ /* List all backends to allow the user to choose where to search */
+ if ($abook->numbackends > 1) {
+ echo '<strong>' . _("in") . '</strong> '."\n".
+ $selopts['-1'] = _("All address books");
+
+ $ret = $abook->get_backend_list();
+ while (list($undef,$v) = each($ret)) {
+ $selopts[$v->bnum] = $v->sname;
}
-
- 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)) {
+ echo addSelect('backend', $selopts, '-1', TRUE);
+ } else {
+ echo addHidden('backend', '-1');
+ }
+
+ echo '</td></tr>' .
+ html_tag( 'tr',
+ html_tag( 'td', '', 'left' ) .
+ html_tag( 'td',
+ '<input type="submit" value="' . _("Search") . '" name="show" />' .
+ ' | <input type="submit" value="' . _("List all") .
+ '" name="listall" />' . "\n" .
+ ' | <input type="button" value="' . _("Close") .
+ '" onclick="parent.close();" />' . "\n" ,
+ 'left' )
+ ) .
+ '</table></form>' . "\n";
+} else {
+
+ /* Show personal addressbook */
+ if ($show == 'blank' && empty($listall)) {
if($backend != -1 || $show == 'blank') {
- if($show == 'blank')
+ if ($show == 'blank') {
$backend = $abook->localbackend;
-
+ }
$res = $abook->list_addr($backend);
if(is_array($res)) {
+ usort($res,'alistcmp');
display_result($res, false);
} else {
- printf("<P ALIGN=center><STRONG>"._("Unable to list addresses from %s").
- "</STRONG></P>\n", $abook->backends[$backend]->sname);
+ echo html_tag( 'p', '<strong>' .
+ sprintf(_("Unable to list addresses from %s"),
+ $abook->backends[$backend]->sname) . '</strong>' ,
+ 'center' ) . "\n";
}
-
} else {
- $res = $abook->list_addr();
- display_result($res, true);
+ $res = $abook->list_addr();
+ usort($res,'alistcmp');
+ display_result($res, true);
}
- } else
-
- // Do the search
- if(!empty($query) && empty($listall)) {
-
- if($backend == -1) {
- $res = $abook->s_search($query);
- } else {
- $res = $abook->s_search($query, $backend);
- }
-
- if(!is_array($res)) {
- printf("<P ALIGN=center><B><BR>%s:<br>%s</B></P>\n</BODY></HTML>\n",
- _("Your search failed with the following error(s)"),
- $abook->error);
- exit;
+ } else {
+ if( !empty( $listall ) ){
+ $query = '*';
}
-
- if(sizeof($res) == 0) {
- printf("<P ALIGN=center><BR><B>%s.</B></P>\n</BODY></HTML>\n",
- _("No persons matching your search was found"));
- exit;
+
+ /* Do the search */
+ if (!empty($query)) {
+
+ if($backend == -1) {
+ $res = $abook->s_search($query);
+ } else {
+ $res = $abook->s_search($query, $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";
+ exit;
+ }
+
+ if (sizeof($res) == 0) {
+ echo html_tag( 'p', '<br /><b>' .
+ _("No persons matching your search were found") . "</b>\n" ,
+ 'center' ) .
+ "\n</body></html>\n";
+ exit;
+ }
+
+ display_result($res);
}
-
- display_result($res);
}
-
- echo "</BODY></HTML>\n";
-
+
+}
?>
+</body></html>
\ No newline at end of file