mirror of
https://github.com/status-im/consul.git
synced 2025-01-22 19:50:36 +00:00
5ea748005c
1. Addition of external source icons for services marked as such. 2. New %with-tooltip css component (wip) 3. New 'no healthcheck' icon as external sources might not have healthchecks, also minus icon on node cards in the service detail view 4. If a service doesn't have healthchecks, we use the [Services] tabs as the default instead of the [Health Checks] tab in the Service detail page. 5. `css-var` helper. The idea here is that it will eventually be replaced with pure css custom properties instead of having to use JS. It would be nice to be able to build the css variables into the JS at build time (you'd probably still want to specify in config which variables you wanted available in JS), but that's possible future work. Lastly there is probably a tiny bit more testing edits here than usual, I noticed that there was an area where the dynamic mocking wasn't happening, it was just using the mocks from consul-api-double, the mocks I was 'dynamically' setting happened to be the same as the ones in consul-api-double. I've fixed this here also but it wasn't effecting anything until actually made certain values dynamic.
71 lines
2.3 KiB
JavaScript
71 lines
2.3 KiB
JavaScript
import Controller from '@ember/controller';
|
|
import { get, computed } from '@ember/object';
|
|
import { htmlSafe } from '@ember/string';
|
|
import WithHealthFiltering from 'consul-ui/mixins/with-health-filtering';
|
|
const max = function(arr, prop) {
|
|
return arr.reduce(function(prev, item) {
|
|
return Math.max(prev, get(item, prop));
|
|
}, 0);
|
|
};
|
|
const chunk = function(str, size) {
|
|
const num = Math.ceil(str.length / size);
|
|
const chunks = new Array(num);
|
|
for (let i = 0, o = 0; i < num; ++i, o += size) {
|
|
chunks[i] = str.substr(o, size);
|
|
}
|
|
return chunks;
|
|
};
|
|
const width = function(num) {
|
|
const str = num.toString();
|
|
const len = str.length;
|
|
const commas = chunk(str, 3).length - 1;
|
|
return commas * 4 + len * 10;
|
|
};
|
|
const widthDeclaration = function(num) {
|
|
return htmlSafe(`width: ${num}px`);
|
|
};
|
|
export default Controller.extend(WithHealthFiltering, {
|
|
filter: function(item, { s = '', status = '' }) {
|
|
const term = s.toLowerCase();
|
|
return (
|
|
(get(item, 'Name')
|
|
.toLowerCase()
|
|
.indexOf(term) !== -1 ||
|
|
(get(item, 'Tags') || []).some(function(item) {
|
|
return item.toLowerCase().indexOf(term) !== -1;
|
|
})) &&
|
|
item.hasStatus(status)
|
|
);
|
|
},
|
|
maxWidth: computed('{maxPassing,maxWarning,maxCritical}', function() {
|
|
const PADDING = 32 * 3 + 13;
|
|
return ['maxPassing', 'maxWarning', 'maxCritical'].reduce((prev, item) => {
|
|
return prev + width(get(this, item));
|
|
}, PADDING);
|
|
}),
|
|
totalWidth: computed('maxWidth', function() {
|
|
return widthDeclaration(get(this, 'maxWidth'));
|
|
}),
|
|
remainingWidth: computed('maxWidth', function() {
|
|
return htmlSafe(`width: calc(50% - ${Math.round(get(this, 'maxWidth') / 2)}px)`);
|
|
}),
|
|
maxPassing: computed('items', function() {
|
|
return max(get(this, 'items'), 'ChecksPassing');
|
|
}),
|
|
maxWarning: computed('items', function() {
|
|
return max(get(this, 'items'), 'ChecksWarning');
|
|
}),
|
|
maxCritical: computed('items', function() {
|
|
return max(get(this, 'items'), 'ChecksCritical');
|
|
}),
|
|
passingWidth: computed('maxPassing', function() {
|
|
return widthDeclaration(width(get(this, 'maxPassing')));
|
|
}),
|
|
warningWidth: computed('maxWarning', function() {
|
|
return widthDeclaration(width(get(this, 'maxWarning')));
|
|
}),
|
|
criticalWidth: computed('maxCritical', function() {
|
|
return widthDeclaration(width(get(this, 'maxCritical')));
|
|
}),
|
|
});
|