mirror of
https://github.com/strapi/strapi.git
synced 2025-10-24 06:23:40 +00:00
44 lines
1.3 KiB
JavaScript
44 lines
1.3 KiB
JavaScript
'use strict';
|
|
|
|
const { objectType } = require('nexus');
|
|
const { prop, identity, isEmpty } = require('lodash/fp');
|
|
|
|
module.exports = ({ strapi }) => {
|
|
const { naming } = strapi.plugin('graphql').service('utils');
|
|
|
|
return {
|
|
/**
|
|
* Build a higher level type for a content type which contains the attributes, the ID and the metadata
|
|
* @param {object} contentType The content type which will be used to build its entity type
|
|
* @return {NexusObjectTypeDef}
|
|
*/
|
|
buildEntityDefinition(contentType) {
|
|
const { attributes } = contentType;
|
|
|
|
const name = naming.getEntityName(contentType);
|
|
const typeName = naming.getTypeName(contentType);
|
|
|
|
return objectType({
|
|
name,
|
|
|
|
definition(t) {
|
|
// Keep the ID attribute at the top level
|
|
t.id('id', { resolve: prop('id') });
|
|
|
|
if (!isEmpty(attributes)) {
|
|
// Keep the fetched object into a dedicated `attributes` field
|
|
// TODO: [v4] precise why we keep the ID
|
|
t.field('attributes', {
|
|
type: typeName,
|
|
resolve: identity,
|
|
});
|
|
}
|
|
|
|
// todo[v4]: add the meta field to the entity when there will be data in it (can't add an empty type for now)
|
|
// t.field('meta', { type: utils.getEntityMetaName(contentType) });
|
|
},
|
|
});
|
|
},
|
|
};
|
|
};
|