mirror of
https://github.com/devbridge/jQuery-Autocomplete.git
synced 2024-11-25 22:27:39 +00:00
Merge branch 'develop'
Conflicts: readme.md
This commit is contained in:
commit
f2aef10a5b
@ -33,6 +33,7 @@ The standard jquery.autocomplete.js file is around 2.7KB when minified via Closu
|
|||||||
* `onSearchStart`: `function (query) {}` called before ajax request. `this` is bound to input element.
|
* `onSearchStart`: `function (query) {}` called before ajax request. `this` is bound to input element.
|
||||||
* `onSearchComplete`: `function (query) {}` called after ajax response is processed. `this` is bound to input element.
|
* `onSearchComplete`: `function (query) {}` called after ajax response is processed. `this` is bound to input element.
|
||||||
* `onSearchError`: `function (query, jqXHR, textStatus, errorThrown) {}` called if ajax request fails. `this` is bound to input element.
|
* `onSearchError`: `function (query, jqXHR, textStatus, errorThrown) {}` called if ajax request fails. `this` is bound to input element.
|
||||||
|
* `beforeRender`: `function (container) {}` called before displaying the suggestions. You may manipulate suggestions DOM before it is displayed.
|
||||||
* `tabDisabled`: Default `false`. Set to true to leave the cursor in the input field after the user tabs to select a suggestion.
|
* `tabDisabled`: Default `false`. Set to true to leave the cursor in the input field after the user tabs to select a suggestion.
|
||||||
* `paramName`: Default `query`. The name of the request parameter that contains the query.
|
* `paramName`: Default `query`. The name of the request parameter that contains the query.
|
||||||
* `transformResult`: `function(response, originalQuery) {}` called after the result of the query is ready. Converts the result into response.suggestions format.
|
* `transformResult`: `function(response, originalQuery) {}` called after the result of the query is ready. Converts the result into response.suggestions format.
|
||||||
|
@ -56,6 +56,7 @@ $(function () {
|
|||||||
// Initialize autocomplete with local lookup:
|
// Initialize autocomplete with local lookup:
|
||||||
$('#autocomplete').autocomplete({
|
$('#autocomplete').autocomplete({
|
||||||
lookup: countriesArray,
|
lookup: countriesArray,
|
||||||
|
minChars: 0,
|
||||||
onSelect: function (suggestion) {
|
onSelect: function (suggestion) {
|
||||||
$('#selection').html('You selected: ' + suggestion.value + ', ' + suggestion.data);
|
$('#selection').html('You selected: ' + suggestion.value + ', ' + suggestion.data);
|
||||||
}
|
}
|
||||||
|
@ -473,4 +473,27 @@ describe('Autocomplete', function () {
|
|||||||
|
|
||||||
expect(width).toBeGreaterThan(0);
|
expect(width).toBeGreaterThan(0);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('Should call beforeRender and pass container jQuery object', function () {
|
||||||
|
var element = document.createElement('input'),
|
||||||
|
input = $(element),
|
||||||
|
instance,
|
||||||
|
elementCount,
|
||||||
|
context;
|
||||||
|
|
||||||
|
input.autocomplete({
|
||||||
|
lookup: [{ value: 'Jamaica', data: 'B' }],
|
||||||
|
beforeRender: function (container) {
|
||||||
|
context = this;
|
||||||
|
elementCount = container.length;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
input.val('Jam');
|
||||||
|
instance = input.autocomplete();
|
||||||
|
instance.onValueChange();
|
||||||
|
|
||||||
|
expect(context).toBe(element);
|
||||||
|
expect(elementCount).toBe(1);
|
||||||
|
});
|
||||||
});
|
});
|
@ -29,10 +29,12 @@
|
|||||||
escapeRegExChars: function (value) {
|
escapeRegExChars: function (value) {
|
||||||
return value.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, "\\$&");
|
return value.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, "\\$&");
|
||||||
},
|
},
|
||||||
createNode: function (html) {
|
createNode: function (containerClass) {
|
||||||
var div = document.createElement('div');
|
var div = document.createElement('div');
|
||||||
div.innerHTML = html;
|
div.className = containerClass;
|
||||||
return div.firstChild;
|
div.style.position = 'absolute';
|
||||||
|
div.style.display = 'none';
|
||||||
|
return div;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}()),
|
}()),
|
||||||
@ -140,7 +142,7 @@
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
that.suggestionsContainer = Autocomplete.utils.createNode('<div class="' + options.containerClass + '" style="position: absolute; display: none;"></div>');
|
that.suggestionsContainer = Autocomplete.utils.createNode(options.containerClass);
|
||||||
|
|
||||||
container = $(that.suggestionsContainer);
|
container = $(that.suggestionsContainer);
|
||||||
|
|
||||||
@ -175,15 +177,23 @@
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
$(window).on('resize', that.fixPositionCapture);
|
$(window).on('resize.autocomplete', that.fixPositionCapture);
|
||||||
|
|
||||||
that.el.on('keydown.autocomplete', function (e) { that.onKeyPress(e); });
|
that.el.on('keydown.autocomplete', function (e) { that.onKeyPress(e); });
|
||||||
that.el.on('keyup.autocomplete', function (e) { that.onKeyUp(e); });
|
that.el.on('keyup.autocomplete', function (e) { that.onKeyUp(e); });
|
||||||
that.el.on('blur.autocomplete', function () { that.onBlur(); });
|
that.el.on('blur.autocomplete', function () { that.onBlur(); });
|
||||||
that.el.on('focus.autocomplete', function () { that.fixPosition(); });
|
that.el.on('focus.autocomplete', function () { that.onFocus(); });
|
||||||
that.el.on('change.autocomplete', function (e) { that.onKeyUp(e); });
|
that.el.on('change.autocomplete', function (e) { that.onKeyUp(e); });
|
||||||
},
|
},
|
||||||
|
|
||||||
|
onFocus: function () {
|
||||||
|
var that = this;
|
||||||
|
that.fixPosition();
|
||||||
|
if (that.options.minChars <= that.el.val().length) {
|
||||||
|
that.onValueChange();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
onBlur: function () {
|
onBlur: function () {
|
||||||
this.enableKillerFn();
|
this.enableKillerFn();
|
||||||
},
|
},
|
||||||
@ -220,7 +230,11 @@
|
|||||||
},
|
},
|
||||||
|
|
||||||
disable: function () {
|
disable: function () {
|
||||||
this.disabled = true;
|
var that = this;
|
||||||
|
that.disabled = true;
|
||||||
|
if (that.currentRequest) {
|
||||||
|
that.currentRequest.abort();
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
enable: function () {
|
enable: function () {
|
||||||
@ -229,7 +243,8 @@
|
|||||||
|
|
||||||
fixPosition: function () {
|
fixPosition: function () {
|
||||||
var that = this,
|
var that = this,
|
||||||
offset;
|
offset,
|
||||||
|
styles;
|
||||||
|
|
||||||
// Don't adjsut position if custom container has been specified:
|
// Don't adjsut position if custom container has been specified:
|
||||||
if (that.options.appendTo !== 'body') {
|
if (that.options.appendTo !== 'body') {
|
||||||
@ -238,10 +253,16 @@
|
|||||||
|
|
||||||
offset = that.el.offset();
|
offset = that.el.offset();
|
||||||
|
|
||||||
$(that.suggestionsContainer).css({
|
styles = {
|
||||||
top: (offset.top + that.el.outerHeight()) + 'px',
|
top: (offset.top + that.el.outerHeight()) + 'px',
|
||||||
left: offset.left + 'px'
|
left: offset.left + 'px'
|
||||||
});
|
};
|
||||||
|
|
||||||
|
if (that.options.width === 'auto') {
|
||||||
|
styles.width = (that.el.outerWidth() - 2) + 'px';
|
||||||
|
}
|
||||||
|
|
||||||
|
$(that.suggestionsContainer).css(styles);
|
||||||
},
|
},
|
||||||
|
|
||||||
enableKillerFn: function () {
|
enableKillerFn: function () {
|
||||||
@ -260,7 +281,7 @@
|
|||||||
that.intervalId = window.setInterval(function () {
|
that.intervalId = window.setInterval(function () {
|
||||||
that.hide();
|
that.hide();
|
||||||
that.stopKillSuggestions();
|
that.stopKillSuggestions();
|
||||||
}, 300);
|
}, 50);
|
||||||
},
|
},
|
||||||
|
|
||||||
stopKillSuggestions: function () {
|
stopKillSuggestions: function () {
|
||||||
@ -431,15 +452,16 @@
|
|||||||
if ($.isFunction(options.serviceUrl)) {
|
if ($.isFunction(options.serviceUrl)) {
|
||||||
serviceUrl = options.serviceUrl.call(that.element, q);
|
serviceUrl = options.serviceUrl.call(that.element, q);
|
||||||
}
|
}
|
||||||
if(this.currentRequest != null) {
|
if (that.currentRequest) {
|
||||||
this.currentRequest.abort();
|
that.currentRequest.abort();
|
||||||
}
|
}
|
||||||
this.currentRequest = $.ajax({
|
that.currentRequest = $.ajax({
|
||||||
url: serviceUrl,
|
url: serviceUrl,
|
||||||
data: options.ignoreParams ? null : options.params,
|
data: options.ignoreParams ? null : options.params,
|
||||||
type: options.type,
|
type: options.type,
|
||||||
dataType: options.dataType
|
dataType: options.dataType
|
||||||
}).done(function (data) {
|
}).done(function (data) {
|
||||||
|
that.currentRequest = null;
|
||||||
that.processResponse(data, q);
|
that.processResponse(data, q);
|
||||||
options.onSearchComplete.call(that.element, q);
|
options.onSearchComplete.call(that.element, q);
|
||||||
}).fail(function (jqXHR, textStatus, errorThrown) {
|
}).fail(function (jqXHR, textStatus, errorThrown) {
|
||||||
@ -481,6 +503,7 @@
|
|||||||
className = that.classes.suggestion,
|
className = that.classes.suggestion,
|
||||||
classSelected = that.classes.selected,
|
classSelected = that.classes.selected,
|
||||||
container = $(that.suggestionsContainer),
|
container = $(that.suggestionsContainer),
|
||||||
|
beforeRender = that.options.beforeRender,
|
||||||
html = '',
|
html = '',
|
||||||
width;
|
width;
|
||||||
|
|
||||||
@ -498,8 +521,7 @@
|
|||||||
container.width(width > 0 ? width : 300);
|
container.width(width > 0 ? width : 300);
|
||||||
}
|
}
|
||||||
|
|
||||||
container.html(html).show();
|
container.html(html);
|
||||||
that.visible = true;
|
|
||||||
|
|
||||||
// Select first value by default:
|
// Select first value by default:
|
||||||
if (that.options.autoSelectFirst) {
|
if (that.options.autoSelectFirst) {
|
||||||
@ -507,6 +529,13 @@
|
|||||||
container.children().first().addClass(classSelected);
|
container.children().first().addClass(classSelected);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($.isFunction(beforeRender)) {
|
||||||
|
beforeRender.call(that.element, container);
|
||||||
|
}
|
||||||
|
|
||||||
|
container.show();
|
||||||
|
that.visible = true;
|
||||||
|
|
||||||
that.findBestHint();
|
that.findBestHint();
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -703,7 +732,7 @@
|
|||||||
var that = this;
|
var that = this;
|
||||||
that.el.off('.autocomplete').removeData('autocomplete');
|
that.el.off('.autocomplete').removeData('autocomplete');
|
||||||
that.disableKillerFn();
|
that.disableKillerFn();
|
||||||
$(window).off('resize', that.fixPositionCapture);
|
$(window).off('resize.autocomplete', that.fixPositionCapture);
|
||||||
$(that.suggestionsContainer).remove();
|
$(that.suggestionsContainer).remove();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user