gitlab-org--gitlab-foss/app/assets/javascripts/importer_status.js.coffee
Phil Hughes 3cfbd2b160 Added loading icon to import buttons
See #14488 for more details
2016-04-11 18:27:34 +01:00

50 lines
1.6 KiB
CoffeeScript

class @ImporterStatus
constructor: (@jobs_url, @import_url) ->
this.initStatusPage()
this.setAutoUpdate()
initStatusPage: ->
$(".js-add-to-import")
.off 'click'
.on 'click', (event) =>
new_namespace = null
$btn = $(event.currentTarget)
$tr = $btn.closest("tr")
id = $tr.attr("id").replace("repo_", "")
if $tr.find(".import-target input").length > 0
new_namespace = $tr.find(".import-target input").prop("value")
$tr.find(".import-target").empty().append(new_namespace + "/" + $tr.find(".import-target").data("project_name"))
$btn
.disable()
.addClass 'is-loading'
$.post @import_url, {repo_id: id, new_namespace: new_namespace}, dataType: 'script'
$(".js-import-all")
.off 'click'
.on 'click', (event) =>
$btn = $(event.currentTarget)
$btn
.disable()
.addClass 'is-loading'
$(".js-add-to-import").each ->
$(this).click()
setAutoUpdate: ->
setInterval (=>
$.get @jobs_url, (data) =>
$.each data, (i, job) =>
job_item = $("#project_" + job.id)
status_field = job_item.find(".job-status")
if job.import_status == 'finished'
job_item.removeClass("active").addClass("success")
status_field.html('<span><i class="fa fa-check"></i> done</span>')
else if job.import_status == 'started'
status_field.html("<i class='fa fa-spinner fa-spin'></i> started")
else
status_field.html(job.import_status)
), 4000