Skip to content

Commit

Permalink
Update API docs for BelongsToReference
Browse files Browse the repository at this point in the history
  • Loading branch information
bmac committed Nov 10, 2016
1 parent 1ca87a2 commit a5f89b1
Show file tree
Hide file tree
Showing 2 changed files with 306 additions and 1 deletion.
4 changes: 3 additions & 1 deletion addon/-private/system/model/model.js
Original file line number Diff line number Diff line change
Expand Up @@ -840,7 +840,9 @@ var Model = Ember.Object.extend(Ember.Evented, {
type: 'blog',
id: 1,
relationships: {
user: { type: 'user', id: 1 }
user: {
data: { type: 'user', id: 1 }
}
}
});
var userRef = blog.belongsTo('user');
Expand Down
303 changes: 303 additions & 0 deletions addon/-private/system/references/belongs-to.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,16 @@ import Reference from './reference';
import isEnabled from 'ember-data/-private/features';
import { assertPolymorphicType, deprecate } from "ember-data/-private/debug";


/**
An BelongsToReference is a low level API that allows users and
addon author to perform meta-operations on a belongs-to
relationship.
@class BelongsToReference
@namespace DS
@extends DS.Reference
*/
var BelongsToReference = function(store, parentInternalModel, belongsToRelationship) {
this._super$constructor(store, parentInternalModel);
this.belongsToRelationship = belongsToRelationship;
Expand All @@ -18,6 +28,41 @@ BelongsToReference.prototype = Object.create(Reference.prototype);
BelongsToReference.prototype.constructor = BelongsToReference;
BelongsToReference.prototype._super$constructor = Reference;

/**
This returns a string that represents how the reference will be
looked up when it is loaded. If the relationship has a link it will
use the "link" otherwise it defaults to "id".
Example
```javascript
// models/blog.js
export default DS.Model.extend({
user: DS.belongsTo({ async: true })
});
var blog = store.push({
type: 'blog',
id: 1,
relationships: {
user: {
data: { type: 'user', id: 1 }
}
}
});
var userRef = blog.belongsTo('user');
// get the identifier of the reference
if (userRef.remoteType() === "id") {
var id = userRef.id();
} else if (userRef.remoteType() === "link") {
var link = userRef.link();
}
```
@method remoteType
@return {String} The name of the remote type. This should either be "link" or "id"
*/
BelongsToReference.prototype.remoteType = function() {
if (this.belongsToRelationship.link) {
return "link";
Expand All @@ -26,19 +71,165 @@ BelongsToReference.prototype.remoteType = function() {
return "id";
};

/**
The `id` of the record that this reference refers to. Together, the
`type()` and `id()` methods form a composite key for the identity
map. This can be used to access the id of an asycn relationship
without triggering a fetch that would normally happen if you
attempted to use `record.get('relationship.id')`.
Example
```javascript
// models/blog.js
export default DS.Model.extend({
user: DS.belongsTo({ async: true })
});
var blog = store.push({
type: 'blog',
id: 1,
relationships: {
user: {
data: { type: 'user', id: 1 }
}
}
});
var userRef = blog.belongsTo('user');
// get the identifier of the reference
if (userRef.remoteType() === "id") {
var id = userRef.id();
}
```
@method id
@return {String} The id of the record in this belongsTo relationship.
*/
BelongsToReference.prototype.id = function() {
var inverseRecord = this.belongsToRelationship.inverseRecord;
return inverseRecord && inverseRecord.id;
};

/**
The link Ember Data will use to fetch or reload this belongs-to
relationship. Together, the `type()` and `id()` methods form a
composite key for the identity map.
Example
```javascript
// models/blog.js
export default DS.Model.extend({
user: DS.belongsTo({ async: true })
});
var blog = store.push({
type: 'blog',
id: 1,
relationships: {
user: {
links: {
related: '/articles/1/author'
}
}
}
});
var userRef = blog.belongsTo('user');
// get the identifier of the reference
if (userRef.remoteType() === "link") {
var link = userRef.link();
}
```
@method link
@return {String} The link Ember Data will use to fetch or reload this belongs-to relationship.
*/
BelongsToReference.prototype.link = function() {
return this.belongsToRelationship.link;
};

/**
The meta data for the belongs-to relationship.
Example
```javascript
// models/blog.js
export default DS.Model.extend({
user: DS.belongsTo({ async: true })
});
var blog = store.push({
type: 'blog',
id: 1,
relationships: {
user: {
links: {
related: {
href: '/articles/1/author',
meta: {
count: 10
}
}
}
}
}
});
var userRef = blog.belongsTo('user');
userRef.meta() // { count: 10 }
```
@method meta
@return {Object} The meta information for the belongs-oo relationship.
*/
BelongsToReference.prototype.meta = function() {
return this.belongsToRelationship.meta;
};

/**
`push` can be used to update the data in the relationship and Ember
Data will treat the new data as the conanical value of this
relationship on the backend.
Example
```javascript
// models/blog.js
export default DS.Model.extend({
user: DS.belongsTo({ async: true })
});
var blog = store.push({
type: 'blog',
id: 1,
relationships: {
user: {
data: { type: 'user', id: 1 }
}
}
});
var userRef = blog.belongsTo('user');
// provide data for reference
userRef.push({
type: 'user',
id: 1,
attributes: {
username: "@user"
}
}).then(function(user) {
userRef.value() === user;
});
```
@method push
@param {Object|Promise} objectOrPromise a promise that resolves to a JSONAPI document object describing the new value of this relationship.
@return {Object} The meta information for the belongs-oo relationship.
*/
BelongsToReference.prototype.push = function(objectOrPromise) {
return Ember.RSVP.resolve(objectOrPromise).then((data) => {
var record;
Expand All @@ -63,6 +254,50 @@ BelongsToReference.prototype.push = function(objectOrPromise) {
});
};

/**
`value()` sycronously returns the current value of the belongs-to
relationship. Unlike `record.get('relationshipName')`, calling
`value()` on a reference does not trigger a fetch if the async
relationship is not yet loaded. If the relationship is not loaded
it will always return `null`.
Example
```javascript
// models/blog.js
export default DS.Model.extend({
user: DS.belongsTo({ async: true })
});
var blog = store.push({
type: 'blog',
id: 1,
relationships: {
user: {
data: { type: 'user', id: 1 }
}
}
});
var userRef = blog.belongsTo('user');
userRef.value(); // null
// provide data for reference
userRef.push({
type: 'user',
id: 1,
attributes: {
username: "@user"
}
}).then(function(user) {
userRef.value(); // user
});
```
@method value
@param {Object|Promise} objectOrPromise a promise that resolves to a JSONAPI document object describing the new value of this relationship.
@return {DS.Model} the record in this relationship
*/
BelongsToReference.prototype.value = function() {
var inverseRecord = this.belongsToRelationship.inverseRecord;

Expand All @@ -73,6 +308,42 @@ BelongsToReference.prototype.value = function() {
return null;
};

/**
`value()` sycronously returns the current value of the belongs-to
relationship. Unlike `record.get('relationshipName')`, calling
`value()` on a reference does not trigger a fetch if the async
relationship is not yet loaded. If the relationship is not loaded
it will always return `null`. If the relationship is already loaded
this method does not trigger a new load.
Example
```javascript
// models/blog.js
export default DS.Model.extend({
user: DS.belongsTo({ async: true })
});
var blog = store.push({
type: 'blog',
id: 1,
relationships: {
user: {
data: { type: 'user', id: 1 }
}
}
});
var userRef = blog.belongsTo('user');
userRef.value(); // null
userRef.load().then(function(user) {
userRef.value() === user
});
@method load
@return {Promise} a promise that resolves with the record in this belongs-to relationship.
*/
BelongsToReference.prototype.load = function() {
if (this.remoteType() === "id") {
return this.belongsToRelationship.getRecord();
Expand All @@ -85,6 +356,38 @@ BelongsToReference.prototype.load = function() {
}
};

/**
Triggers a reload of the value in this relationship. If the
remoteType is `"link"` Ember Data will use the relationship link to
reload the relationship. Otherwise it will reload the record by its
id.
Example
```javascript
// models/blog.js
export default DS.Model.extend({
user: DS.belongsTo({ async: true })
});
var blog = store.push({
type: 'blog',
id: 1,
relationships: {
user: {
data: { type: 'user', id: 1 }
}
}
});
var userRef = blog.belongsTo('user');
userRef.reload().then(function(user) {
userRef.value() === user
});
@method reload
@return {Promise} a promise that resolves with the record in this belongs-to relationship after the reload has completed.
*/
BelongsToReference.prototype.reload = function() {
return this.belongsToRelationship.reload().then((internalModel) => {
return this.value();
Expand Down

0 comments on commit a5f89b1

Please sign in to comment.