From aeee6636fd1be323ced89c264044c86d1f086424 Mon Sep 17 00:00:00 2001 From: atg Date: Sat, 27 Oct 2007 22:17:53 +0000 Subject: [PATCH] Initial version of the Browser Search plugin (with search suggestions\!) git-svn-id: file:///home/shish/svn/shimmie2/trunk@575 7f39781d-f577-437e-ae19-be835c7a54ca --- contrib/browser_search/main.php | 114 ++++++++++++++++++++++++++++++++ 1 file changed, 114 insertions(+) create mode 100755 contrib/browser_search/main.php diff --git a/contrib/browser_search/main.php b/contrib/browser_search/main.php new file mode 100755 index 00000000..32ae7480 --- /dev/null +++ b/contrib/browser_search/main.php @@ -0,0 +1,114 @@ +) from the 'tagger' extention - Used with permission + * Link: http://atravelinggeek.com/ + * License: GPLv2 + * Description: Allows the user to add a browser 'plugin' to search the site with real-time suggestions + * Version 0.1c + * October 26, 2007 + * + */ + +class BrowserSearch extends Extension { + public function receive_event($event) { + global $page; + global $config; + + if(is_a($event, 'InitExtEvent')) { + $config->set_default_string("search_suggestions_results_order", 'a'); + } + + // Add in header code to let the browser know that the search plugin exists + if(is_a($event, 'PageRequestEvent')) { + // We need to build the data for the header + global $config; + $search_title = $config->get_string('title'); + $search_file_url = make_link('browser_search/please_dont_use_this_tag_as_it_would_break_stuff__search.xml'); + $page->add_header(""); + } + + // The search.xml file that is generated on the fly + if(is_a($event, 'PageRequestEvent') && ($event->page_name == "browser_search") && $event->get_arg(0) == "please_dont_use_this_tag_as_it_would_break_stuff__search.xml") { + // First, we need to build all the variables we'll need + + $search_title = $config->get_string('title'); + //$search_form_url = $config->get_string('base_href'); //make_link('post/list'); + $search_form_url = make_link('post/list/{searchTerms}'); + $suggenton_url = make_link('browser_search/')."{searchTerms}"; + + + // Now for the XML + $xml = " + + $search_title + UTF-8 +  + $search_form_url + + + + + + "; + + // And now to send it to the browser + $page->set_mode("data"); + $page->set_type("text/xml"); + $page->set_data($xml); + } else if(is_a($event, 'PageRequestEvent') && ($event->page_name == "browser_search") && !$config->get_bool("disable_search_suggestions")) { // We need to return results! + global $database; + + // We have to build some json stuff + $tag_search = $event->get_arg(0); + + // Now to get DB results + if($config->get_string("search_suggestions_results_order") == "a") { + $tags = $database->execute("SELECT tag FROM tags WHERE tag LIKE ? AND count > 0 ORDER BY tag ASC LIMIT 30",array($tag_search."%")); + } else { + $tags = $database->execute("SELECT tag FROM tags WHERE tag LIKE ? AND count > 0 ORDER BY count DESC LIMIT 30",array($tag_search."%")); + } + + + // And to do stuff with it. We want our output to look like: + // ["shimmie",["shimmies","shimmy","shimmie","21 shimmies","hip shimmies","skea shimmies"],[],[]] + $json_tag_list = ""; + + $tags_array = array(); + foreach($tags as $tag) { + array_push($tags_array,$tag['tag']); + } + + + $json_tag_list .= implode("\",\"", $tags_array); +// $json_tag_list = implode($tags_array,", "); +// $json_tag_list = "\"".implode($tags_array,"\", \"")."\""; + + + // And now for the final output + $json_string = "[\"$tag_search\",[\"$json_tag_list\"],[],[]]"; + $page->set_mode("data"); + $page->set_data($json_string); + } + + if(is_a($event, 'SetupBuildingEvent')) { + + $sort_by = array(); + $sort_by['Alphabetical'] = 'a'; + $sort_by['Tag Count'] = 't'; + + $sb = new SetupBlock("Browser Search"); + $sb->add_bool_option("disable_search_suggestions", "Disable search suggestions when using browser-based search: "); + $sb->add_label("
"); + $sb->add_choice_option("search_suggestions_results_order", $sort_by, "Sort the suggestions by:"); + $event->panel->add_block($sb); + } + + } + + +} +add_event_listener(new BrowserSearch()); +?> \ No newline at end of file