gitlab-org--gitlab-foss/app/assets/javascripts/issue.js

132 lines
4.4 KiB
JavaScript
Raw Normal View History

/* eslint-disable func-names, space-before-function-paren, no-var, prefer-rest-params, wrap-iife, one-var, no-underscore-dangle, one-var-declaration-per-line, object-shorthand, no-unused-vars, no-new, comma-dangle, consistent-return, quotes, dot-notation, quote-props, prefer-arrow-callback, max-len */
/* global Flash */
2016-07-24 16:45:11 -04:00
require('./flash');
2017-03-16 20:10:35 -04:00
require('~/lib/utils/text_utility');
require('vendor/jquery.waitforimages');
require('./task_list');
2016-07-24 16:45:11 -04:00
2017-03-01 14:54:04 -05:00
class Issue {
constructor() {
if ($('a.btn-close').length) {
this.taskList = new gl.TaskList({
dataType: 'issue',
fieldName: 'description',
selector: '.detail-page-description',
onSuccess: (result) => {
document.querySelector('#task_status').innerText = result.task_status;
document.querySelector('#task_status_short').innerText = result.task_status_short;
}
});
Issue.initIssueBtnEventListeners();
2016-07-24 16:45:11 -04:00
}
2017-03-01 14:54:04 -05:00
Issue.initMergeRequests();
Issue.initRelatedBranches();
Issue.initCanCreateBranch();
}
2016-07-24 16:45:11 -04:00
2017-03-01 14:54:04 -05:00
static initIssueBtnEventListeners() {
var issueFailMessage;
issueFailMessage = 'Unable to update this issue at this time.';
return $('a.btn-close, a.btn-reopen').on('click', function(e) {
var $this, isClose, shouldSubmit, url;
e.preventDefault();
e.stopImmediatePropagation();
$this = $(this);
isClose = $this.hasClass('btn-close');
shouldSubmit = $this.hasClass('btn-comment');
if (shouldSubmit) {
Issue.submitNoteForm($this.closest('form'));
}
$this.prop('disabled', true);
url = $this.attr('href');
return $.ajax({
type: 'PUT',
url: url,
error: function(jqXHR, textStatus, errorThrown) {
var issueStatus;
issueStatus = isClose ? 'close' : 'open';
return new Flash(issueFailMessage, 'alert');
},
success: function(data, textStatus, jqXHR) {
if ('id' in data) {
$(document).trigger('issuable:change');
2017-03-16 20:10:35 -04:00
let total = Number($('.issue_counter').text().replace(/[^\d]/, ''));
2017-03-01 14:54:04 -05:00
if (isClose) {
$('a.btn-close').addClass('hidden');
$('a.btn-reopen').removeClass('hidden');
$('div.status-box-closed').removeClass('hidden');
$('div.status-box-open').addClass('hidden');
2017-03-16 20:10:35 -04:00
total -= 1;
2016-07-24 16:45:11 -04:00
} else {
2017-03-01 14:54:04 -05:00
$('a.btn-reopen').addClass('hidden');
$('a.btn-close').removeClass('hidden');
$('div.status-box-closed').addClass('hidden');
$('div.status-box-open').removeClass('hidden');
2017-03-16 20:10:35 -04:00
total += 1;
2016-07-24 16:45:11 -04:00
}
2017-03-16 20:10:35 -04:00
$('.issue_counter').text(gl.text.addDelimiter(total));
2017-03-01 14:54:04 -05:00
} else {
new Flash(issueFailMessage, 'alert');
2016-07-24 16:45:11 -04:00
}
2017-03-01 14:54:04 -05:00
return $this.prop('disabled', false);
}
2016-07-24 16:45:11 -04:00
});
2017-03-01 14:54:04 -05:00
});
}
2016-07-24 16:45:11 -04:00
2017-03-01 14:54:04 -05:00
static submitNoteForm(form) {
var noteText;
noteText = form.find("textarea.js-note-text").val();
if (noteText.trim().length > 0) {
return form.submit();
}
}
2016-07-24 16:45:11 -04:00
2017-03-01 14:54:04 -05:00
static initMergeRequests() {
var $container;
$container = $('#merge-requests');
return $.getJSON($container.data('url')).error(function() {
return new Flash('Failed to load referenced merge requests', 'alert');
}).success(function(data) {
if ('html' in data) {
return $container.html(data.html);
}
});
}
2016-07-24 16:45:11 -04:00
2017-03-01 14:54:04 -05:00
static initRelatedBranches() {
var $container;
$container = $('#related-branches');
return $.getJSON($container.data('url')).error(function() {
return new Flash('Failed to load related branches', 'alert');
}).success(function(data) {
if ('html' in data) {
return $container.html(data.html);
}
});
}
2016-07-24 16:45:11 -04:00
2017-03-01 14:54:04 -05:00
static initCanCreateBranch() {
var $container;
$container = $('#new-branch');
// If the user doesn't have the required permissions the container isn't
// rendered at all.
if ($container.length === 0) {
return;
}
return $.getJSON($container.data('path')).error(function() {
$container.find('.unavailable').show();
return new Flash('Failed to check if a new branch can be created.', 'alert');
}).success(function(data) {
if (data.can_create_branch) {
$container.find('.available').show();
} else {
return $container.find('.unavailable').show();
2016-07-24 16:45:11 -04:00
}
2017-03-01 14:54:04 -05:00
});
}
}
2016-07-24 16:45:11 -04:00
2017-03-01 14:54:04 -05:00
export default Issue;