Ghost/ghost/admin/app/mixins/validation-state.js
Kevin Ansfield 2f4f6db133 Use es6 across client and add ember-suave to enforce rules
no issue
- add ember-suave dependency
- upgrade grunt-jscs dependency
- add a new .jscsrc for the client's tests directory that extends from client's base .jscsrc
- separate client tests in Gruntfile jscs task so they pick up the test's .jscsrc
- standardize es6 usage across client
2015-11-30 10:41:01 +00:00

35 lines
875 B
JavaScript

import Ember from 'ember';
const {Mixin, computed, isEmpty} = Ember;
const emberA = Ember.A;
export default Mixin.create({
errors: null,
property: '',
hasValidated: emberA(),
hasError: computed('errors.[]', 'property', 'hasValidated.[]', function () {
let property = this.get('property');
let errors = this.get('errors');
let hasValidated = this.get('hasValidated');
// if we aren't looking at a specific property we always want an error class
if (!property && !isEmpty(errors)) {
return true;
}
// If we haven't yet validated this field, there is no validation class needed
if (!hasValidated || !hasValidated.contains(property)) {
return false;
}
if (errors) {
return errors.get(property);
}
return false;
})
});