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