mirror of
https://github.com/status-im/consul.git
synced 2025-01-23 20:19:29 +00:00
2b0b1e61d2
The WithEventSource mixin was responsible for catching EventSource errors and cleaning up events sources then the user left a Controller. As we are trying to avoid mixin usage, we moved this all to an `EventSource` component, which can clean up when the component is removed from the page, and also fires an onerror event. Moving to a component firing an onerror event means we can also remove all of our custom computed property work that we were using previously to catch errors (thrown when a service etc. is removed)
35 lines
826 B
JavaScript
35 lines
826 B
JavaScript
import Controller from '@ember/controller';
|
|
import { computed } from '@ember/object';
|
|
|
|
export default Controller.extend({
|
|
queryParams: {
|
|
sortBy: 'sort',
|
|
search: {
|
|
as: 'filter',
|
|
},
|
|
},
|
|
services: computed('items.[]', function() {
|
|
return this.items.filter(function(item) {
|
|
return item.Kind !== 'connect-proxy';
|
|
});
|
|
}),
|
|
proxies: computed('items.[]', function() {
|
|
const proxies = {};
|
|
this.items
|
|
.filter(function(item) {
|
|
return item.Kind === 'connect-proxy';
|
|
})
|
|
.forEach(item => {
|
|
// Iterating to cover the usecase of a proxy being
|
|
// used by more than one service
|
|
if (item.ProxyFor) {
|
|
item.ProxyFor.forEach(service => {
|
|
proxies[service] = true;
|
|
});
|
|
}
|
|
});
|
|
|
|
return proxies;
|
|
}),
|
|
});
|