/// /// // ---------------------------------------------------------------------------------------- // --------------------------------- WEBSITE EXAMPLE -------------------------------------- // ---------- https://www.devbridge.com/sourcery/components/jquery-autocomplete/ ---------- // ---------------------------------------------------------------------------------------- var input = $('#autocomplete'); var options = {}; input.autocomplete('disable'); input.autocomplete('setOptions', options); input.autocomplete().disable(); input.autocomplete().setOptions(options); // Ajax lookup: input.autocomplete({ serviceUrl: '/autocomplete/countries', onSelect: function (suggestion) { alert('You selected: ' + suggestion.value + ', ' + suggestion.data); } }); // Local lookup (no ajax): var countries = [ { value: 'Andorra', data: 'AD' }, // ... { value: 'Zimbabwe', data: 'ZZ' } ]; input.autocomplete({ lookup: countries, onSelect: function (suggestion) { alert('You selected: ' + suggestion.value + ', ' + suggestion.data); } }); // Non standard query/results input.autocomplete({ paramName: 'searchString', transformResult: function(response: any, originalQuery: string): AutocompleteResponse { return { suggestions: $.map(response.myData, function (dataItem) { return {value: dataItem.valueField, data: dataItem.dataField}; }) }; } }); // ---------------------------------------------------------------------------------------- // ------------------------------ TEST INSTANCE METHODS ----------------------------------- // ---------------------------------------------------------------------------------------- input.autocomplete().setOptions(options); input.autocomplete().clear(); input.autocomplete().clearCache(); input.autocomplete().disable(); input.autocomplete().enable(); input.autocomplete().hide(); input.autocomplete().dispose(); // ---------------------------------------------------------------------------------------- // ------------------------------ TEST DEFAULT OPTIONS ------------------------------------ // ---------------------------------------------------------------------------------------- input.autocomplete({ //----------------o AJAX SETTINGS serviceUrl: '/autocomplete/countries', type: 'GET', dataType: 'text', paramName: 'query', params: {}, deferRequestBy: 0, ajaxSettings: {}, //----------------o CONFIG SETTINGS noCache: false, delimiter: "-", onSearchStart(query: string) { console.log("query: ", query); }, onSearchComplete(query: string, suggestions: AutocompleteSuggestion[]) { console.log("query: ", query); console.log("suggestions: ", suggestions); }, onSearchError(query: string, jqXHR: JQueryXHR, textStatus: string, errorThrown: any) { console.log("query: ", query); console.log("jqXHR: ", jqXHR); console.log("textStatus: ", textStatus); console.log("errorThrown: ", errorThrown); }, transformResult(response: any, originalQuery: string): AutocompleteResponse { return { suggestions: [ { value: 'Andorra', data: 'AD' }, // ... { value: 'Zimbabwe', data: 'ZZ' } ] } }, onSelect(suggestion: AutocompleteSuggestion) { console.log("suggestions: ", suggestion); }, minChars: 1, lookupLimit: 1, lookup: [ { value: 'Andorra', data: 'AD' }, // ... { value: 'Zimbabwe', data: 'ZZ' } ], lookupFilter(suggestion: AutocompleteSuggestion, query: string, queryLowercase: string): any { return query !== "query" }, triggerSelectOnValidInput: true, preventBadQueries: true, autoSelectFirst: false, onHide(container: any) { console.log("container: ", container); }, //----------------o PRESENTATION SETTINGS beforeRender(container: any) { console.log("container: ", container); }, formatResult(suggestion: AutocompleteSuggestion, currentValue: string): string { return currentValue; }, groupBy: [ { value: 'Chicago Blackhawks', data: { category: 'NHL' } }, { value: 'Chicago Bulls', data: { category: 'NBA' } } ], maxHeight: 300, width: "auto", zIndex: 9999, appendTo: document.body, forceFixPosition: false, orientation: "bottom", preserveInput: false, showNoSuggestionNotice: false, noSuggestionNotice: "No results", onInvalidateSelection() { console.log("onInvalidateSelection"); }, tabDisabled: false });