awards_handler.coffee 5.2 KB
Newer Older
V
Valery Sizov 已提交
1
class @AwardsHandler
V
Valery Sizov 已提交
2
  constructor: (@post_emoji_url, @noteable_type, @noteable_id, @aliases) ->
3 4 5 6 7
    $(".add-award").click (event)->
      event.stopPropagation()
      event.preventDefault()
      $(".emoji-menu").show()

8
    $("html").on 'click', (event) ->
9 10 11
      if !$(event.target).closest(".emoji-menu").length
        if $(".emoji-menu").is(":visible")
          $(".emoji-menu").hide()
V
Valery Sizov 已提交
12

13
    @renderFrequentlyUsedBlock()
V
Valery Sizov 已提交
14
    @setupSearch()
15

V
Valery Sizov 已提交
16
  addAward: (emoji) ->
V
Valery Sizov 已提交
17
    emoji = @normilizeEmojiName(emoji)
V
Valery Sizov 已提交
18
    @postEmoji emoji, =>
19
      @addAwardToEmojiBar(emoji)
20 21

    $(".emoji-menu").hide()
22

23
  addAwardToEmojiBar: (emoji) ->
24 25
    @addEmojiToFrequentlyUsedList(emoji)

V
Valery Sizov 已提交
26
    emoji = @normilizeEmojiName(emoji)
27 28 29 30 31 32 33
    if @exist(emoji)
      if @isActive(emoji)
        @decrementCounter(emoji)
      else
        counter = @findEmojiIcon(emoji).siblings(".counter")
        counter.text(parseInt(counter.text()) + 1)
        counter.parent().addClass("active")
V
Valery Sizov 已提交
34
        @addMeToAuthorList(emoji)
35
    else
36
      @createEmoji(emoji)
V
Valery Sizov 已提交
37 38

  exist: (emoji) ->
39
    @findEmojiIcon(emoji).length > 0
V
Valery Sizov 已提交
40 41

  isActive: (emoji) ->
42
    @findEmojiIcon(emoji).parent().hasClass("active")
V
Valery Sizov 已提交
43 44

  decrementCounter: (emoji) ->
45
    counter = @findEmojiIcon(emoji).siblings(".counter")
46
    emojiIcon = counter.parent()
47
    if parseInt(counter.text()) > 0
V
Valery Sizov 已提交
48
      counter.text(parseInt(counter.text()) - 1)
49
      emojiIcon.removeClass("active")
V
Valery Sizov 已提交
50
      @removeMeFromAuthorList(emoji)
51 52 53 54
    else if emoji =="thumbsup" || emoji == "thumbsdown"
      emojiIcon.tooltip("destroy")
      counter.text(0)
      emojiIcon.removeClass("active")
V
Valery Sizov 已提交
55
    else
56 57
      emojiIcon.tooltip("destroy")
      emojiIcon.remove()
V
Valery Sizov 已提交
58

V
Valery Sizov 已提交
59 60 61
  removeMeFromAuthorList: (emoji) ->
    award_block = @findEmojiIcon(emoji).parent()
    authors = award_block.attr("data-original-title").split(", ")
62 63 64
    if authors.indexOf("me") != -1
      authors.splice(authors.indexOf("me"),1)
    award_block.closest(".award").attr("data-original-title", authors.join(", "))
V
Valery Sizov 已提交
65 66 67 68
    @resetTooltip(award_block)

  addMeToAuthorList: (emoji) ->
    award_block = @findEmojiIcon(emoji).parent()
69 70 71 72
    origTitle = award_block.attr("data-original-title").trim()
    authors = []
    if origTitle
      authors = origTitle.split(', ')
73 74 75
    if authors.indexOf("me") == -1
      authors.push("me")
    award_block.attr("title", authors.join(", "))
V
Valery Sizov 已提交
76 77 78 79 80
    @resetTooltip(award_block)

  resetTooltip: (award) ->
    award.tooltip("destroy")

V
Valery Sizov 已提交
81
    # "destroy" call is asynchronous and there is no appropriate callback on it, this is why we need to set timeout.
V
Valery Sizov 已提交
82 83 84
    setTimeout (->
      award.tooltip()
    ), 200
85

V
Valery Sizov 已提交
86

87 88 89
  createEmoji: (emoji) ->
    emojiCssClass = @resolveNameToCssClass(emoji)

V
Valery Sizov 已提交
90
    nodes = []
V
Valery Sizov 已提交
91
    nodes.push("<div class='award active' title='me'>")
V
Valery Sizov 已提交
92
    nodes.push("<div class='icon emoji-icon #{emojiCssClass}' data-emoji='#{emoji}'></div>")
93
    nodes.push("<div class='counter'>1</div>")
V
Valery Sizov 已提交
94 95
    nodes.push("</div>")

96
    emoji_node = $(nodes.join("\n")).insertBefore(".awards-controls").find(".emoji-icon").data("emoji", emoji)
V
Valery Sizov 已提交
97

V
Valery Sizov 已提交
98 99
    $(".award").tooltip()

100
  resolveNameToCssClass: (emoji) ->
V
Valery Sizov 已提交
101
    emoji_icon = $(".emoji-menu-content [data-emoji='#{emoji}']")
102

V
Valery Sizov 已提交
103 104 105 106 107 108 109
    if emoji_icon.length > 0
      unicodeName = emoji_icon.data("unicode-name")
    else
      # Find by alias
      unicodeName = $(".emoji-menu-content [data-aliases*=':#{emoji}:']").data("unicode-name")

    "emoji-#{unicodeName}"
V
Valery Sizov 已提交
110 111

  postEmoji: (emoji, callback) ->
V
Valery Sizov 已提交
112
    $.post @post_emoji_url, { note: {
V
Valery Sizov 已提交
113
      note: ":#{emoji}:"
V
Valery Sizov 已提交
114 115
      noteable_type: @noteable_type
      noteable_id: @noteable_id
V
Valery Sizov 已提交
116
    }},(data) ->
V
Valery Sizov 已提交
117
      if data.ok
118 119 120
        callback.call()

  findEmojiIcon: (emoji) ->
V
Valery Sizov 已提交
121
    $(".award [data-emoji='#{emoji}']")
122 123 124 125 126

  scrollToAwards: ->
    $('body, html').animate({
      scrollTop: $('.awards').offset().top - 80
    }, 200)
V
Valery Sizov 已提交
127 128 129

  normilizeEmojiName: (emoji) ->
    @aliases[emoji] || emoji
130 131 132 133 134 135 136 137 138 139 140

  addEmojiToFrequentlyUsedList: (emoji) ->
    frequently_used_emojis = @getFrequentlyUsedEmojis()
    frequently_used_emojis.push(emoji)
    $.cookie('frequently_used_emojis', frequently_used_emojis.join(","), { expires: 365 })

  getFrequentlyUsedEmojis: ->
    frequently_used_emojis = ($.cookie('frequently_used_emojis') || "").split(",")
    _.compact(_.uniq(frequently_used_emojis))

  renderFrequentlyUsedBlock: ->
141 142
    if $.cookie('frequently_used_emojis')
      frequently_used_emojis = @getFrequentlyUsedEmojis()
143

144
      ul = $("<ul>")
145

146 147 148
      for emoji in frequently_used_emojis
        do (emoji) ->
          $(".emoji-menu-content [data-emoji='#{emoji}']").closest("li").clone().appendTo(ul)
149

150
      $("input.emoji-search").after(ul).after($("<h5>").text("Frequently used"))
151

V
Valery Sizov 已提交
152
  setupSearch: ->
V
Valery Sizov 已提交
153
    $("input.emoji-search").keyup (ev) =>
V
Valery Sizov 已提交
154 155 156 157 158 159
      term = $(ev.target).val()

      # Clean previous search results
      $("ul.emoji-search,h5.emoji-search").remove()

      if term
V
Valery Sizov 已提交
160
        # Generate a search result block
V
Valery Sizov 已提交
161 162 163 164 165 166 167 168 169
        h5 = $("<h5>").text("Search results").addClass("emoji-search")
        found_emojis = @searchEmojis(term).show()
        ul = $("<ul>").addClass("emoji-search").append(found_emojis)
        $(".emoji-menu-content ul, .emoji-menu-content h5").hide()
        $(".emoji-menu-content").append(h5).append(ul)
      else
        $(".emoji-menu-content").children().show()

  searchEmojis: (term)->
V
Valery Sizov 已提交
170
    $(".emoji-menu-content [data-emoji*='#{term}']").closest("li").clone()