Merge pull request #3412 from hashicorp/b-ui-disable-fuzzy-search

Disable fuzzy search
This commit is contained in:
Michael Lange 2017-10-18 20:08:15 -07:00 committed by GitHub
commit 79c836d734
6 changed files with 13 additions and 57 deletions

View File

@ -20,7 +20,7 @@ export default Controller.extend(Sortable, Searchable, {
sortProperty: 'modifyIndex',
sortDescending: true,
searchProps: computed(() => ['id', 'name']),
searchProps: computed(() => ['shortId', 'name']),
allocations: computed('model.allocations.[]', function() {
return this.get('model.allocations') || [];

View File

@ -18,7 +18,7 @@ export default Controller.extend(Sortable, Searchable, {
sortProperty: 'modifyIndex',
sortDescending: true,
searchProps: computed(() => ['id', 'name']),
searchProps: computed(() => ['shortId', 'name']),
listToSort: computed.alias('model.allocations'),
listToSearch: computed.alias('listSorted'),

View File

@ -1,5 +1,4 @@
import Ember from 'ember';
import Fuse from 'npm:fuse.js';
const { Mixin, computed, get } = Ember;
@ -14,46 +13,26 @@ const { Mixin, computed, get } = Ember;
- listToSearch: the list of objects to search
Properties provided:
- listSearched: a subset of listToSearch of items that meet the search criteria,
ordered by relevance.
- listSearched: a subset of listToSearch of items that meet the search criteria
*/
export default Mixin.create({
searchTerm: '',
listToSearch: computed(() => []),
searchProps: null,
fuse: computed('listToSearch.[]', 'searchProps.[]', function() {
return new Fuse(this.get('listToSearch'), {
shouldSort: true,
threshold: 0.6,
location: 0,
distance: 100,
maxPatternLength: 32,
minMatchCharLength: 1,
keys: this.get('searchProps') || [],
getFn(item, key) {
return get(item, key);
},
});
}),
listSearched: computed('fuse', 'searchTerm', function() {
const { fuse, searchTerm } = this.getProperties('fuse', 'searchTerm');
listSearched: computed('searchTerm', 'listToSearch.[]', 'searchProps.[]', function() {
const searchTerm = this.get('searchTerm');
if (searchTerm && searchTerm.length) {
if (searchTerm.startsWith('/')) {
return regexSearch(searchTerm, fuse);
}
return fuse.search(searchTerm);
return regexSearch(searchTerm, this.get('listToSearch'), this.get('searchProps'));
}
return this.get('listToSearch');
}),
});
function regexSearch(term, { list, options: { keys } }) {
const regexStr = term.slice(1);
if (regexStr.length) {
function regexSearch(term, list, keys) {
if (term.length) {
try {
const regex = new RegExp(regexStr, 'i');
const regex = new RegExp(term, 'i');
// Test the value of each key for each object against the regex
// All that match are returned.
return list.filter(item => keys.some(key => regex.test(get(item, key))));

View File

@ -20,10 +20,7 @@
"prettier --single-quote --trailing-comma es5 --print-width 100 --write",
"git add"
],
"ui/app/styles/**/*.*": [
"prettier --write",
"git add"
]
"ui/app/styles/**/*.*": ["prettier --write", "git add"]
}
},
"devDependencies": {
@ -69,7 +66,6 @@
"ember-welcome-page": "^3.0.0",
"eslint": "^4.0.0",
"flat": "^2.0.1",
"fuse.js": "^3.0.5",
"husky": "^0.13.4",
"json-formatter-js": "^2.2.0",
"lint-staged": "^3.6.1",
@ -81,9 +77,6 @@
},
"private": true,
"ember-addon": {
"paths": [
"lib/bulma",
"lib/calendar"
]
"paths": ["lib/bulma", "lib/calendar"]
}
}

View File

@ -24,18 +24,6 @@ test('the searchable mixin does nothing when there is no search term', function(
assert.deepEqual(subject.get('listSearched'), subject.get('source'));
});
test('the searchable mixin allows for fuzzy match search', function(assert) {
const subject = this.subject();
subject.set('source', [{ id: '1', name: 'hello' }, { id: '2', name: 'world' }]);
subject.set('searchTerm', 'helo');
assert.deepEqual(
subject.get('listSearched'),
[{ id: '1', name: 'hello' }],
'hello matched for the term helo'
);
});
test('the searchable mixin allows for regex search', function(assert) {
const subject = this.subject();
subject.set('source', [
@ -44,7 +32,7 @@ test('the searchable mixin allows for regex search', function(assert) {
{ id: '3', name: 'oranges' },
]);
subject.set('searchTerm', '/.+l+[A-Z]$');
subject.set('searchTerm', '.+l+[A-Z]$');
assert.deepEqual(
subject.get('listSearched'),
[{ id: '1', name: 'hello' }, { id: '2', name: 'world' }],
@ -60,7 +48,7 @@ test('the searchable mixin only searches the declared search props', function(as
{ id: '3', name: 'Mexico', continent: 'North America' },
]);
subject.set('searchTerm', '/America');
subject.set('searchTerm', 'America');
assert.deepEqual(
subject.get('listSearched'),
[{ id: '1', name: 'United States of America', continent: 'North America' }],

View File

@ -4086,10 +4086,6 @@ functional-red-black-tree@^1.0.1:
version "1.0.1"
resolved "https://registry.yarnpkg.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz#1b0ab3bd553b2a0d6399d29c0e3ea0b252078327"
fuse.js@^3.0.5:
version "3.0.5"
resolved "https://registry.yarnpkg.com/fuse.js/-/fuse.js-3.0.5.tgz#b58d85878802321de94461654947b93af1086727"
gauge@~2.7.3:
version "2.7.4"
resolved "https://registry.yarnpkg.com/gauge/-/gauge-2.7.4.tgz#2c03405c7538c39d7eb37b317022e325fb018bf7"