mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-18 16:01:40 +03:00
c3487fea41
refs https://github.com/TryGhost/Ghost/issues/14101 - migrated component to Glimmer - swapped usage of `ValidationState` mixin for `{{validation-status}}` modifier - updated modifier to accept custom error/success classes - removed unnecessary/unused code in the `gh-benefit-item.js` backing class
43 lines
1.3 KiB
JavaScript
43 lines
1.3 KiB
JavaScript
import Modifier from 'ember-modifier';
|
|
import {isEmpty} from '@ember/utils';
|
|
|
|
const ERROR_CLASS = 'error';
|
|
const SUCCESS_CLASS = 'success';
|
|
|
|
export default class ValidationStatusModifier extends Modifier {
|
|
modify(element, positional, {errors, property, hasValidated, errorClass = ERROR_CLASS, successClass = SUCCESS_CLASS}) {
|
|
const hasError = this.hasError(errors, property, hasValidated);
|
|
|
|
let validationClass = '';
|
|
|
|
if (!property || hasValidated?.includes(property)) {
|
|
validationClass = hasError ? errorClass : successClass;
|
|
}
|
|
|
|
element.classList.remove(errorClass);
|
|
element.classList.remove(successClass);
|
|
|
|
if (validationClass) {
|
|
element.classList.add(validationClass);
|
|
}
|
|
}
|
|
|
|
hasError(errors, property, hasValidated) {
|
|
// if we aren't looking at a specific property we always want an error class
|
|
if (!property && errors && !errors.get('isEmpty')) {
|
|
return true;
|
|
}
|
|
|
|
// If we haven't yet validated this field, there is no validation class needed
|
|
if (!hasValidated || !hasValidated.includes(property)) {
|
|
return false;
|
|
}
|
|
|
|
if (errors && !isEmpty(errors.errorsFor(property))) {
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
}
|