summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/pages/profiles/show/index.js
blob: c9d3bbc8c396632e3f104d5dfb7c4fcde5109450 (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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
import $ from 'jquery';
import createFlash from '~/flash';
import GfmAutoComplete from '~/gfm_auto_complete';
import emojiRegex from 'emoji-regex';
import EmojiMenu from './emoji_menu';

const defaultStatusEmoji = 'speech_balloon';

document.addEventListener('DOMContentLoaded', () => {
  const toggleEmojiMenuButtonSelector = '.js-toggle-emoji-menu';
  const toggleEmojiMenuButton = document.querySelector(toggleEmojiMenuButtonSelector);
  const statusEmojiField = document.getElementById('js-status-emoji-field');
  const statusMessageField = document.getElementById('js-status-message-field');

  const toggleNoEmojiPlaceholder = isVisible => {
    const placeholderElement = document.getElementById('js-no-emoji-placeholder');
    placeholderElement.classList.toggle('hidden', !isVisible);
  };

  const findStatusEmoji = () => toggleEmojiMenuButton.querySelector('gl-emoji');
  const removeStatusEmoji = () => {
    const statusEmoji = findStatusEmoji();
    if (statusEmoji) {
      statusEmoji.remove();
    }
  };

  const selectEmojiCallback = (emoji, emojiTag) => {
    statusEmojiField.value = emoji;
    toggleNoEmojiPlaceholder(false);
    removeStatusEmoji();
    toggleEmojiMenuButton.innerHTML += emojiTag;
  };

  const clearEmojiButton = document.getElementById('js-clear-user-status-button');
  clearEmojiButton.addEventListener('click', () => {
    statusEmojiField.value = '';
    statusMessageField.value = '';
    removeStatusEmoji();
    toggleNoEmojiPlaceholder(true);
  });

  const emojiAutocomplete = new GfmAutoComplete();
  emojiAutocomplete.setup($(statusMessageField), { emojis: true });

  const userNameInput = document.getElementById('user_name');
  userNameInput.addEventListener('input', () => {
    const EMOJI_REGEX = emojiRegex();
    if (EMOJI_REGEX.test(userNameInput.value)) {
      // set field to invalid so it gets detected by GlFieldErrors
      userNameInput.setCustomValidity('Invalid field');
    } else {
      userNameInput.setCustomValidity('');
    }
  });

  import(/* webpackChunkName: 'emoji' */ '~/emoji')
    .then(Emoji => {
      Emoji.initEmojiMap()
        .then(() => {
          const emojiMenu = new EmojiMenu(
            Emoji,
            toggleEmojiMenuButtonSelector,
            'js-status-emoji-menu',
            selectEmojiCallback,
          );
          emojiMenu.bindEvents();

          const defaultEmojiTag = Emoji.glEmojiTag(defaultStatusEmoji);
          statusMessageField.addEventListener('input', () => {
            const hasStatusMessage = statusMessageField.value.trim() !== '';
            const statusEmoji = findStatusEmoji();
            if (hasStatusMessage && statusEmoji) {
              return;
            }

            if (hasStatusMessage) {
              toggleNoEmojiPlaceholder(false);
              toggleEmojiMenuButton.innerHTML += defaultEmojiTag;
            } else if (statusEmoji.dataset.name === defaultStatusEmoji) {
              toggleNoEmojiPlaceholder(true);
              removeStatusEmoji();
            }
          });
        })
        .catch(() => createFlash('Failed to load emoji list.'));
    })
    .catch(() => createFlash('Failed to load emoji list.'));
});