debian-mirror-gitlab/app/assets/javascripts/users_select.js.coffee

122 lines
3.6 KiB
CoffeeScript
Raw Normal View History

2015-04-26 12:48:37 +05:30
class @UsersSelect
constructor: ->
@usersPath = "/autocomplete/users.json"
@userPath = "/autocomplete/users/:id.json"
$('.ajax-users-select').each (i, select) =>
@projectId = $(select).data('project-id')
@groupId = $(select).data('group-id')
2015-09-11 14:41:01 +05:30
@showCurrentUser = $(select).data('current-user')
2015-04-26 12:48:37 +05:30
showNullUser = $(select).data('null-user')
showAnyUser = $(select).data('any-user')
showEmailUser = $(select).data('email-user')
firstUser = $(select).data('first-user')
$(select).select2
placeholder: "Search for a user"
multiple: $(select).hasClass('multiselect')
minimumInputLength: 0
query: (query) =>
@users query.term, (users) =>
data = { results: users }
if query.term.length == 0
if firstUser
# Move current user to the front of the list
for obj, index in data.results
if obj.username == firstUser
data.results.splice(index, 1)
data.results.unshift(obj)
break
if showNullUser
nullUser = {
name: 'Unassigned',
id: 0
}
data.results.unshift(nullUser)
if showAnyUser
2015-12-23 02:04:40 +05:30
name = showAnyUser
name = 'Any User' if name == true
2015-04-26 12:48:37 +05:30
anyUser = {
2015-12-23 02:04:40 +05:30
name: name,
2015-04-26 12:48:37 +05:30
id: null
}
data.results.unshift(anyUser)
if showEmailUser && data.results.length == 0 && query.term.match(/^[^@]+@[^@]+$/)
emailUser = {
name: "Invite \"#{query.term}\"",
username: query.term,
id: query.term
}
data.results.unshift(emailUser)
query.callback(data)
2015-12-23 02:04:40 +05:30
initSelection: (args...) =>
@initSelection(args...)
2015-04-26 12:48:37 +05:30
formatResult: (args...) =>
@formatResult(args...)
formatSelection: (args...) =>
@formatSelection(args...)
dropdownCssClass: "ajax-users-dropdown"
escapeMarkup: (m) -> # we do not want to escape markup since we are displaying html in results
m
2015-12-23 02:04:40 +05:30
initSelection: (element, callback) ->
id = $(element).val()
if id == "0"
nullUser = { name: 'Unassigned' }
callback(nullUser)
else if id != ""
@user(id, callback)
2015-04-26 12:48:37 +05:30
formatResult: (user) ->
2014-09-02 18:07:02 +05:30
if user.avatar_url
avatar = user.avatar_url
else
avatar = gon.default_avatar_url
2015-12-23 02:04:40 +05:30
"<div class='user-result #{'no-username' unless user.username}'>
2014-09-02 18:07:02 +05:30
<div class='user-image'><img class='avatar s24' src='#{avatar}'></div>
<div class='user-name'>#{user.name}</div>
2015-12-23 02:04:40 +05:30
<div class='user-username'>#{user.username || ""}</div>
2014-09-02 18:07:02 +05:30
</div>"
2015-04-26 12:48:37 +05:30
formatSelection: (user) ->
2014-09-02 18:07:02 +05:30
user.name
2015-04-26 12:48:37 +05:30
user: (user_id, callback) =>
url = @buildUrl(@userPath)
url = url.replace(':id', user_id)
$.ajax(
url: url
dataType: "json"
).done (user) ->
callback(user)
# Return users list. Filtered by query
# Only active users retrieved
users: (query, callback) =>
url = @buildUrl(@usersPath)
$.ajax(
url: url
data:
search: query
per_page: 20
active: true
project_id: @projectId
group_id: @groupId
2015-09-11 14:41:01 +05:30
current_user: @showCurrentUser
2015-04-26 12:48:37 +05:30
dataType: "json"
).done (users) ->
callback(users)
buildUrl: (url) ->
url = gon.relative_url_root.replace(/\/$/, '') + url if gon.relative_url_root?
2015-04-26 12:48:37 +05:30
return url