Skip to content

Instantly share code, notes, and snippets.

@mapohjola
Last active April 12, 2016 10:02
Show Gist options
  • Save mapohjola/f62581bdad4fa2005b74976758243445 to your computer and use it in GitHub Desktop.
Save mapohjola/f62581bdad4fa2005b74976758243445 to your computer and use it in GitHub Desktop.
Ember Data Model validation
import DS from "ember-data";
export default DS.JSONAPIAdapter.extend();
export function returnJSON(status, body) {
return json(...arguments);
};
export function json(status, body) {
if (arguments.length === 1) {
body = status;
status = 200;
}
return [
status,
{ "Content-Type": "application/json" },
JSON.stringify(body)
];
};
export const server = new Pretender();
export function initialize() {
server.handledRequest = function(verb, path, request) {
console.log(`handled request to ${verb} ${path}`);
}
server.unhandledRequest = function(verb, path, request) {
console.log(`undhandled request ${verb} ${path}`);
}
};
export default {
name: 'pretender',
initialize
};
import DS from 'ember-data';
const { attr } = DS;
export default DS.Model.extend({
name: attr(),
username: attr()
});
import Ember from 'ember';
import { server, json } from '../initializers/pretender';
server.map(function() {
this.get('/people/1', function() {
return json({
data: {
type: 'person',
id: 1,
attributes: {
name: 'George Michael Bluth',
username: null
}
}
});
});
});
export default Ember.Route.extend({
model: function() {
return this.store.findRecord('person', 1);
},
actions: {
validateOld() {
let record = this.get('controller.model')
// validate record
// add error to model errors
record.get('errors').add('username', "We just wanted to trigger username error")
},
validateNew() {
let record = this.get('controller.model')
// validate record
// add error to model errors
// No public way to add errors to record
record.get('errors')._add('username', "We just wanted to trigger username error")
// Manually trigger becameInvalid event
record.send('becameInvalid')
},
clearOld() {
let record = this.get('controller.model')
// Clear the errors marks model as valid again
record.get('errors').clear()
},
clearNew() {
let record = this.get('controller.model')
// Clear the errors, not public API
record.get('errors')._clear()
// Manually trigger becameValid
record.send('becameValid')
}
}
});
Name: {{model.name}} - {{model.isValid}}
<br>
Give username: {{input type="text" value=model.username}}
<br>
{{#if model.errors}}
Model errors:<br>
{{#each model.errors as |error|}}
{{error.attribute}} - {{error.message}}
{{/each}}
{{/if}}
<br>
<button {{action 'validateOld'}}>Validate old style</button>
<button {{action 'validateNew'}}>Validate new style</button>
<br>
<button {{action 'clearOld'}}>Clear errors old style</button>
<button {{action 'clearNew'}}>Clear errors new style</button>
{
"version": "0.4.17",
"dependencies": {
"jquery": "https://cdnjs.cloudflare.com/ajax/libs/jquery/1.11.3/jquery.js",
"ember": "canary",
"ember-data": "canary",
"ember-template-compiler": "canary",
"route-recognizer": "https://rawgit.com/tildeio/route-recognizer/56f5fcec6ae58d8e86b5dc77609809fb91198142/dist/route-recognizer.js",
"FakeXMLHttpRequest": "https://rawgit.com/pretenderjs/FakeXMLHttpRequest/23c3a96b5b24f1bfe595867437e4f128a29c2840/fake_xml_http_request.js",
"pretender": "https://rawgit.com/pretenderjs/pretender/c6de9afe18b1472aded2592f5a80ad9a26a0e262/pretender.js"
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment