/* * @file Manages all advanced search form logic. */ var searchGroups = $("div#search-groups"); /* * Load all advanced search form libraries. */ function loadInputFieldWidgets(){ $(".search-group input#date-last-modified").datepicker(); $(".search-group input#date-created").datepicker(); $(".search-group input#autocomplete").autocomplete({ source: function(request, response){ var matcher = new RegExp( $.ui.autocomplete.escapeRegex(request.term), "i"); response($.grep(AUTOCOMPLETE_LANGUAGES, function(item){ return matcher.test(item); })); } }); }; loadInputFieldWidgets(); /* * Set all advanced search form button callbacks. */ (function setSearchFormCallbacks(){ // Create a new search group, and update the `#sidebar` checklist. $("button#add-group").click(function(){ $("div#sidebar input[type=checkbox]").prop("checked", false); searchGroups.children("#selected").removeAttr("id"); var searchGroup = $("
", { class : "search-group", id : "selected" }); searchGroups.append( searchGroup.append(createSearchGroupInput("language", "languages"))); loadInputFieldWidgets(); $("div#sidebar input[type=checkbox]#language").prop("checked", true); searchGroups[0].scrollTop = searchGroups[0].scrollHeight; }); // Remove the currently selected group if it's not the only one, and mark // one of its siblings as selected. $("button#remove-group").click(function(){ var currentGroup = $("div.search-group#selected"); if($("div.search-group").length == 1) return; else { var nextGroup = currentGroup.prev(); if(nextGroup.size() == 0) nextGroup = currentGroup.next(); } currentGroup.remove(); nextGroup.click(); }); // Select a search group, and update the `#sidebar` checklist accordingly. $(document).on("click", "div.search-group", function(){ searchGroups.children("#selected").removeAttr("id"); $(this).attr("id", "selected"); $("div#sidebar input[type=checkbox]").prop("checked", false); $(this).find("input[type=text]").each(function(){ var checkBoxSelector = "div#sidebar input[type=checkbox]"; $(checkBoxSelector + "#" + $(this).attr("class").split(" ")[0]). prop("checked", true); }) }); // Toggle the presence of an input field. $("div#sidebar input[type=checkbox]").click(function(){ var fieldId = $(this).prop("id"); if($(this).is(":checked")){ $("div.search-group#selected").append( $.parseHTML(createSearchGroupInput( fieldId, $(this).next("label").children("div"). text()))); loadInputFieldWidgets(); if(fieldId.slice(0, 4) == "date") $(".search-group#selected ." + fieldId).datepicker(); } else { if($(".search-group#selected").children("div").length > 1) $(".search-group#selected #" + fieldId).remove() else $(this).prop("checked", true); } searchGroups[0].scrollTop = searchGroups[0].scrollHeight; }); $("div#advanced-search button#submit").click(function(){ $("div#advanced-search").hide(); advancedSearchButton.removeClass("clicked"); assembleQuery(); populateResults(); }) var previousAdvancedQuery = ""; var searchBar = $("form#search-bar input[name=query]"); window.setInterval(function(){ var currentQuery = assembleQuery(); if(currentQuery != previousAdvancedQuery){ previousAdvancedQuery = currentQuery; searchBar.val(assembleQuery()); } }, 1e3 / 15); }()); /* * Return an HTML string representing a new input field div in a search group. * * @param fieldId The id of the input field div, and its child elements. * @param name The name to display next to the input field. */ function createSearchGroupInput(fieldId, name){ var fieldHTML = [ "