addbf89c63
I don't think this would have a large effect on the UI whichever but best to make sure
48 lines
1.4 KiB
JavaScript
48 lines
1.4 KiB
JavaScript
import Adapter from './application';
|
|
import { PRIMARY_KEY, SLUG_KEY } from 'consul-ui/models/node';
|
|
import { OK as HTTP_OK } from 'consul-ui/utils/http/status';
|
|
// TODO: Looks like ID just isn't used at all
|
|
// consider just using .Node for the SLUG_KEY
|
|
const fillSlug = function(item) {
|
|
if (item[SLUG_KEY] === '') {
|
|
item[SLUG_KEY] = item['Node'];
|
|
}
|
|
return item;
|
|
};
|
|
export default Adapter.extend({
|
|
urlForQuery: function(query, modelName) {
|
|
return this.appendURL('internal/ui/nodes', [], this.cleanQuery(query));
|
|
},
|
|
urlForQueryRecord: function(query, modelName) {
|
|
return this.appendURL('internal/ui/node', [query.id], this.cleanQuery(query));
|
|
},
|
|
handleResponse: function(status, headers, payload, requestData) {
|
|
let response = payload;
|
|
if (status === HTTP_OK) {
|
|
const url = this.parseURL(requestData.url);
|
|
switch (true) {
|
|
case this.isQueryRecord(url):
|
|
response = fillSlug(response);
|
|
response = {
|
|
...response,
|
|
...{
|
|
[PRIMARY_KEY]: this.uidForURL(url),
|
|
},
|
|
};
|
|
break;
|
|
default:
|
|
response = response.map((item, i, arr) => {
|
|
item = fillSlug(item);
|
|
return {
|
|
...item,
|
|
...{
|
|
[PRIMARY_KEY]: this.uidForURL(url, item[SLUG_KEY]),
|
|
},
|
|
};
|
|
});
|
|
}
|
|
}
|
|
return this._super(status, headers, response, requestData);
|
|
},
|
|
});
|