mirror of
https://github.com/status-im/consul.git
synced 2025-01-09 13:26:07 +00:00
99c51c9f86
Various ember addons produced deprecation messages, some in the browser console and some in terminal. Upgrading and replacing some of these has reduced this. Upgrades: - ember-collection - ember-computed-style Replacements: - ember-pluralize replaced with ember-inflector - ember-cli-format-number replaced with custom helper using standard `toLocaleString` Removing ember-cli-format-number also meant some further changes related to decimal places in the tomography graph, done using `toFixed` The ExternalSources background-images have also now been escaped correctly preventing in-development `console` warnings. The only deprecation warnings are now from ember-block-slots, only in terminal, making for a better development experience overall, especially now we have an empty browser console Also adds a `callIfType` 'helper util' which is a util specifically for helpers (it conforms to a helper argument signature) to be expanded upon later.
48 lines
1.5 KiB
JavaScript
48 lines
1.5 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';
|
|
// TODO: DRY out in acls at least
|
|
const createCounter = function(prop) {
|
|
return function(items, val) {
|
|
return val === '' ? get(items, 'length') : items.filterBy(prop, val).length;
|
|
};
|
|
};
|
|
const countAction = createCounter('Action');
|
|
export default Controller.extend(WithFiltering, {
|
|
queryParams: {
|
|
action: {
|
|
as: 'action',
|
|
},
|
|
s: {
|
|
as: 'filter',
|
|
replace: true,
|
|
},
|
|
},
|
|
actionFilters: computed('items', function() {
|
|
const items = get(this, 'items');
|
|
return ['', 'allow', 'deny'].map(function(item) {
|
|
return {
|
|
label: `${item === '' ? 'All' : ucfirst(item)} (${countAction(
|
|
items,
|
|
item
|
|
).toLocaleString()})`,
|
|
value: item,
|
|
};
|
|
});
|
|
}),
|
|
filter: function(item, { s = '', action = '' }) {
|
|
const source = get(item, 'SourceName').toLowerCase();
|
|
const destination = get(item, 'DestinationName').toLowerCase();
|
|
const sLower = s.toLowerCase();
|
|
const allLabel = 'All Services (*)'.toLowerCase();
|
|
return (
|
|
(source.indexOf(sLower) !== -1 ||
|
|
destination.indexOf(sLower) !== -1 ||
|
|
(source === '*' && allLabel.indexOf(sLower) !== -1) ||
|
|
(destination === '*' && allLabel.indexOf(sLower) !== -1)) &&
|
|
(action === '' || get(item, 'Action') === action)
|
|
);
|
|
},
|
|
});
|