f3ea2f29a5
We're not concerning ourselves with non-HTML5 browser compatibility, and this removes 21 KB from our compiled JavaScript. Bonus fix: There was an extra space after the query string in the URLs that has now been removed.
35 lines
1 KiB
CoffeeScript
35 lines
1 KiB
CoffeeScript
#
|
|
# * Filter merge requests
|
|
#
|
|
@MergeRequests =
|
|
init: ->
|
|
MergeRequests.initSearch()
|
|
|
|
# Make sure we trigger ajax request only after user stop typing
|
|
initSearch: ->
|
|
@timer = null
|
|
$("#issue_search").keyup ->
|
|
clearTimeout(@timer)
|
|
@timer = setTimeout(MergeRequests.filterResults, 500)
|
|
|
|
filterResults: =>
|
|
form = $("#issue_search_form")
|
|
search = $("#issue_search").val()
|
|
$('.merge-requests-holder').css("opacity", '0.5')
|
|
issues_url = form.attr('action') + '?' + form.serialize()
|
|
|
|
$.ajax
|
|
type: "GET"
|
|
url: form.attr('action')
|
|
data: form.serialize()
|
|
complete: ->
|
|
$('.merge-requests-holder').css("opacity", '1.0')
|
|
success: (data) ->
|
|
$('.merge-requests-holder').html(data.html)
|
|
# Change url so if user reload a page - search results are saved
|
|
history.replaceState {page: issues_url}, document.title, issues_url
|
|
MergeRequests.reload()
|
|
dataType: "json"
|
|
|
|
reload: ->
|
|
$('#filter_issue_search').val($('#issue_search').val())
|