summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/emoji/no_emoji_validator.js
blob: 0fd4dd7495305d0edbe842462d1ac617710f1058 (plain)
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
import { __ } from '~/locale';
import emojiRegex from 'emoji-regex';

const invalidInputClass = 'gl-field-error-outline';

export default class NoEmojiValidator {
  constructor(opts = {}) {
    const container = opts.container || '';
    this.noEmojiEmelents = document.querySelectorAll(`${container} .js-block-emoji`);

    this.noEmojiEmelents.forEach(element =>
      element.addEventListener('input', this.eventHandler.bind(this)),
    );
  }

  eventHandler(event) {
    this.inputDomElement = event.target;
    this.inputErrorMessage = this.inputDomElement.nextSibling;

    const { value } = this.inputDomElement;

    this.validatePattern(value);
    this.setValidationStateAndMessage();
  }

  validatePattern(value) {
    const pattern = emojiRegex();
    this.hasEmojis = new RegExp(pattern).test(value);

    if (this.hasEmojis) {
      this.inputDomElement.setCustomValidity(__('Invalid input, please avoid emojis'));
    } else {
      this.inputDomElement.setCustomValidity('');
    }
  }

  setValidationStateAndMessage() {
    if (!this.inputDomElement.checkValidity()) {
      this.setInvalidState();
    } else {
      this.clearFieldValidationState();
    }
  }

  clearFieldValidationState() {
    this.inputDomElement.classList.remove(invalidInputClass);
    this.inputErrorMessage.classList.add('hide');
  }

  setInvalidState() {
    this.inputDomElement.classList.add(invalidInputClass);
    this.setErrorMessage();
  }

  setErrorMessage() {
    if (this.hasEmojis) {
      this.inputErrorMessage.innerHTML = this.inputDomElement.validationMessage;
    } else {
      this.inputErrorMessage.innerHTML = this.inputDomElement.title;
    }
    this.inputErrorMessage.classList.remove('hide');
  }
}