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

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorZeger-Jan van de Weg <zegerjan@gitlab.com>2016-05-11 23:33:27 +0300
committerZeger-Jan van de Weg <zegerjan@gitlab.com>2016-05-11 23:33:27 +0300
commitd8c27e4e2b332cb9ece780bfb06155c3d1739d92 (patch)
treec788e9219f37ea9f8fff1c206023634126618ef1 /app/assets/javascripts/awards_handler.coffee
parent7e6dcf9cd0626c6d0cbbe96ae5327048d2c6849f (diff)
merge awards-handler.coffee from another branch
Diffstat (limited to 'app/assets/javascripts/awards_handler.coffee')
-rw-r--r--app/assets/javascripts/awards_handler.coffee97
1 files changed, 48 insertions, 49 deletions
diff --git a/app/assets/javascripts/awards_handler.coffee b/app/assets/javascripts/awards_handler.coffee
index c18c9984c1f..043ad697dfe 100644
--- a/app/assets/javascripts/awards_handler.coffee
+++ b/app/assets/javascripts/awards_handler.coffee
@@ -1,26 +1,26 @@
class @AwardsHandler
constructor: ->
- @aliases = gl.emoji.emojiAliases()
+ @aliases = emojiAliases()
$(document)
.off "click", ".js-add-award"
- .on "click", ".js-add-award", (e) =>
- e.stopPropagation()
- e.preventDefault()
+ .on "click", ".js-add-award", (event) =>
+ event.stopPropagation()
+ event.preventDefault()
- @showEmojiMenu $(e.currentTarget)
+ @showEmojiMenu $(event.currentTarget)
- $("html").on 'click', (e) ->
- if !$(e.target).closest(".emoji-menu").length
+ $("html").on 'click', (event) ->
+ if !$(event.target).closest(".emoji-menu").length
if $(".emoji-menu").is(":visible")
$('.js-add-award.is-active').removeClass 'is-active'
$(".emoji-menu").removeClass "is-visible"
$(document)
.off "click", ".js-emoji-btn"
- .on "click", ".js-emoji-btn", @handleClick.bind(@)
+ .on "click", ".js-emoji-btn", @handleClick
- handleClick: (e) ->
+ handleClick: (e) =>
e.preventDefault()
$emojiBtn = $(e.currentTarget)
$addAwardBtn = $('.js-add-award.is-active')
@@ -31,27 +31,16 @@ class @AwardsHandler
else if $votesBlock.length is 0
$votesBlock = $addAwardBtn.closest('.js-awards-block')
- @currentVoteBlock = $votesBlock
-
+ $votesBlock.addClass 'js-awards-block-current'
awardUrl = $votesBlock.data 'award-url'
emoji = $emojiBtn
.find(".icon")
.data "emoji"
-
- if emoji is "thumbsup" and @didUserClickEmoji $emojiBtn, "thumbsdown"
- @addAward awardUrl, "thumbsdown"
-
- else if emoji is "thumbsdown" and @didUserClickEmoji $emojiBtn, "thumbsup"
- @addAward awardUrl, "thumbsup"
-
@addAward awardUrl, emoji
- didUserClickEmoji: (emojiBtn, emoji) ->
- if emojiBtn.siblings("button:has([data-emoji=#{emoji}])").attr("data-original-title")
- emojiBtn.siblings("button:has([data-emoji=#{emoji}])").attr("data-original-title").indexOf('me') > -1
-
showEmojiMenu: ($addBtn) ->
$menu = $('.emoji-menu')
+
if $menu.length
$holder = $addBtn.closest('.js-award-holder')
@@ -60,7 +49,6 @@ class @AwardsHandler
$menu.removeClass "is-visible"
$("#emoji_search").blur()
else
- $(".emoji-menu").addClass "is-visible"
$addBtn.addClass "is-active"
@positionMenu($menu, $addBtn)
@@ -77,6 +65,7 @@ class @AwardsHandler
@positionMenu($menu, $addBtn)
@renderFrequentlyUsedBlock()
+
setTimeout =>
$menu.addClass "is-visible"
$("#emoji_search").focus()
@@ -101,16 +90,18 @@ class @AwardsHandler
$menu.css(css)
addAward: (awardUrl, emoji) ->
- emoji = @normilizeEmojiName(emoji)
+ emoji = @normalizeEmojiName(emoji)
@postEmoji awardUrl, emoji, =>
@addAwardToEmojiBar(emoji)
- $('.emoji-menu').removeClass 'is-visible'
+ $('.js-awards-block-current').removeClass 'js-awards-block-current'
+
+ $(".emoji-menu").removeClass "is-visible"
addAwardToEmojiBar: (emoji) ->
@addEmojiToFrequentlyUsedList(emoji)
- emoji = @normilizeEmojiName(emoji)
+ emoji = @normalizeEmojiName(emoji)
$emojiBtn = @findEmojiIcon(emoji).parent()
if $emojiBtn.length > 0
@@ -146,12 +137,16 @@ class @AwardsHandler
$emojiBtn.removeClass("active")
+ if !isntNoteBody and $awardsBlock.children('.js-emoji-btn').length is 0
+ # If this is a note body, we just hide the award emoji row like the initial state
+ $awardsBlock.addClass 'hidden'
+
removeMeFromUserList: ($emojiBtn, emoji) ->
award_block = $emojiBtn
authors = award_block
.attr("data-original-title")
.split(", ")
- authors.splice(authors.indexOf("me"), 1)
+ authors.splice(authors.indexOf("me"),1)
award_block
.closest(".js-emoji-btn")
.attr("data-original-title", authors.join(", "))
@@ -164,17 +159,18 @@ class @AwardsHandler
if origTitle
users = origTitle.split(', ')
users.push("me")
- award_block.attr("data-original-title", users.join(", "))
+ award_block.attr("title", users.join(", "))
@resetTooltip(award_block)
resetTooltip: (award) ->
- award.tooltip('destroy')
+ award.tooltip("destroy")
# "destroy" call is asynchronous and there is no appropriate callback on it, this is why we need to set timeout.
setTimeout (->
award.tooltip()
), 200
+
createEmoji: (emoji) ->
emojiCssClass = @resolveNameToCssClass(emoji)
@@ -194,13 +190,13 @@ class @AwardsHandler
$currentBlock.removeClass 'hidden'
resolveNameToCssClass: (emoji) ->
- emojiIcon = $(".emoji-menu-content [data-emoji='#{emoji}']")
+ emoji_icon = $(".emoji-menu-content [data-emoji='#{emoji}']")
- if emojiIcon.length > 0
- unicodeName = emojiIcon.data('unicode-name')
+ 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')
+ unicodeName = $(".emoji-menu-content [data-aliases*=':#{emoji}:']").data("unicode-name")
"emoji-#{unicodeName}"
@@ -210,49 +206,52 @@ class @AwardsHandler
callback.call()
findEmojiIcon: (emoji) ->
- @currentVoteBlock.find(".js-emoji-btn [data-emoji='#{emoji}']")
+ $(".js-awards-block-current.awards > .js-emoji-btn [data-emoji='#{emoji}']")
scrollToAwards: ->
$('body, html').animate({
scrollTop: $('.awards').offset().top - 80
}, 200)
+ normalizeEmojiName: (emoji) ->
+ @aliases[emoji] || emoji
+
addEmojiToFrequentlyUsedList: (emoji) ->
- frequentlyUsedEmojis = @getFrequentlyUsedEmojis()
- frequentlyUsedEmojis.push(emoji)
- $.cookie('frequently_used_emojis', frequentlyUsedEmojis.join(','), { expires: 365 })
+ frequently_used_emojis = @getFrequentlyUsedEmojis()
+ frequently_used_emojis.push(emoji)
+ $.cookie('frequently_used_emojis', frequently_used_emojis.join(","), { expires: 365 })
getFrequentlyUsedEmojis: ->
- frequentlyUsedEmojis = ($.cookie('frequently_used_emojis') || '').split(',')
- _.compact(_.uniq(frequentlyUsedEmojis))
+ frequently_used_emojis = ($.cookie('frequently_used_emojis') || "").split(",")
+ _.compact(_.uniq(frequently_used_emojis))
renderFrequentlyUsedBlock: ->
if $.cookie('frequently_used_emojis')
- frequentlyUsedEmojis = @getFrequentlyUsedEmojis()
+ frequently_used_emojis = @getFrequentlyUsedEmojis()
ul = $("<ul class='clearfix emoji-menu-list'>")
for emoji in frequently_used_emojis
$(".emoji-menu-content [data-emoji='#{emoji}']").closest("li").clone().appendTo(ul)
- $('input.emoji-search').after(ul).after($('<h5>').text('Frequently used'))
+ $("input.emoji-search").after(ul).after($("<h5>").text("Frequently used"))
setupSearch: ->
- $('input.emoji-search').keyup (ev) =>
+ $("input.emoji-search").on 'keyup', (ev) =>
term = $(ev.target).val()
# Clean previous search results
- $('ul.emoji-menu-search, h5.emoji-search').remove()
+ $("ul.emoji-menu-search, h5.emoji-search").remove()
if term
# Generate a search result block
- h5 = $('<h5>').text('Search results').addClass('emoji-search')
- foundEmojis = @searchEmojis(term).show()
- ul = $('<ul>').addClass('emoji-menu-list emoji-menu-search').append(foundEmojis)
- $('.emoji-menu-content ul, .emoji-menu-content h5').hide()
- $('.emoji-menu-content').append(h5).append(ul)
+ h5 = $("<h5>").text("Search results").addClass("emoji-search")
+ found_emojis = @searchEmojis(term).show()
+ ul = $("<ul>").addClass("emoji-menu-list emoji-menu-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()
+ $(".emoji-menu-content").children().show()
searchEmojis: (term)->
$(".emoji-menu-content [data-emoji*='#{term}']").closest("li").clone()