X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Faddrbook_search.php;h=d3c99c3548a3a90ab54adbfefb7b18ffa738d387;hb=65d0d1624a60633c008fd0b5631ca37713a7ad7c;hp=9557065cf1f74af43075cf0a90a5c0c613912141;hpb=9487c2ff3a9d36af3dc93bd231a6f85fe7a6f762;p=squirrelmail.git
diff --git a/src/addrbook_search.php b/src/addrbook_search.php
index 9557065c..d3c99c35 100644
--- a/src/addrbook_search.php
+++ b/src/addrbook_search.php
@@ -1,244 +1,317 @@
-
+ function bcc_address($addr) {
+ var prefix = "";
+ var pwintype = typeof parent.opener.document.compose;
-';
- printf("
".
- " | %s | %s".
- " | %s",
- _("Name"), _("E-mail"), _("Info"));
-
- if($includesource)
- printf(" | %s", _("Source"));
-
- echo " |
\n";
-
- while(list($undef, $row) = each($res)) {
- printf("".
- "To | ".
- "Cc | ".
- "Bcc".
- " | %s | ".
- " %s ".
- " | %s ",
- ($line % 2) ? " bgcolor=\"$color[0]\"" : "",
- $row["email"], $row["email"], $row["email"],
- $row["name"], $row["email"], $row["email"],
- $row["label"]);
-
- if($includesource)
- printf(" | %s", $row["source"]);
-
- echo " |
\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 '';
}
- /* ================= 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 "';
- } else {
- echo "\n";
- }
+// -->
+
%s\n\n",
- _("No persons matching your search was found"));
- exit;
+ 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' );
+
+ if ($includesource) {
+ echo html_tag( 'th', ' ' . _("Source"), 'left', '', 'width="10%"' );
}
+ echo "\n";
- // Initialize addressbook
- $abook = addressbook_init();
-
- // Create search form
- if($show == 'form') {
- echo "\n";
- } else
-
- // Show personal addressbook
- if($show == 'blank' || !empty($listall)) {
+ echo html_tag( 'tr', '', '', $tr_bgcolor, 'style="white-space: nowrap;"' ) .
+ html_tag( 'td',
+ '"._("To")." | " .
+ '"._("Cc")." | " .
+ '"._("Bcc")."",
+ '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', ' ' .
+ '" . htmlspecialchars($row['email']) . ''
+ , '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 "\n";
+ $line++;
+ }
+ echo '';
+}
+
+/* ================= End of functions ================= */
+
+/** 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);
+
+if (! sqgetGlobalVar('show' , $show)) {
+ $show = '';
+}
+if (! sqgetGlobalVar('query', $query, SQ_POST)) {
+ $query = '';
+}
+if (! sqgetGlobalVar('listall', $listall, SQ_POST)) {
+ unset($listall);
+}
+if (! sqgetGlobalVar('backend', $backend, SQ_POST)) {
+ $backend = '';
+}
+
+displayHtmlHeader();
+
+/** set correct value of $default_charset */
+global $default_charset;
+set_my_charset();
+
+/* Choose correct colors for top and bottom frame */
+if ($show == 'form' && !isset($listall)) {
+ echo '';
+} else {
+ echo '\n";
+}
+
+/* Empty search */
+if (empty($query) && empty($show) && !isset($listall)) {
+ echo html_tag( 'p', '
' .
+ _("No persons matching your search were found"),
+ 'center' ) .
+ "\n\n";
+ exit;
+}
+
+/* Initialize addressbook, show init errors only in bottom frame */
+$showerr=($show=='form' ? false : true);
+$abook = addressbook_init($showerr);
+
+/* Create search form (top frame) */
+if ($show == 'form' && ! isset($listall)) {
+ echo '' . "\n";
+} else {
+ /**
+ * List addresses (bottom frame)
+ * If listall is set, list all entries in selected backend.
+ * If $show is 'blank' (initial call of address book popup) - list
+ * personal address book.
+ */
+ if ($show == 'blank' || isset($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(""._("Unable to list addresses from %s").
- "
\n", $abook->backends[$backend]->sname);
+ echo html_tag( 'p', '' .
+ sprintf(_("Unable to list addresses from %s"),
+ $abook->backends[$backend]->sname) . '' ,
+ 'center' ) . "\n";
}
-
} else {
- $res = $abook->list_addr();
- display_result($res, true);
+ $res = $abook->list_addr();
+ usort($res,'alistcmp');
+ display_result($res, true);
}
- } else
+ } elseif (!empty($query)) {
+ /* Do the search (listall is not set. query is set.)*/
- // 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("
%s:
%s
\n