Welcome to mirror list, hosted at ThFree Co, Russian Federation.

index.js « show « profiles « pages « javascripts « assets « app - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: b544112779724c7766c2bc34049798274c9bfe7b (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
import emojiRegex from 'emoji-regex';
import $ from 'jquery';
import GfmAutoComplete from 'ee_else_ce/gfm_auto_complete';
import * as Emoji from '~/emoji';
import { deprecatedCreateFlash as createFlash } from '~/flash';
import { __ } from '~/locale';
import EmojiMenu from './emoji_menu';

const defaultStatusEmoji = 'speech_balloon';
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('');
  }
});

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.')));