mirror of
https://github.com/status-im/consul.git
synced 2025-01-09 13:26:07 +00:00
5f625666b4
For URL maintenance reasons we store the last visited DC in localStorage incase you come back to a page (for example settings) that doesn't have a dc in the URL. A problem arises here if the last DC you tried to visit is unreachable. The first fix here clears out the last visited DC from localStorage if the API has errored out. Secondly, our `href-mut` helper which mutates the current current and replaces 'parts' in the URL rather than the whole thing functioned by detecting the current route/URL you are on an 'mutating' that. A problem arose here as even though you might be on the `/ui/dc-1/services` URL the actual route is the 'error' route which does not have a URL that can be changed properly. The second fix here uses route.currentRoute.name over route.currentRouteName. The latter is equal to error when an error occurs whereas the former gives you the name of the route before the error happened, which is actually what we want/the intent here. ie. when `router.currentRouteName === 'error'` then `router.currentRoute.name === Name Of Route Before It Errored` it seems
50 lines
1.5 KiB
JavaScript
50 lines
1.5 KiB
JavaScript
import RepositoryService from 'consul-ui/services/repository';
|
|
import { inject as service } from '@ember/service';
|
|
import { get } from '@ember/object';
|
|
import Error from '@ember/error';
|
|
import { Promise } from 'rsvp';
|
|
|
|
const modelName = 'dc';
|
|
export default RepositoryService.extend({
|
|
settings: service('settings'),
|
|
getModelName: function() {
|
|
return modelName;
|
|
},
|
|
findAll: function() {
|
|
return this.store.findAll(this.getModelName()).then(function(items) {
|
|
// TODO: Move to view/template
|
|
return items.sortBy('Name');
|
|
});
|
|
},
|
|
findBySlug: function(name, items) {
|
|
if (name != null) {
|
|
const item = items.findBy('Name', name);
|
|
if (item) {
|
|
return this.settings.persist({ dc: get(item, 'Name') }).then(function() {
|
|
// TODO: create a model
|
|
return { Name: get(item, 'Name') };
|
|
});
|
|
}
|
|
}
|
|
const e = new Error();
|
|
e.status = '404';
|
|
e.detail = 'Page not found';
|
|
return Promise.reject({ errors: [e] });
|
|
},
|
|
getActive: function(name, items) {
|
|
const settings = this.settings;
|
|
return Promise.all([name || settings.findBySlug('dc'), items || this.findAll()]).then(
|
|
([name, items]) => {
|
|
return this.findBySlug(name, items).catch(function() {
|
|
const item = get(items, 'firstObject');
|
|
settings.persist({ dc: get(item, 'Name') });
|
|
return item;
|
|
});
|
|
}
|
|
);
|
|
},
|
|
clearActive: function() {
|
|
return this.settings.delete('dc');
|
|
},
|
|
});
|