X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Fsearch.php;h=7245baa2d39df690268bb9bf12e83893b04a910a;hb=5fdc77ebc3179b9d1b6bc51d439ee67524610a3c;hp=d385c90b5c7b05321e49c43f421113d430a92dea;hpb=29eb54865a68627bd3dc4934103a1a38f8db4678;p=squirrelmail.git
diff --git a/src/search.php b/src/search.php
index d385c90b..7245baa2 100644
--- a/src/search.php
+++ b/src/search.php
@@ -1,9 +1,9 @@
$tit\n";
}
-displayPageHeader($color, $mailbox);
+// function to get the recent searches and put them in arrays
+
+function get_recent($pref_name, $username, $data_dir) {
+ $array = array ();
+ $recent_count = getPref($data_dir, $username, 'search_memory', 0);
+ $n = 0;
+ for ($x=1;$x<=$recent_count;$x++) {
+ $array[$n] = getPref($data_dir, $username, "$pref_name" . "$x", "");
+ $n++;
+ }
+ return $array;
+}
+
+// function to get the saved searches and put them in arrays
+
+function get_saved($pref_name, $username, $data_dir) {
+ $array = array ();
+ $n = 0;
+ for ($x=1;;$x++) {
+ $array[$n] = getPref($data_dir, $username, "$pref_name" . "$x", "");
+ if ($array[$n] == "") {
+ array_pop($array);
+ return $array;
+ }
+ $n++;
+ }
+ return $array;
+}
+
+// function to update pref file with recent searches
+
+function update_recent($array, $recent_value, $pref_name, $username, $data_dir) {
+ $array = get_recent($pref_name, $username, $data_dir);
+ array_push ($array, $recent_value);
+ array_shift ($array);
+ $recent_count = getPref($data_dir, $username, 'search_memory', 0);
+ $n=0;
+ for ($i=1;$i<=$recent_count;$i++) {
+ setPref($data_dir, $username, "$pref_name" . "$i", $array[$n]);
+ $n++;
+ }
+}
+
+// function to "forget" a recent search
+
+function forget_recent($forget_index, $username, $data_dir) {
+ $what_array = get_recent("search_what", $username, $data_dir);
+ $where_array = get_recent("search_where", $username, $data_dir);
+ $folder_array = get_recent("search_folder", $username, $data_dir);
+ array_splice($what_array, $forget_index, 1);
+ array_splice($where_array, $forget_index, 1);
+ array_splice($folder_array, $forget_index, 1);
+ array_unshift($what_array, "");
+ array_unshift($where_array, "");
+ array_unshift($folder_array, "");
+ $recent_count = getPref($data_dir, $username, 'search_memory', 0);
+ $n=0;
+ for ($i=1;$i<=$recent_count;$i++) {
+ setPref($data_dir, $username, "search_what" . "$i", $what_array[$n]);
+ setPref($data_dir, $username, "search_where" . "$i", $where_array[$n]);
+ setPref($data_dir, $username, "search_folder" . "$i", $folder_array[$n]);
+ $n++;
+ }
+
+// function to delete a saved search
+}
+function delete_saved($delete_index, $username, $data_dir) {
+ $saved_what_array = get_saved("saved_what", $username, $data_dir);
+ $saved_where_array = get_saved("saved_where", $username, $data_dir);
+ $saved_folder_array = get_saved("saved_folder", $username, $data_dir);
+ array_splice($saved_what_array, $delete_index, 1);
+ array_splice($saved_where_array, $delete_index, 1);
+ array_splice($saved_folder_array, $delete_index, 1);
+ $n=0;
+ $saved_count = count($saved_what_array);
+ $last_element = $saved_count + 1;
+ if ($last_element < 1) {
+ for ($i=1;$i<=$saved_count;$i++) {
+ setPref($data_dir, $username, "saved_what" . "$i", $saved_what_array[$n]);
+ setPref($data_dir, $username, "saved_where" . "$i", $saved_where_array[$n]);
+ setPref($data_dir, $username, "saved_folder" . "$i", $saved_folder_array[$n]);
+ $n++;
+ }
+ }
+ removePref($data_dir, $username, "saved_what" . "$last_element");
+ removePref($data_dir, $username, "saved_where" . "$last_element");
+ removePref($data_dir, $username, "saved_folder" . "$last_element");
+}
+
+// function to save a search from recent to saved
+
+function save_recent($save_index, $username, $data_dir) {
+ $what_array = get_recent("search_what", $username, $data_dir);
+ $where_array = get_recent("search_where", $username, $data_dir);
+ $folder_array = get_recent("search_folder", $username, $data_dir);
+ $saved_what_once = array_slice($what_array, $save_index, 1);
+ $saved_where_once = array_slice($where_array, $save_index, 1);
+ $saved_folder_once = array_slice($folder_array, $save_index, 1);
+ $saved_array = get_saved("saved_what", $username, $data_dir);
+ $saved_count = (count($saved_array) + 1);
+ setPref($data_dir, $username, "saved_what" . "$saved_count", $saved_what_once[0]);
+ setPref($data_dir, $username, "saved_where" . "$saved_count", $saved_where_once[0]);
+ setPref($data_dir, $username, "saved_folder" . "$saved_count", $saved_folder_once[0]);
+}
+
+
+
+/* ------------------------ main ------------------------ */
+
+// reset these arrays on each page load just in case
+
+$what_array = array ();
+$where_array = array ();
+$folder_array = array ();
+$saved_what_array = array ();
+$saved_where_array = array ();
+$saved_folder_array = array ();
+$search_all = "none";
+
+// get mailbox names
+
$imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0);
+$boxes = sqimap_mailbox_list($imapConnection);
+
+
+// set current mailbox to INBOX if none was selected or if page
+// was called to search all folders.
+
+if ($mailbox == 'None' || $mailbox == "" ) {
+ $mailbox = $boxes[0]['unformatted'];
+}
+if ($mailbox == "All Folders") {
+ $search_all = "all";
+}
+
+// page headers
+displayPageHeader($color, $mailbox);
+
+// if the page is called from a search link or button update recent values
+// in pref files here
+
+if ($submit == "Search" && !empty($what)) {
+ update_recent($what_array, $what, "search_what", $username, $data_dir);
+ update_recent($where_array, $where, "search_where", $username, $data_dir);
+ update_recent($folder_array, $mailbox, "search_folder", $username, $data_dir);
+}
+// if the page is called from a "forget recent" link remove search from pref file
+elseif ($submit == "forget") {
+ forget_recent($count, $username, $data_dir);
+}
+// if the page is called from a "save recent" link add search to saved searches
+elseif ($submit == "save") {
+ save_recent($count, $username, $data_dir);
+}
+elseif ($submit == "delete") {
+ delete_saved($count, $username, $data_dir);
+}
+// if the page is called from a "delete saved" link delete saved search
do_hook('search_before_form');
-echo "
\n".
- "
\n".
- " |
'. - - " |