gitlab-org--gitlab-foss/app/assets/javascripts/LabelManager.js.coffee

85 lines
2.2 KiB
CoffeeScript
Raw Normal View History

2016-05-02 19:19:46 -04:00
class @LabelManager
2016-06-03 02:15:32 -04:00
errorMessage: 'Unable to update label prioritization at this time'
2016-05-02 19:19:46 -04:00
constructor: (opts = {}) ->
# Defaults
{
@togglePriorityButton = $('.js-toggle-priority')
@prioritizedLabels = $('.js-prioritized-labels')
@otherLabels = $('.js-other-labels')
} = opts
@prioritizedLabels.sortable(
items: 'li'
2016-05-19 01:46:09 -04:00
placeholder: 'list-placeholder'
axis: 'y'
2016-05-02 19:19:46 -04:00
update: @onPrioritySortUpdate.bind(@)
)
@bindEvents()
bindEvents: ->
@togglePriorityButton.on 'click', @, @onTogglePriorityClick
onTogglePriorityClick: (e) ->
e.preventDefault()
_this = e.data
$btn = $(e.currentTarget)
$label = $("##{$btn.data('domId')}")
action = if $btn.parents('.js-prioritized-labels').length then 'remove' else 'add'
_this.toggleLabelPriority($label, action)
2016-06-03 02:15:32 -04:00
toggleLabelPriority: ($label, action, persistState = true) ->
2016-05-02 19:19:46 -04:00
_this = @
url = $label.find('.js-toggle-priority').data 'url'
$target = @prioritizedLabels
$from = @otherLabels
# Optimistic update
if action is 'remove'
$target = @otherLabels
$from = @prioritizedLabels
if $from.find('li').length is 1
$from.find('.empty-message').show()
if not $target.find('li').length
$target.find('.empty-message').hide()
$label.detach().appendTo($target)
# Return if we are not persisting state
2016-06-03 02:15:32 -04:00
return unless persistState
2016-05-02 19:19:46 -04:00
if action is 'remove'
xhr = $.ajax url: url, type: 'DELETE'
else
2016-06-03 02:15:32 -04:00
xhr = @savePrioritySort($label, action)
2016-05-02 19:19:46 -04:00
2016-06-03 02:15:32 -04:00
xhr.fail @rollbackLabelPosition.bind(@, $label, action)
2016-05-02 19:19:46 -04:00
2016-06-03 02:15:32 -04:00
onPrioritySortUpdate: ->
xhr = @savePrioritySort()
2016-05-02 19:19:46 -04:00
xhr.fail ->
2016-06-03 02:15:32 -04:00
new Flash(@errorMessage, 'alert')
savePrioritySort: () ->
$.post
url: @prioritizedLabels.data('url')
data:
label_ids: @getSortedLabelsIds()
rollbackLabelPosition: ($label, originalAction)->
action = if originalAction is 'remove' then 'add' else 'remove'
@toggleLabelPriority($label, action, false)
new Flash(@errorMessage, 'alert')
2016-05-02 19:19:46 -04:00
getSortedLabelsIds: ->
sortedIds = []
@prioritizedLabels.find('li').each ->
sortedIds.push $(@).data 'id'
sortedIds