Each entity maps to a different API endpoint. The name of the entity, defines the endpoint:
// set the main API endpoint for this admin
var app = nga.application('My backend')
.baseApiUrl('http://localhost:3000/');
// define an entity mapped by the http://localhost:3000/posts endpoint
var post = nga.entity('posts');
-
label()
Defines the name of the entity, as displayed on screenvar comment = nga.entity('comments').label('Discussions');
-
identifier(Field)
Defines the field to be used as identifier. By default, entities use the field namedid
.var post = nga.entity('posts').identifier(nga.field('_id'));
-
readOnly()
A read-only entity doesn't allow access to the mutation views (editionView, creationView, deletionView). In addition, all links to the editionView are replaced by links to the showView.var tag = nga.entity('tags').readOnly();
-
baseApiUrl()
Defines the base API endpoint for all views of this entityvar comment = nga.entity('comments').baseApiUrl('http://localhost:3001/');
-
url()
Defines the API endpoint for all views of this entity. It can be a string or a function.var comment = nga.entity('comments').url(function(entityName, viewType, identifierValue, identifierName) { var e = encodeURIComponent; return '/comments/' + e(entityName) + '_' + e(viewType) + '?' + e(identifierName) + '=' + e(identifierValue); // Can be absolute or relative });
-
createMethod(string)
andupdateMethod(string)
Customize the HTTP method to be used for write queries, e.g. to usePATCH
instead ofPUT
. -
listView()
,creationView()
,editionView()
,showView()
, anddeletionView()
are getters for the entity's Views. Most of an entity's customization takes place in the views. See the Views Configuration chapter for details.var post = nga.entity('post'); post.listView() .fields([ nga.field('id'), nga.field('title'), nga.field('userId', 'reference') .targetEntity(user) .targetField(nga.field('username')) .label('User') ]).filters([ nga.field('q') .label('Full-Text') .pinned(true), nga.field('userId', 'reference') .targetEntity(user) .targetField(nga.field('username')) .label('User') ]);