summaryrefslogtreecommitdiff
path: root/app
diff options
context:
space:
mode:
authorFatih Acet <acetfatih@gmail.com>2016-05-28 01:49:18 +0300
committerZ.J. van de Weg <zegerjan@gitlab.com>2016-06-06 11:07:22 +0200
commit40c86c916e252dd3556c0dc526e6a9de505e5de3 (patch)
tree30836599d2ffe1c400881468a37f714147fbfaff /app
parentf261be0949bb589b54359b8fba2bcee9872e69cf (diff)
downloadgitlab-ce-40c86c916e252dd3556c0dc526e6a9de505e5de3.tar.gz
Refactor awardsHandler methods to work with votesBlock.
Diffstat (limited to 'app')
-rw-r--r--app/assets/javascripts/awards_handler.coffee68
-rw-r--r--app/assets/javascripts/notes.js.coffee3
2 files changed, 36 insertions, 35 deletions
diff --git a/app/assets/javascripts/awards_handler.coffee b/app/assets/javascripts/awards_handler.coffee
index 071dbd36641..27b2853e7d1 100644
--- a/app/assets/javascripts/awards_handler.coffee
+++ b/app/assets/javascripts/awards_handler.coffee
@@ -32,7 +32,7 @@ class @AwardsHandler
emoji = $target.find('.icon').data 'emoji'
$target.closest('.js-awards-block').addClass 'current'
- @addAward @getAwardUrl(), emoji
+ @addAward @getVotesBlock(), @getAwardUrl(), emoji
showEmojiMenu: ($addBtn) ->
@@ -100,23 +100,23 @@ class @AwardsHandler
$menu.css(css)
- addAward: (awardUrl, emoji, checkMutuality = yes) ->
+ addAward: (votesBlock, awardUrl, emoji, checkMutuality = yes) ->
emoji = @normilizeEmojiName emoji
@postEmoji awardUrl, emoji, =>
- @addAwardToEmojiBar emoji, checkMutuality
+ @addAwardToEmojiBar votesBlock, emoji, checkMutuality
$('.emoji-menu').removeClass 'is-visible'
- addAwardToEmojiBar: (emoji, checkForMutuality = yes) ->
+ addAwardToEmojiBar: (votesBlock, emoji, checkForMutuality = yes) ->
- @checkMutuality emoji if checkForMutuality
- @addEmojiToFrequentlyUsedList(emoji)
+ @checkMutuality votesBlock, emoji if checkForMutuality
+ @addEmojiToFrequentlyUsedList emoji
- emoji = @normilizeEmojiName(emoji)
- $emojiBtn = @findEmojiIcon(emoji).parent()
+ emoji = @normilizeEmojiName emoji
+ $emojiBtn = @findEmojiIcon(votesBlock, emoji).parent()
if $emojiBtn.length > 0
if @isActive $emojiBtn
@@ -125,10 +125,10 @@ class @AwardsHandler
counter = $emojiBtn.find '.js-counter'
counter.text parseInt(counter.text()) + 1
$emojiBtn.addClass 'active'
- @addMeToUserList emoji
+ @addMeToUserList votesBlock, emoji
else
- @getVotesBlock().removeClass 'hidden'
- @createEmoji emoji
+ votesBlock.removeClass 'hidden'
+ @createEmoji votesBlock, emoji
getVotesBlock: -> return $ '.js-awards-block.current'
@@ -137,7 +137,7 @@ class @AwardsHandler
getAwardUrl: -> return @getVotesBlock().data 'award-url'
- checkMutuality: (emoji) ->
+ checkMutuality: (votesBlock, emoji) ->
awardUrl = @getAwardUrl()
@@ -145,8 +145,8 @@ class @AwardsHandler
mutualVote = if emoji is 'thumbsup' then 'thumbsdown' else 'thumbsup'
selector = "[data-emoji=#{mutualVote}]"
- isAlreadyVoted = @getVotesBlock().find(selector).parent().hasClass 'active'
- @addAward awardUrl, mutualVote, no if isAlreadyVoted
+ isAlreadyVoted = votesBlock.find(selector).parent().hasClass 'active'
+ @addAward votesBlock, awardUrl, mutualVote, no if isAlreadyVoted
isActive: ($emojiBtn) -> $emojiBtn.hasClass 'active'
@@ -155,20 +155,20 @@ class @AwardsHandler
decrementCounter: ($emojiBtn, emoji) ->
counter = $('.js-counter', $emojiBtn)
- counterNumber = parseInt(counter.text())
+ counterNumber = parseInt counter.text(), 10
if counterNumber > 1
- counter.text(counterNumber - 1)
- @removeMeFromUserList($emojiBtn, emoji)
+ counter.text counterNumber - 1
+ @removeMeFromUserList $emojiBtn, emoji
else if emoji is 'thumbsup' or emoji is 'thumbsdown'
- $emojiBtn.tooltip('destroy')
- counter.text('0')
- @removeMeFromUserList($emojiBtn, emoji)
+ $emojiBtn.tooltip 'destroy'
+ counter.text '0'
+ @removeMeFromUserList $emojiBtn, emoji
@removeEmoji $emojiBtn if $emojiBtn.parents('.note').length
else
@removeEmoji $emojiBtn
- $emojiBtn.removeClass('active')
+ $emojiBtn.removeClass 'active'
removeEmoji: ($emojiBtn) ->
@@ -207,9 +207,9 @@ class @AwardsHandler
@resetTooltip(awardBlock)
- addMeToUserList: (emoji) ->
+ addMeToUserList: (votesBlock, emoji) ->
- awardBlock = @findEmojiIcon(emoji).parent()
+ awardBlock = @findEmojiIcon(votesBlock, emoji).parent()
origTitle = @getAwardTooltip awardBlock
users = []
@@ -231,29 +231,29 @@ class @AwardsHandler
), 200
- createEmoji_: (emoji) ->
+ createEmoji_: (votesBlock, emoji) ->
emojiCssClass = @resolveNameToCssClass emoji
-
- buttonHtml = "<button class='btn award-control js-emoji-btn has-tooltip active' title='me' data-placement='bottom'>
+ buttonHtml = "<button class='btn award-control js-emoji-btn has-tooltip active' title='me' data-placement='bottom'>
<div class='icon emoji-icon #{emojiCssClass}' data-emoji='#{emoji}'></div>
<span class='award-control-text js-counter'>1</span>
</button>"
emoji_node = $(buttonHtml)
- .insertBefore '.js-awards-block.current .js-award-holder:not(.js-award-action-btn)'
+ .insertBefore votesBlock.find '.js-award-holder:not(.js-award-action-btn)'
.find '.emoji-icon'
.data 'emoji', emoji
$('.award-control').tooltip()
- $('.js-awards-block.current').removeClass 'current'
+ votesBlock.removeClass 'current'
- createEmoji: (emoji) ->
+ createEmoji: (votesBlock, emoji) ->
- return @createEmoji_ emoji if $('.emoji-menu').length
+ if $('.emoji-menu').length
+ return @createEmoji_ votesBlock, emoji
- @createEmojiMenu @getAwardMenuUrl(), => @createEmoji emoji
+ @createEmojiMenu @getAwardMenuUrl(), => @createEmoji votesBlock, emoji
getAwardMenuUrl: -> return gl.awardMenuUrl or '/emojis'
@@ -278,14 +278,14 @@ class @AwardsHandler
callback.call() if data.ok
- findEmojiIcon: (emoji) ->
+ findEmojiIcon: (votesBlock, emoji) ->
- return $(".js-awards-block.current > .js-emoji-btn [data-emoji='#{emoji}']")
+ return votesBlock.find ".js-emoji-btn [data-emoji='#{emoji}']"
scrollToAwards: ->
- options = scrollTop: $('.awards').offset().top - 80
+ options = scrollTop: $('.awards').offset().top - 110
$('body, html').animate options, 200
diff --git a/app/assets/javascripts/notes.js.coffee b/app/assets/javascripts/notes.js.coffee
index 101154114ba..0fdbe55ea9c 100644
--- a/app/assets/javascripts/notes.js.coffee
+++ b/app/assets/javascripts/notes.js.coffee
@@ -167,7 +167,8 @@ class @Notes
return
if note.award
- awardsHandler.addAwardToEmojiBar(note.name)
+ votesBlock = $('.js-awards-block').eq 0
+ awardsHandler.addAwardToEmojiBar votesBlock, note.name
awardsHandler.scrollToAwards()
# render note if it not present in loaded list