2013-03-13 15:37:13 -04:00
|
|
|
$ ->
|
|
|
|
userFormatResult = (user) ->
|
|
|
|
avatar = gon.gravatar_url
|
|
|
|
avatar = avatar.replace('%{hash}', md5(user.email))
|
|
|
|
avatar = avatar.replace('%{size}', '24')
|
|
|
|
|
|
|
|
markup = "<div class='user-result'>"
|
|
|
|
markup += "<div class='user-image'><img class='avatar s24' src='" + avatar + "'></div>"
|
|
|
|
markup += "<div class='user-name'>" + user.name + "</div>"
|
|
|
|
markup += "<div class='user-username'>" + user.username + "</div>"
|
|
|
|
markup += "</div>"
|
|
|
|
markup
|
|
|
|
|
2013-03-13 15:42:14 -04:00
|
|
|
userFormatSelection = (user) ->
|
|
|
|
user.name
|
2013-03-13 15:37:13 -04:00
|
|
|
|
|
|
|
$('.ajax-users-select').select2
|
|
|
|
placeholder: "Search for a user"
|
2013-03-13 16:32:04 -04:00
|
|
|
multiple: $('.ajax-users-select').hasClass('multiselect')
|
2013-03-13 15:37:13 -04:00
|
|
|
minimumInputLength: 0
|
2013-03-20 15:55:25 -04:00
|
|
|
query: (query) ->
|
|
|
|
Api.users query.term, (users) ->
|
|
|
|
data = { results: users }
|
|
|
|
query.callback(data)
|
2013-03-13 15:37:13 -04:00
|
|
|
|
|
|
|
initSelection: (element, callback) ->
|
|
|
|
id = $(element).val()
|
|
|
|
if id isnt ""
|
2013-03-20 15:55:25 -04:00
|
|
|
Api.user(id, callback)
|
2013-03-13 15:37:13 -04:00
|
|
|
|
|
|
|
|
2013-03-20 15:55:25 -04:00
|
|
|
formatResult: userFormatResult
|
|
|
|
formatSelection: userFormatSelection
|
|
|
|
dropdownCssClass: "ajax-users-dropdown"
|
2013-03-13 15:37:13 -04:00
|
|
|
escapeMarkup: (m) -> # we do not want to escape markup since we are displaying html in results
|
|
|
|
m
|