2014-10-21 18:19:16 -04:00
|
|
|
class @UsersSelect
|
|
|
|
constructor: ->
|
|
|
|
$('.ajax-users-select').each (i, select) =>
|
|
|
|
$(select).select2
|
|
|
|
placeholder: "Search for a user"
|
|
|
|
multiple: $(select).hasClass('multiselect')
|
|
|
|
minimumInputLength: 0
|
|
|
|
query: (query) ->
|
|
|
|
Api.users query.term, (users) ->
|
|
|
|
data = { results: users }
|
|
|
|
query.callback(data)
|
|
|
|
|
|
|
|
initSelection: (element, callback) ->
|
|
|
|
id = $(element).val()
|
|
|
|
if id isnt ""
|
|
|
|
Api.user(id, callback)
|
|
|
|
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
formatResult: (user) ->
|
2014-02-13 08:45:24 -05:00
|
|
|
if user.avatar_url
|
2014-06-13 10:46:48 -04:00
|
|
|
avatar = user.avatar_url
|
2014-02-11 08:49:39 -05:00
|
|
|
else
|
2014-06-13 10:46:48 -04:00
|
|
|
avatar = gon.default_avatar_url
|
2013-12-20 12:31:45 -05:00
|
|
|
|
|
|
|
"<div class='user-result'>
|
|
|
|
<div class='user-image'><img class='avatar s24' src='#{avatar}'></div>
|
|
|
|
<div class='user-name'>#{user.name}</div>
|
|
|
|
<div class='user-username'>#{user.username}</div>
|
|
|
|
</div>"
|
2013-03-13 15:37:13 -04:00
|
|
|
|
2014-10-21 18:19:16 -04:00
|
|
|
formatSelection: (user) ->
|
2013-03-13 15:42:14 -04:00
|
|
|
user.name
|