/**
* 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
*/
-require_once('../src/validate.php');
-require_once('../functions/strings.php');
+/**
+ * Path for SquirrelMail required files.
+ * @ignore
+ */
+define('SM_PATH','../');
+
+/** 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 include JavaScript code */
+/** 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);
+
+sqgetGlobalVar('show' , $show);
+sqgetGlobalVar('query', $query, SQ_POST);
+sqgetGlobalVar('listall', $listall, SQ_POST);
+sqgetGlobalVar('backend', $backend, SQ_POST);
+
+/**
+ * Function to include JavaScript code
+ * @return void
+ */
function insert_javascript() {
?>
- <SCRIPT LANGUAGE="Javascript"><!--
+ <script language="Javascript"><!--
function to_and_close($addr) {
to_address($addr);
}
}
-// --></SCRIPT>
+// --></script>
<?php
} /* End of included JavaScript */
-/* List search results */
+/**
+ * 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 '<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");
+ 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' );
if ($includesource) {
- echo '<TH ALIGN=left WIDTH="10%"> ' . _("Source");
- }
- echo "</TR>\n";
-
+ echo html_tag( 'th', ' ' . _("Source"), 'left', 'width="10%"' );
+ }
+ echo "</tr>\n";
+
while (list($undef, $row) = each($res)) {
- echo '<tr';
- if ($line % 2) { echo ' bgcolor="' . $color[0] . '"'; }
- echo ' nowrap><td valign=top nowrap align=center width="5%">' .
- '<small><a href="javascript:to_address(' .
- "'" . $row['email'] . "');\">To</A> | " .
- '<a href="javascript:cc_address(' .
- "'" . $row['email'] . "');\">Cc</A> | " .
- '<a href="javascript:bcc_address(' .
- "'" . $row['email'] . "');\">Bcc</A></small>" .
- '<td nowrap valign=top> ' .
- $row['name'] . '<td valign=top>' .
+ $email = htmlspecialchars(addcslashes(AddressBook::full_address($row), "'"), ENT_QUOTES);
+ if ($line % 2) {
+ $tr_bgcolor = $color[12];
+ } else {
+ $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(' .
- "'" . $row['email'] . "');\">" . $row['email'] . '</A>' .
- '<td valign=top nowrap>' . $row['label'];
+ "'" . $email . "');\">" . htmlspecialchars($row['email']) . '</a>'
+ , 'left', '', 'valign="top"' ) .
+ html_tag( 'td', htmlspecialchars($row['label']), 'left', '', 'valign="top" style="white-space: nowrap;"' );
if ($includesource) {
- echo '<td nowrap valign=top> ' . $row['source'];
+ echo html_tag( 'td', ' ' . $row['source'], 'left', '', 'valign="top" style="white-space: nowrap;"' );
}
- echo "</TR>\n";
+ echo "</tr>\n";
$line++;
}
- echo '</TABLE>';
+ echo '</table>';
}
/* ================= End of functions ================= */
-
-require_once('../functions/array.php');
+
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 = ''; }
/* 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] . '" ' .
+ 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";
+ 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 '<P ALIGN=center><BR>' .
- _("No persons matching your search was found") .
- "</P>\n</BODY></HTML>\n",
+ echo html_tag( 'p', '<br />' .
+ _("No persons matching your search were found"),
+ 'center' ) .
+ "\n</body></html>\n";
exit;
}
-/* Initialize addressbook */
-$abook = addressbook_init();
+/* 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" .
- '<TABLE BORDER="0" WIDTH="100%" HEIGHT="100%">' .
- '<TR><TD NOWRAP VALIGN=middle align=left width=10%>' . "\n" .
- ' <STRONG>' . _("Search for") . "</STRONG>\n" .
- ' </TD><TD align=left><INPUT TYPE=text NAME=query VALUE="' . htmlspecialchars($query) .
- "\" SIZE=28>\n";
+ 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> <SELECT NAME=backend>'."\n".
- '<OPTION VALUE=-1 SELECTED>' . _("All address books") . "\n";
+ echo '<strong>' . _("in") . '</strong> '."\n".
+ $selopts['-1'] = _("All address books");
+
$ret = $abook->get_backend_list();
while (list($undef,$v) = each($ret)) {
- echo '<OPTION VALUE=' . $v->bnum . '>' . $v->sname . "\n";
+ $selopts[$v->bnum] = $v->sname;
}
- echo "</SELECT>\n";
+ echo addSelect('backend', $selopts, '-1', TRUE);
} else {
- echo '<INPUT TYPE=hidden NAME=backend VALUE=-1>' . "\n";
+ echo addHidden('backend', '-1');
}
-
- echo '</TD></TR><TR><TD></TD><TD align=left>'.
- '<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" .
- '</TD></TR></TABLE></FORM>' . "\n";
+
+ 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 */
usort($res,'alistcmp');
display_result($res, false);
} else {
- echo '<P ALIGN=center><STRONG>' .
- sprintf(_("Unable to list addresses from %s"),
- $abook->backends[$backend]->sname) .
- '</STRONG></P>' . "\n";
+ echo html_tag( 'p', '<strong>' .
+ sprintf(_("Unable to list addresses from %s"),
+ $abook->backends[$backend]->sname) . '</strong>' ,
+ 'center' ) . "\n";
}
} else {
$res = $abook->list_addr();
/* 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 '<P ALIGN=center><B><BR>' .
- _("Your search failed with the following error(s)") .
- ':<br>' . $abook->error . "</B></P>\n</BODY></HTML>\n";
+ 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 '<P ALIGN=center><BR><B>' .
- _("No persons matching your search was found") .
- ".</B></P>\n</BODY></HTML>\n";
+ echo html_tag( 'p', '<br /><b>' .
+ _("No persons matching your search were found") . "</b>\n" ,
+ 'center' ) .
+ "\n</body></html>\n";
exit;
}
-
+
display_result($res);
}
}
-
-}
-echo "</BODY></HTML>\n";
-
+}
?>
+</body></html>
\ No newline at end of file