mirror of
https://github.com/status-im/consul.git
synced 2025-01-10 05:45:46 +00:00
c532e53d9a
Move all the dom-things to use the dom service in tabular-collection, feedback-dialog, list-collection and node show. Move get-component-factory into utils/dom and use dom.root() in a few more places This includes an additional `dom.components` method which gives you a list of components matching the selector instead of just one.
49 lines
1.3 KiB
JavaScript
49 lines
1.3 KiB
JavaScript
import Controller from '@ember/controller';
|
|
import { computed, get } from '@ember/object';
|
|
import WithFiltering from 'consul-ui/mixins/with-filtering';
|
|
import ucfirst from 'consul-ui/utils/ucfirst';
|
|
const countType = function(items, type) {
|
|
return type === '' ? get(items, 'length') : items.filterBy('Type', type).length;
|
|
};
|
|
export default Controller.extend(WithFiltering, {
|
|
queryParams: {
|
|
type: {
|
|
as: 'type',
|
|
},
|
|
s: {
|
|
as: 'filter',
|
|
replace: true,
|
|
},
|
|
},
|
|
typeFilters: computed('items', function() {
|
|
const items = get(this, 'items');
|
|
return ['', 'management', 'client'].map(function(item) {
|
|
return {
|
|
label: `${item === '' ? 'All' : ucfirst(item)} (${countType(
|
|
items,
|
|
item
|
|
).toLocaleString()})`,
|
|
value: item,
|
|
};
|
|
});
|
|
}),
|
|
// TODO: This should be using a searchable
|
|
filter: function(item, { s = '', type = '' }) {
|
|
const sLower = s.toLowerCase();
|
|
return (
|
|
(get(item, 'Name')
|
|
.toLowerCase()
|
|
.indexOf(sLower) !== -1 ||
|
|
get(item, 'ID')
|
|
.toLowerCase()
|
|
.indexOf(sLower) !== -1) &&
|
|
(type === '' || get(item, 'Type') === type)
|
|
);
|
|
},
|
|
actions: {
|
|
sendClone: function(item) {
|
|
this.send('clone', item);
|
|
},
|
|
},
|
|
});
|