2
0
mirror of https://github.com/devbridge/jQuery-Autocomplete.git synced 2025-01-05 15:32:10 +00:00

Implement preserve input option. Closes #164.

This commit is contained in:
Tomas Kirda 2014-12-03 14:14:48 -06:00
parent dfd7f44509
commit 54f24951e3
3 changed files with 52 additions and 4 deletions

View File

@ -52,6 +52,7 @@ The standard jquery.autocomplete.js file is around 2.7KB when minified via Closu
* `orientation`: Default `bottom`. Vertical orientation of the displayed suggestions, available values are `auto`, `top`, `bottom`. * `orientation`: Default `bottom`. Vertical orientation of the displayed suggestions, available values are `auto`, `top`, `bottom`.
If set to `auto`, the suggestions will be orientated it the way that place them closer to middle of the view port. If set to `auto`, the suggestions will be orientated it the way that place them closer to middle of the view port.
* `groupBy`: property name of the suggestion `data` object, by which results should be grouped. * `groupBy`: property name of the suggestion `data` object, by which results should be grouped.
* `preserveInput`: if `true`, input value stays the same when navigating over suggestions. Default: `false`.
Autocomplete instance has following methods: Autocomplete instance has following methods:

View File

@ -1,4 +1,4 @@
/*jslint vars: true*/ /*jslint vars: true*/
/*global describe, it, expect, waits, waitsFor, runs, afterEach, spyOn, $*/ /*global describe, it, expect, waits, waitsFor, runs, afterEach, spyOn, $*/
describe('Autocomplete Async', function(){ describe('Autocomplete Async', function(){
@ -39,7 +39,7 @@ describe('Autocomplete Async', function(){
}); });
}); });
describe('Autocomplete Async', function() { describe('Autocomplete Async', function () {
var input = document.createElement('input'), var input = document.createElement('input'),
completeQuery, completeQuery,
mockupSuggestion = { value: 'A', data: 'A' }, mockupSuggestion = { value: 'A', data: 'A' },
@ -688,3 +688,47 @@ describe('Autocomplete', function () {
}); });
}); });
describe('When options.preserveInput is true', function() {
var input = $('<input />'),
instance,
suggestionData = null;
beforeEach(function() {
input.autocomplete({
lookup: [{ value: 'Jamaica', data: 'J' }, { value: 'Jamaica2', data: 'J' }, { value: 'Jamaica3', data: 'J' }],
preserveInput: true,
onSelect: function (suggestion) {
suggestionData = suggestion.data;
}
});
input.val('J');
instance = input.autocomplete();
});
afterEach(function() {
instance.dispose();
});
it('Should NOT change input value when item is selected', function() {
instance.onValueChange();
instance.select(0);
expect(input.val()).toEqual('J');
});
it('Should NOT change input value when move down', function() {
instance.onValueChange();
instance.moveDown();
expect(input.val()).toEqual('J');
});
it('Should NOT change input value when move up', function() {
instance.onValueChange();
instance.moveUp();
expect(input.val()).toEqual('J');
});
});

View File

@ -74,6 +74,7 @@
onSearchStart: noop, onSearchStart: noop,
onSearchComplete: noop, onSearchComplete: noop,
onSearchError: noop, onSearchError: noop,
preserveInput: false,
containerClass: 'autocomplete-suggestions', containerClass: 'autocomplete-suggestions',
tabDisabled: false, tabDisabled: false,
dataType: 'text', dataType: 'text',
@ -890,7 +891,9 @@
$(that.suggestionsContainer).scrollTop(offsetTop - that.options.maxHeight + heightDelta); $(that.suggestionsContainer).scrollTop(offsetTop - that.options.maxHeight + heightDelta);
} }
that.el.val(that.getValue(that.suggestions[index].value)); if (!that.options.preserveInput) {
that.el.val(that.getValue(that.suggestions[index].value));
}
that.signalHint(null); that.signalHint(null);
}, },
@ -901,7 +904,7 @@
that.currentValue = that.getValue(suggestion.value); that.currentValue = that.getValue(suggestion.value);
if (that.currentValue !== that.el.val()) { if (that.currentValue !== that.el.val() && !that.options.preserveInput) {
that.el.val(that.currentValue); that.el.val(that.currentValue);
} }