Skip to content

Commit

Permalink
feat(clearOnSelected): allow users to clear the input instead of fill…
Browse files Browse the repository at this point in the history
…ing (#244)

* feat(clearOnSelected): allow users to clear the input instead of filling

In some use-cases, like when you're using autocomplete to make tags on a page, or using the output in any other way than prefilling the query, you don't want the suggested value to show in the input, but would rather like it to be empty.

Before this PR it was basically impossible to have your input not filled, since it came back on blur and a few different places (see `resetInputValue`

fixes #241

* fix: make sure both query and input are ''

* chore: update test

* chore: test implem of callback too

* chore: more specific test
  • Loading branch information
Haroenv authored Aug 7, 2018
1 parent c194736 commit aa2edbb
Show file tree
Hide file tree
Showing 7 changed files with 43 additions and 3 deletions.
2 changes: 2 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -290,6 +290,8 @@ When initializing an autocomplete, there are a number of options you can configu

* `debug` – If `true`, the autocomplete will not close on `blur`. Defaults to `false`.

* `clearOnSelected` – If `true`, the autocomplete will empty the search box when a suggestion is selected. This is useful if you want to use this as a way to input tags using the `selected` event.

* `openOnFocus` – If `true`, the dropdown menu will open when the input is focused. Defaults to `false`.

* `appendTo` – If set with a DOM selector, doesn't wrap the input and appends the wrapper and dropdown menu to the first DOM element matching the selector. It automatically positions the wrapper under the input, and sets it to the same width as the input. Can't be used with `hint: true`, because `hint` requires the wrapper around the input.
Expand Down
2 changes: 1 addition & 1 deletion examples/basic.html
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ <h3>Basic example</h3>
autocomplete('#search-input', { hint: false }, [
{
source: autocomplete.sources.hits(index, { hitsPerPage: 5 }),
displayKey: 'my_attribute',
displayKey: 'name',
templates: {
suggestion: function(suggestion) {
return suggestion._highlightResult.name.value;
Expand Down
1 change: 1 addition & 0 deletions src/angular/directive.js
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@ angular.module('algolia.autocomplete', [])
openOnFocus: scope.options.openOnFocus,
templates: scope.options.templates,
debug: scope.options.debug,
clearOnSelected: scope.options.clearOnSelected,
cssClasses: scope.options.cssClasses,
datasets: scope.datasets,
keyboardShortcuts: scope.options.keyboardShortcuts,
Expand Down
7 changes: 6 additions & 1 deletion src/autocomplete/typeahead.js
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ function Typeahead(o) {
this.openOnFocus = !!o.openOnFocus;
this.minLength = _.isNumber(o.minLength) ? o.minLength : 1;
this.autoWidth = (o.autoWidth === undefined) ? true : !!o.autoWidth;
this.clearOnSelected = !!o.clearOnSelected;

o.hint = !!o.hint;

Expand Down Expand Up @@ -417,7 +418,11 @@ _.mixin(Typeahead.prototype, {
if (typeof datum.value !== 'undefined') {
this.input.setQuery(datum.value);
}
this.input.setInputValue(datum.value, true);
if (this.clearOnSelected) {
this.setVal('');
} else {
this.input.setInputValue(datum.value, true);
}

this._setLanguageDirection();

Expand Down
1 change: 1 addition & 0 deletions src/jquery/plugin.js
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,7 @@ methods = {
openOnFocus: o.openOnFocus,
templates: o.templates,
debug: o.debug,
clearOnSelected: o.clearOnSelected,
cssClasses: o.cssClasses,
datasets: datasets,
keyboardShortcuts: o.keyboardShortcuts,
Expand Down
1 change: 1 addition & 0 deletions src/standalone/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ function autocomplete(selector, options, datasets, typeaheadObject) {
openOnFocus: options.openOnFocus,
templates: options.templates,
debug: options.debug,
clearOnSelected: options.clearOnSelected,
cssClasses: options.cssClasses,
datasets: datasets,
keyboardShortcuts: options.keyboardShortcuts,
Expand Down
32 changes: 31 additions & 1 deletion test/unit/typeahead_spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -342,7 +342,6 @@ describe('Typeahead', function() {
});

describe('when debug flag is set', function() {

beforeEach(function() {
this.view = new Typeahead({
input: this.$input,
Expand All @@ -368,6 +367,37 @@ describe('Typeahead', function() {
});
});

describe('when clearOnSelected flag is set to true', function() {
it('clears input when selected', function() {
var spy = jasmine.createSpy();
var view = new Typeahead({
input: this.$input,
clearOnSelected: true,
hint: true,
datasets: {}
});
view.dropdown.getDatumForCursor.and.returnValue(testDatum);

// select something, and clear
var $e = jasmine.createSpyObj('event', ['preventDefault']);
view.$input.on('autocomplete:selected', spy);
view.input.trigger('enterKeyed', $e);

expect(spy).toHaveBeenCalledTimes(1);
expect(spy).toHaveBeenCalledWith(jasmine.objectContaining({
type: 'autocomplete:selected',
target: jasmine.any(Object),
delegateTarget: jasmine.any(Object),
currentTarget: jasmine.any(Object),
handleObj: jasmine.objectContaining({
type: 'autocomplete:selected'
})
}), undefined, undefined);
expect(view.input.setQuery).toHaveBeenCalledWith('');
expect(view.input.setInputValue).toHaveBeenCalledWith('', true);
});
});

describe('when input triggers enterKeyed', function() {
beforeEach(function() {
this.dropdown.getDatumForCursor.and.returnValue(testDatum);
Expand Down

0 comments on commit aa2edbb

Please sign in to comment.