mirror of https://github.com/hashicorp/consul
86 lines
2.8 KiB
JavaScript
86 lines
2.8 KiB
JavaScript
import Controller from '@ember/controller';
|
|
import { get, set } from '@ember/object';
|
|
import { getOwner } from '@ember/application';
|
|
import WithFiltering from 'consul-ui/mixins/with-filtering';
|
|
import qsaFactory from 'consul-ui/utils/dom/qsa-factory';
|
|
import getComponentFactory from 'consul-ui/utils/get-component-factory';
|
|
|
|
const $$ = qsaFactory();
|
|
export default Controller.extend(WithFiltering, {
|
|
queryParams: {
|
|
s: {
|
|
as: 'filter',
|
|
replace: true,
|
|
},
|
|
},
|
|
setProperties: function() {
|
|
this._super(...arguments);
|
|
// the default selected tab depends on whether you have any healthchecks or not
|
|
// so check the length here.
|
|
// This method is called immediately after `Route::setupController`, and done here rather than there
|
|
// as this is a variable used purely for view level things, if the view was different we might not
|
|
// need this variable
|
|
set(this, 'selectedTab', get(this.item, 'Checks.length') > 0 ? 'health-checks' : 'services');
|
|
},
|
|
filter: function(item, { s = '' }) {
|
|
const term = s.toLowerCase();
|
|
return (
|
|
get(item, 'Service')
|
|
.toLowerCase()
|
|
.indexOf(term) !== -1 ||
|
|
get(item, 'ID')
|
|
.toLowerCase()
|
|
.indexOf(term) !== -1 ||
|
|
(get(item, 'Tags') || []).some(function(item) {
|
|
return item.toLowerCase().indexOf(term) !== -1;
|
|
}) ||
|
|
get(item, 'Port')
|
|
.toString()
|
|
.toLowerCase()
|
|
.indexOf(term) !== -1
|
|
);
|
|
},
|
|
actions: {
|
|
change: function(e) {
|
|
set(this, 'selectedTab', e.target.value);
|
|
const getComponent = getComponentFactory(getOwner(this));
|
|
// Ensure tabular-collections sizing is recalculated
|
|
// now it is visible in the DOM
|
|
[...$$('.tab-section input[type="radio"]:checked + div table')].forEach(function(item) {
|
|
const component = getComponent(item);
|
|
if (component && typeof component.didAppear === 'function') {
|
|
getComponent(item).didAppear();
|
|
}
|
|
});
|
|
},
|
|
sortChecksByImportance: function(a, b) {
|
|
const statusA = get(a, 'Status');
|
|
const statusB = get(b, 'Status');
|
|
switch (statusA) {
|
|
case 'passing':
|
|
// a = passing
|
|
// unless b is also passing then a is less important
|
|
return statusB === 'passing' ? 0 : 1;
|
|
case 'critical':
|
|
// a = critical
|
|
// unless b is also critical then a is more important
|
|
return statusB === 'critical' ? 0 : -1;
|
|
case 'warning':
|
|
// a = warning
|
|
switch (statusB) {
|
|
// b is passing so a is more important
|
|
case 'passing':
|
|
return -1;
|
|
// b is critical so a is less important
|
|
case 'critical':
|
|
return 1;
|
|
// a and b are both warning, therefore equal
|
|
default:
|
|
return 0;
|
|
}
|
|
}
|
|
return 0;
|
|
},
|
|
},
|
|
});
|