mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 10:59:30 +03:00
f2da8a20b8
closes https://github.com/TryGhost/Ghost/issues/8690 - https://github.com/ember-cli/eslint-plugin-ember/blob/master/docs/rules/no-observers.md - remove observers where possible - move night shift toggle behaviour to the feature service - refresh feature service after import to fix stuck night shift toggle
47 lines
1.3 KiB
JavaScript
47 lines
1.3 KiB
JavaScript
import Mixin from '@ember/object/mixin';
|
|
import {A as emberA} from '@ember/array';
|
|
import {isEmpty} from '@ember/utils';
|
|
import {observer} from '@ember/object';
|
|
import {run} from '@ember/runloop';
|
|
|
|
export default Mixin.create({
|
|
|
|
errors: null,
|
|
property: '',
|
|
hasValidated: emberA(),
|
|
|
|
hasError: false,
|
|
|
|
setHasError() {
|
|
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 && errors && !errors.get('isEmpty')) {
|
|
this.set('hasError', true);
|
|
return;
|
|
}
|
|
|
|
// If we haven't yet validated this field, there is no validation class needed
|
|
if (!hasValidated || !hasValidated.includes(property)) {
|
|
this.set('hasError', false);
|
|
return;
|
|
}
|
|
|
|
if (errors && !isEmpty(errors.errorsFor(property))) {
|
|
this.set('hasError', true);
|
|
return;
|
|
}
|
|
|
|
this.set('hasError', false);
|
|
},
|
|
|
|
// eslint-disable-next-line ghost/ember/no-observers
|
|
hasErrorObserver: observer('errors.[]', 'property', 'hasValidated.[]', function () {
|
|
run.once(this, 'setHasError');
|
|
// this.setHasError();
|
|
}).on('init')
|
|
|
|
});
|