diff --git a/views/layout.html b/views/layout.html
index 488f770b..5b785766 100755
--- a/views/layout.html
+++ b/views/layout.html
@@ -100,45 +100,65 @@
diff --git a/views/treeviewer/layout.html b/views/treeviewer/layout.html
index 8f856e8b..9d5252ea 100755
--- a/views/treeviewer/layout.html
+++ b/views/treeviewer/layout.html
@@ -307,6 +307,54 @@
}
}
+// Keep in sync with the equivalent function in views/layout.html
+function update_search(search_element, should_delay, debug_label) {
+ var search_term = search_element.value;
+ var searchbox = $(search_element).closest('.searchbox');
+ var dropdown = $('.search_dropdown', searchbox);
+
+ var searchresult = $('.searchresult', searchbox);
+ if (searchresult && searchresult.attr('data-highlight')) {
+ onezoom.controller.highlight_remove(searchresult.attr('data-highlight'));
+ }
+
+ if (search_term.length==0) {
+ $('.popular_species', dropdown).show();
+ $('.recents', dropdown).show();
+ {{if is_testing:}}console.log("Hiding no_result section of dropdown");{{pass}}
+ $('.no_results', dropdown).hide();
+ $('.search_hits', dropdown).empty();
+ OZui.search_manager.full_search("");
+ $('.searchinput', searchbox).removeClass('waiting_for_search_result');
+ return;
+ }
+
+ const trimmed_search_term = search_term.replace(/ /g,'');
+
+ // never search for a single character
+ // and only search for two characters if enter has been pressed.
+ if (
+ trimmed_search_term.length > 2 ||
+ ((trimmed_search_term.length > 1) && !should_delay)
+ ) {
+ OZui.search_manager.full_search(
+ search_term,
+ function(original_string, actual_search, results) {
+ OZui.searchPopulate(searchbox, original_string, results);
+ },
+ should_delay ? 1000 : 0,
+ function() {
+ {{if is_testing:}}console.log("Search for '" + search_term + "' sent to OneZoom API from " + debug_label + " search");{{pass}}
+
+ if(!($(".searchinput").hasClass('waiting_for_search_result')))
+ {
+ $(".searchinput", searchbox).addClass('waiting_for_search_result'); // switch flag for search to on
+ }
+ }
+ );
+ }
+}
+
function load_into_searchbox(searchbox, result, highlight) {
// Reconstitute compile_searchbox_data() format
var given_name = result[0],
@@ -474,45 +522,12 @@
// https://github.com/uikit/uikit/blob/8313ce565be686952ab6edf8a7caee5fdfcca08c/src/js/core/toggle.js#L138-L151
event.stopPropagation();
})
- .on('keyup', function(event) {
-
- var search_term = this.value;
- var searchbox = $(this).closest('.searchbox');
- var searchresult = $('.searchresult', searchbox);
- var dropdown = $('.search_dropdown', searchbox);
- if (searchresult.attr('data-highlight')) {
- onezoom.controller.highlight_remove(searchresult.attr('data-highlight'));
- }
- if (search_term.length==0) {
- $('.popular_species', dropdown).show();
- $('.recents', dropdown).show();
- {{if is_testing:}}console.log("Hiding no_result section of dropdown");{{pass}}
- $('.no_results', dropdown).hide();
- $('.search_hits', dropdown).empty();
- OZui.search_manager.full_search(""); // this clears the search
- $('.searchinput', searchbox).removeClass('waiting_for_search_result');
- } else {
- //$('.searchinput', searchbox).addClass('waiting_for_search_result');
- var delay_ms = 1000;
- if (event.which == 13) {
- delay_ms = 1; //enter was pressed - don't delay
- }
- if ((search_term.replace(/ /g,'').length > 2)||((search_term.replace(/ /g,'').length > 1)&&(delay_ms == 1))) { // we're never going to search for a single character and we only search for two characters if enter has been pressed.
-
- //if (search_term.replace(/ /g,'').length > 1) { // we're never going to search for a single character
-
- OZui.search_manager.full_search(
- search_term,
- function(original_string, actual_search, results) {
- OZui.searchPopulate(searchbox, original_string, results);
- },
- delay_ms,
- function() {
- {{if is_testing:}}console.log("Search for '" + search_term + "' sent to OneZoom API from advanced search");{{pass}}
- if(!($(".searchinput").hasClass('waiting_for_search_result'))) {
- $(".searchinput", searchbox).addClass('waiting_for_search_result'); // switch flag for search to on
- }});
- }
+ .on('input', function(event) {
+ update_search(this, true, "advanced");
+ })
+ .on('keydown', function(event) {
+ if (event.which == 13) {
+ update_search(this, false, "advanced");
}
});
@@ -715,50 +730,13 @@
// https://github.com/uikit/uikit/blob/8313ce565be686952ab6edf8a7caee5fdfcca08c/src/js/core/toggle.js#L138-L151
event.stopPropagation();
})
- .keyup(function(event) {
- var search_term = this.value;
- var searchbox = $(this).closest('.searchbox');
- var dropdown = $('.search_dropdown', searchbox);
- if (search_term.length==0) {
- $('.popular_species', dropdown).show();
- $('.recents', dropdown).show();
- {{if is_testing:}}console.log("Hiding no_result section of dropdown");{{pass}}
- $('.no_results', dropdown).hide();
- $('.search_hits', dropdown).empty();
- OZui.search_manager.full_search("");
- $('.searchinput', searchbox).removeClass('waiting_for_search_result');
- } else {
- var delay_ms = 1000;
- if (event.which == 13) {
- delay_ms = 1; //enter was pressed - don't delay
- // we should probably catch the case of short string here and give the user a warning - todo.
- }
- if ((search_term.replace(/ /g,'').length > 2)||((search_term.replace(/ /g,'').length > 1)&&(delay_ms == 1))) { // we're never going to search for a single character and we only search for two characters if enter has been pressed.
-
- // we want to test for whether the search is working already or not....
-
- OZui.search_manager.full_search(
- search_term,
- function(original_string, actual_search, results) {
- OZui.searchPopulate(searchbox, original_string, results);
- },
- delay_ms,
- function() {
- {{if is_testing:}}console.log("Search for '" + search_term + "' sent to OneZoom API from basic search");{{pass}}
-
- if(!($(".searchinput").hasClass('waiting_for_search_result')))
- {
- $(".searchinput", searchbox).addClass('waiting_for_search_result'); // switch flag for search to on
- }
- }
- );
-
- }
- else
- {
- // the user should get some comment back here ideally because they tried to search for a single character
- }
+ .on('keydown', function(event) {
+ if (event.which == 13) {
+ update_search(this, false, "basic");
}
+ })
+ .on('input', function(event) {
+ update_search(this, true, "basic");
});
/* Advanced search stuff */