Browse Source

Create search-provider

pull/14947/head
Michael Klein 2 years ago
parent
commit
aebb988daf
  1. 1
      ui/packages/consul-ui/app/components/providers/search/index.hbs
  2. 28
      ui/packages/consul-ui/app/components/providers/search/index.js

1
ui/packages/consul-ui/app/components/providers/search/index.hbs

@ -0,0 +1 @@
{{yield (hash data=this.data)}}

28
ui/packages/consul-ui/app/components/providers/search/index.js

@ -0,0 +1,28 @@
import Component from '@glimmer/component';
export default class SearchProvider extends Component {
get items() {
const { items, search, searchProperties } = this.args;
const regex = new RegExp(`${search}`, 'ig');
return items.filter((item) => {
const matchesInSearchProperties = searchProperties.reduce((acc, searchProperty) => {
const match = item[searchProperty].match(regex);
if (match) {
return [...acc, match];
} else {
return acc;
}
}, []);
return matchesInSearchProperties.length > 0;
});
}
get data() {
const { items } = this;
return {
items,
};
}
}
Loading…
Cancel
Save