Blame view

lib/jsdom/living/constraint-validation/DefaultConstraintValidation-impl.js 2.42 KB
858f2bdf5   Boyan Georgiev   fixes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
  "use strict";
  
  const ValidityState = require("../generated/ValidityState");
  const { isDisabled } = require("../helpers/form-controls");
  const { closest } = require("../helpers/traversal");
  const { fireAnEvent } = require("../helpers/events");
  
  exports.implementation = class DefaultConstraintValidationImpl {
    // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#dom-cva-willvalidate
    get willValidate() {
      return this._isCandidateForConstraintValidation();
    }
  
    get validity() {
      if (!this._validity) {
        this._validity = ValidityState.createImpl(this._globalObject, [], {
          element: this
        });
      }
      return this._validity;
    }
  
    // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#dom-cva-checkvalidity
    checkValidity() {
      if (!this._isCandidateForConstraintValidation()) {
        return true;
      }
      if (this._satisfiesConstraints()) {
        return true;
      }
      fireAnEvent("invalid", this, undefined, { cancelable: true });
      return false;
    }
  
    // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#dom-cva-setcustomvalidity
    setCustomValidity(message) {
      this._customValidityErrorMessage = message;
    }
  
    // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#dom-cva-reportvalidity
    // Since jsdom has no user interaction, it's the same as #checkValidity
    reportValidity() {
      return this.checkValidity();
    }
  
    // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#dom-cva-validationmessage
    get validationMessage() {
      const { validity } = this;
      if (!this._isCandidateForConstraintValidation() || this._satisfiesConstraints()) {
        return "";
      }
      const isSufferingFromCustomError = validity.customError;
      if (isSufferingFromCustomError) {
        return this._customValidityErrorMessage;
      }
      return "Constraints not satisfied";
    }
  
    _isCandidateForConstraintValidation() {
      // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#attr-fe-disabled
      return !isDisabled(this) &&
        // If an element has a datalist element ancestor,
        // it is barred from constraint validation.
        closest(this, "datalist") === null &&
        !this._barredFromConstraintValidationSpecialization();
    }
  
    _isBarredFromConstraintValidation() {
      return !this._isCandidateForConstraintValidation();
    }
  
    _satisfiesConstraints() {
      return this.validity.valid;
    }
  };