ddf8c20219
* add menu-loader component to show menu loading button when the model relationship isPending * list what keys we've got in api-path error * fix spacing issue on error flash * add an action on list-controller that bubbles to the list-route mixin to refresh the route * empty store when creating scopes * don't delete _requestQuery in the loop, do it after * add scope deletion from the scope list * add deleteRecord to kmip adapters * add model-wrap component * delete role from detail page and list * add revoke credentials functionality * fix comment * treat all operations fields specially on kmip roles * adjust kmip role edit form for new fields * fix api-path test * update document blocks for menu-loader and model-wrap components
78 lines
2.2 KiB
JavaScript
78 lines
2.2 KiB
JavaScript
import { isNone, isBlank } from '@ember/utils';
|
|
import { assign } from '@ember/polyfills';
|
|
import { decamelize } from '@ember/string';
|
|
import DS from 'ember-data';
|
|
|
|
export default DS.JSONSerializer.extend({
|
|
keyForAttribute: function(attr) {
|
|
return decamelize(attr);
|
|
},
|
|
|
|
normalizeItems(payload) {
|
|
if (payload.data && payload.data.keys && Array.isArray(payload.data.keys)) {
|
|
let models = payload.data.keys.map(key => {
|
|
if (typeof key !== 'string') {
|
|
return key;
|
|
}
|
|
let pk = this.get('primaryKey') || 'id';
|
|
let model = { [pk]: key };
|
|
// if we've added _requestQuery in the adapter, we want
|
|
// attach it to the individual models
|
|
if (payload._requestQuery) {
|
|
model = { ...model, ...payload._requestQuery };
|
|
}
|
|
return model;
|
|
});
|
|
return models;
|
|
}
|
|
assign(payload, payload.data);
|
|
delete payload.data;
|
|
return payload;
|
|
},
|
|
|
|
pushPayload(store, payload) {
|
|
const transformedPayload = this.normalizeResponse(
|
|
store,
|
|
store.modelFor(payload.modelName),
|
|
payload,
|
|
payload.id,
|
|
'findRecord'
|
|
);
|
|
return store.push(transformedPayload);
|
|
},
|
|
|
|
normalizeResponse(store, primaryModelClass, payload, id, requestType) {
|
|
const responseJSON = this.normalizeItems(payload, requestType);
|
|
delete payload._requestQuery;
|
|
if (id && !responseJSON.id) {
|
|
responseJSON.id = id;
|
|
}
|
|
let jsonAPIRepresentation = this._super(store, primaryModelClass, responseJSON, id, requestType);
|
|
if (primaryModelClass.relatedCapabilities) {
|
|
jsonAPIRepresentation = primaryModelClass.relatedCapabilities(jsonAPIRepresentation);
|
|
}
|
|
return jsonAPIRepresentation;
|
|
},
|
|
|
|
serializeAttribute(snapshot, json, key, attributes) {
|
|
const val = snapshot.attr(key);
|
|
const valHasNotChanged = isNone(snapshot.changedAttributes()[key]);
|
|
const valIsBlank = isBlank(val);
|
|
if (attributes.options.readOnly) {
|
|
return;
|
|
}
|
|
if (attributes.type === 'object' && val && Object.keys(val).length > 0 && valHasNotChanged) {
|
|
return;
|
|
}
|
|
if (valIsBlank && valHasNotChanged) {
|
|
return;
|
|
}
|
|
|
|
this._super(snapshot, json, key, attributes);
|
|
},
|
|
|
|
serializeBelongsTo(snapshot, json) {
|
|
return json;
|
|
},
|
|
});
|