gitlab-org--gitlab-foss/app/assets/javascripts/awards_handler.coffee

169 lines
5.2 KiB
CoffeeScript
Raw Normal View History

2015-11-11 13:12:51 +00:00
class @AwardsHandler
2015-12-11 11:10:00 +00:00
constructor: (@post_emoji_url, @noteable_type, @noteable_id, @aliases) ->
$(".add-award").click (event)->
event.stopPropagation()
event.preventDefault()
$(".emoji-menu").show()
$("html").on 'click', (event) ->
if !$(event.target).closest(".emoji-menu").length
if $(".emoji-menu").is(":visible")
$(".emoji-menu").hide()
2015-11-11 13:12:51 +00:00
@renderFrequentlyUsedBlock()
2015-12-23 10:01:31 +00:00
@setupSearch()
2015-11-11 13:12:51 +00:00
addAward: (emoji) ->
2015-12-11 11:10:00 +00:00
emoji = @normilizeEmojiName(emoji)
2015-11-11 13:12:51 +00:00
@postEmoji emoji, =>
@addAwardToEmojiBar(emoji)
$(".emoji-menu").hide()
addAwardToEmojiBar: (emoji) ->
@addEmojiToFrequentlyUsedList(emoji)
2015-12-11 11:10:00 +00:00
emoji = @normilizeEmojiName(emoji)
if @exist(emoji)
if @isActive(emoji)
@decrementCounter(emoji)
else
counter = @findEmojiIcon(emoji).siblings(".counter")
counter.text(parseInt(counter.text()) + 1)
counter.parent().addClass("active")
2015-11-18 13:43:53 +00:00
@addMeToAuthorList(emoji)
else
@createEmoji(emoji)
2015-11-11 13:12:51 +00:00
exist: (emoji) ->
@findEmojiIcon(emoji).length > 0
2015-11-11 13:12:51 +00:00
isActive: (emoji) ->
@findEmojiIcon(emoji).parent().hasClass("active")
2015-11-11 13:12:51 +00:00
decrementCounter: (emoji) ->
counter = @findEmojiIcon(emoji).siblings(".counter")
emojiIcon = counter.parent()
if parseInt(counter.text()) > 1
2015-11-11 13:12:51 +00:00
counter.text(parseInt(counter.text()) - 1)
emojiIcon.removeClass("active")
2015-11-18 13:43:53 +00:00
@removeMeFromAuthorList(emoji)
else if emoji =="thumbsup" || emoji == "thumbsdown"
emojiIcon.tooltip("destroy")
counter.text(0)
emojiIcon.removeClass("active")
2015-11-11 13:12:51 +00:00
else
emojiIcon.tooltip("destroy")
emojiIcon.remove()
2015-11-11 13:12:51 +00:00
2015-11-18 13:43:53 +00:00
removeMeFromAuthorList: (emoji) ->
award_block = @findEmojiIcon(emoji).parent()
authors = award_block.attr("data-original-title").split(", ")
authors.splice(authors.indexOf("me"),1)
award_block.closest(".award").attr("data-original-title", authors.join(", "))
2015-11-18 13:43:53 +00:00
@resetTooltip(award_block)
addMeToAuthorList: (emoji) ->
award_block = @findEmojiIcon(emoji).parent()
origTitle = award_block.attr("data-original-title").trim()
authors = []
if origTitle
authors = origTitle.split(', ')
authors.push("me")
award_block.attr("title", authors.join(", "))
2015-11-18 13:43:53 +00:00
@resetTooltip(award_block)
resetTooltip: (award) ->
award.tooltip("destroy")
2015-12-22 18:02:22 +00:00
# "destroy" call is asynchronous and there is no appropriate callback on it, this is why we need to set timeout.
2015-11-18 13:43:53 +00:00
setTimeout (->
award.tooltip()
), 200
2015-11-11 13:12:51 +00:00
createEmoji: (emoji) ->
emojiCssClass = @resolveNameToCssClass(emoji)
2015-11-11 13:12:51 +00:00
nodes = []
2015-11-18 13:43:53 +00:00
nodes.push("<div class='award active' title='me'>")
2015-12-24 09:28:51 +00:00
nodes.push("<div class='icon emoji-icon #{emojiCssClass}' data-emoji='#{emoji}'></div>")
nodes.push("<div class='counter'>1</div>")
2015-11-11 13:12:51 +00:00
nodes.push("</div>")
emoji_node = $(nodes.join("\n")).insertBefore(".awards-controls").find(".emoji-icon").data("emoji", emoji)
2015-11-11 13:12:51 +00:00
2015-11-18 13:43:53 +00:00
$(".award").tooltip()
resolveNameToCssClass: (emoji) ->
2015-12-24 09:28:51 +00:00
emoji_icon = $(".emoji-menu-content [data-emoji='#{emoji}']")
2015-12-24 09:28:51 +00:00
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}"
2015-11-11 13:12:51 +00:00
postEmoji: (emoji, callback) ->
2015-11-19 16:12:17 +00:00
$.post @post_emoji_url, { note: {
2015-12-24 09:28:51 +00:00
note: ":#{emoji}:"
2015-11-11 13:12:51 +00:00
noteable_type: @noteable_type
noteable_id: @noteable_id
2015-11-19 16:12:17 +00:00
}},(data) ->
2015-11-11 13:12:51 +00:00
if data.ok
callback.call()
findEmojiIcon: (emoji) ->
2015-12-24 09:28:51 +00:00
$(".award [data-emoji='#{emoji}']")
scrollToAwards: ->
$('body, html').animate({
scrollTop: $('.awards').offset().top - 80
}, 200)
2015-12-11 11:10:00 +00:00
normilizeEmojiName: (emoji) ->
@aliases[emoji] || emoji
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: ->
if $.cookie('frequently_used_emojis')
frequently_used_emojis = @getFrequentlyUsedEmojis()
ul = $("<ul>")
for emoji in frequently_used_emojis
do (emoji) ->
$(".emoji-menu-content [data-emoji='#{emoji}']").closest("li").clone().appendTo(ul)
$("input.emoji-search").after(ul).after($("<h5>").text("Frequently used"))
2015-12-23 10:01:31 +00:00
setupSearch: ->
2015-12-24 09:57:46 +00:00
$("input.emoji-search").keyup (ev) =>
2015-12-23 10:01:31 +00:00
term = $(ev.target).val()
# Clean previous search results
$("ul.emoji-search,h5.emoji-search").remove()
if term
2015-12-24 13:44:43 +00:00
# Generate a search result block
2015-12-23 10:01:31 +00:00
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)->
2015-12-24 09:57:46 +00:00
$(".emoji-menu-content [data-emoji*='#{term}']").closest("li").clone()