Commit 02fbdb8b authored by Clement Ho's avatar Clement Ho

Merge branch 'es6-class-issue' into 'master'

Convert Issue into ES6 class

See merge request !9636
parents a12664cd 6bf109b7
...@@ -5,7 +5,6 @@ import PrometheusGraph from './monitoring/prometheus_graph'; // TODO: Maybe Make ...@@ -5,7 +5,6 @@ import PrometheusGraph from './monitoring/prometheus_graph'; // TODO: Maybe Make
/* global ShortcutsNavigation */ /* global ShortcutsNavigation */
/* global Build */ /* global Build */
/* global Issuable */ /* global Issuable */
/* global Issue */
/* global ShortcutsIssuable */ /* global ShortcutsIssuable */
/* global ZenMode */ /* global ZenMode */
/* global Milestone */ /* global Milestone */
...@@ -35,6 +34,7 @@ import PrometheusGraph from './monitoring/prometheus_graph'; // TODO: Maybe Make ...@@ -35,6 +34,7 @@ import PrometheusGraph from './monitoring/prometheus_graph'; // TODO: Maybe Make
/* global ProjectShow */ /* global ProjectShow */
/* global Labels */ /* global Labels */
/* global Shortcuts */ /* global Shortcuts */
import Issue from './issue';
import BindInOut from './behaviors/bind_in_out'; import BindInOut from './behaviors/bind_in_out';
import GroupsList from './groups_list'; import GroupsList from './groups_list';
......
...@@ -5,131 +5,125 @@ require('./flash'); ...@@ -5,131 +5,125 @@ require('./flash');
require('vendor/jquery.waitforimages'); require('vendor/jquery.waitforimages');
require('./task_list'); require('./task_list');
(function() { class Issue {
var bind = function(fn, me) { return function() { return fn.apply(me, arguments); }; }; constructor() {
if ($('a.btn-close').length) {
this.Issue = (function() { this.taskList = new gl.TaskList({
function Issue() { dataType: 'issue',
this.submitNoteForm = bind(this.submitNoteForm, this); fieldName: 'description',
if ($('a.btn-close').length) { selector: '.detail-page-description',
this.taskList = new gl.TaskList({ onSuccess: (result) => {
dataType: 'issue', document.querySelector('#task_status').innerText = result.task_status;
fieldName: 'description', document.querySelector('#task_status_short').innerText = result.task_status_short;
selector: '.detail-page-description', }
onSuccess: (result) => { });
document.querySelector('#task_status').innerText = result.task_status; Issue.initIssueBtnEventListeners();
document.querySelector('#task_status_short').innerText = result.task_status_short;
}
});
this.initIssueBtnEventListeners();
}
this.initMergeRequests();
this.initRelatedBranches();
this.initCanCreateBranch();
} }
Issue.initMergeRequests();
Issue.initRelatedBranches();
Issue.initCanCreateBranch();
}
Issue.prototype.initIssueBtnEventListeners = function() { static initIssueBtnEventListeners() {
var _this, issueFailMessage; var issueFailMessage;
_this = this; issueFailMessage = 'Unable to update this issue at this time.';
issueFailMessage = 'Unable to update this issue at this time.'; return $('a.btn-close, a.btn-reopen').on('click', function(e) {
return $('a.btn-close, a.btn-reopen').on('click', function(e) { var $this, isClose, shouldSubmit, url;
var $this, isClose, shouldSubmit, url; e.preventDefault();
e.preventDefault(); e.stopImmediatePropagation();
e.stopImmediatePropagation(); $this = $(this);
$this = $(this); isClose = $this.hasClass('btn-close');
isClose = $this.hasClass('btn-close'); shouldSubmit = $this.hasClass('btn-comment');
shouldSubmit = $this.hasClass('btn-comment'); if (shouldSubmit) {
if (shouldSubmit) { Issue.submitNoteForm($this.closest('form'));
_this.submitNoteForm($this.closest('form')); }
} $this.prop('disabled', true);
$this.prop('disabled', true); url = $this.attr('href');
url = $this.attr('href'); return $.ajax({
return $.ajax({ type: 'PUT',
type: 'PUT', url: url,
url: url, error: function(jqXHR, textStatus, errorThrown) {
error: function(jqXHR, textStatus, errorThrown) { var issueStatus;
var issueStatus; issueStatus = isClose ? 'close' : 'open';
issueStatus = isClose ? 'close' : 'open'; return new Flash(issueFailMessage, 'alert');
return new Flash(issueFailMessage, 'alert'); },
}, success: function(data, textStatus, jqXHR) {
success: function(data, textStatus, jqXHR) { if ('id' in data) {
if ('id' in data) { $(document).trigger('issuable:change');
$(document).trigger('issuable:change'); const currentTotal = Number($('.issue_counter').text());
const currentTotal = Number($('.issue_counter').text()); if (isClose) {
if (isClose) { $('a.btn-close').addClass('hidden');
$('a.btn-close').addClass('hidden'); $('a.btn-reopen').removeClass('hidden');
$('a.btn-reopen').removeClass('hidden'); $('div.status-box-closed').removeClass('hidden');
$('div.status-box-closed').removeClass('hidden'); $('div.status-box-open').addClass('hidden');
$('div.status-box-open').addClass('hidden'); $('.issue_counter').text(currentTotal - 1);
$('.issue_counter').text(currentTotal - 1);
} else {
$('a.btn-reopen').addClass('hidden');
$('a.btn-close').removeClass('hidden');
$('div.status-box-closed').addClass('hidden');
$('div.status-box-open').removeClass('hidden');
$('.issue_counter').text(currentTotal + 1);
}
} else { } else {
new Flash(issueFailMessage, 'alert'); $('a.btn-reopen').addClass('hidden');
$('a.btn-close').removeClass('hidden');
$('div.status-box-closed').addClass('hidden');
$('div.status-box-open').removeClass('hidden');
$('.issue_counter').text(currentTotal + 1);
} }
return $this.prop('disabled', false); } else {
new Flash(issueFailMessage, 'alert');
} }
}); return $this.prop('disabled', false);
}
}); });
}; });
}
Issue.prototype.submitNoteForm = function(form) { static submitNoteForm(form) {
var noteText; var noteText;
noteText = form.find("textarea.js-note-text").val(); noteText = form.find("textarea.js-note-text").val();
if (noteText.trim().length > 0) { if (noteText.trim().length > 0) {
return form.submit(); return form.submit();
} }
}; }
Issue.prototype.initMergeRequests = function() { static initMergeRequests() {
var $container; var $container;
$container = $('#merge-requests'); $container = $('#merge-requests');
return $.getJSON($container.data('url')).error(function() { return $.getJSON($container.data('url')).error(function() {
return new Flash('Failed to load referenced merge requests', 'alert'); return new Flash('Failed to load referenced merge requests', 'alert');
}).success(function(data) { }).success(function(data) {
if ('html' in data) { if ('html' in data) {
return $container.html(data.html); return $container.html(data.html);
} }
}); });
}; }
Issue.prototype.initRelatedBranches = function() { static initRelatedBranches() {
var $container; var $container;
$container = $('#related-branches'); $container = $('#related-branches');
return $.getJSON($container.data('url')).error(function() { return $.getJSON($container.data('url')).error(function() {
return new Flash('Failed to load related branches', 'alert'); return new Flash('Failed to load related branches', 'alert');
}).success(function(data) { }).success(function(data) {
if ('html' in data) { if ('html' in data) {
return $container.html(data.html); return $container.html(data.html);
} }
}); });
}; }
Issue.prototype.initCanCreateBranch = function() { static initCanCreateBranch() {
var $container; var $container;
$container = $('#new-branch'); $container = $('#new-branch');
// If the user doesn't have the required permissions the container isn't // If the user doesn't have the required permissions the container isn't
// rendered at all. // rendered at all.
if ($container.length === 0) { if ($container.length === 0) {
return; 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();
} }
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();
}
});
};
return Issue; export default Issue;
})();
}).call(window);
---
title: Convert Issue into ES6 class
merge_request: 9636
author: winniehell
/* eslint-disable space-before-function-paren, no-var, one-var, one-var-declaration-per-line, no-use-before-define, comma-dangle, max-len */ /* eslint-disable space-before-function-paren, no-var, one-var, one-var-declaration-per-line, no-use-before-define, comma-dangle, max-len */
/* global Issue */ import Issue from '~/issue';
require('~/lib/utils/text_utility'); require('~/lib/utils/text_utility');
require('~/issue');
(function() { describe('Issue', function() {
var INVALID_URL = 'http://goesnowhere.nothing/whereami'; var INVALID_URL = 'http://goesnowhere.nothing/whereami';
var $boxClosed, $boxOpen, $btnClose, $btnReopen; var $boxClosed, $boxOpen, $btnClose, $btnReopen;
...@@ -59,28 +58,26 @@ require('~/issue'); ...@@ -59,28 +58,26 @@ require('~/issue');
expect($btnReopen).toHaveText('Reopen issue'); expect($btnReopen).toHaveText('Reopen issue');
} }
describe('Issue', function() { describe('task lists', function() {
describe('task lists', function() { beforeEach(function() {
beforeEach(function() { loadFixtures('issues/issue-with-task-list.html.raw');
loadFixtures('issues/issue-with-task-list.html.raw'); this.issue = new Issue();
this.issue = new Issue(); });
});
it('modifies the Markdown field', function() {
spyOn(jQuery, 'ajax').and.stub();
$('input[type=checkbox]').attr('checked', true).trigger('change');
expect($('.js-task-list-field').val()).toBe('- [x] Task List Item');
});
it('submits an ajax request on tasklist:changed', function() { it('modifies the Markdown field', function() {
spyOn(jQuery, 'ajax').and.callFake(function(req) { spyOn(jQuery, 'ajax').and.stub();
expect(req.type).toBe('PATCH'); $('input[type=checkbox]').attr('checked', true).trigger('change');
expect(req.url).toBe(gl.TEST_HOST + '/frontend-fixtures/issues-project/issues/1.json'); // eslint-disable-line prefer-template expect($('.js-task-list-field').val()).toBe('- [x] Task List Item');
expect(req.data.issue.description).not.toBe(null); });
});
$('.js-task-list-field').trigger('tasklist:changed'); it('submits an ajax request on tasklist:changed', function() {
spyOn(jQuery, 'ajax').and.callFake(function(req) {
expect(req.type).toBe('PATCH');
expect(req.url).toBe(gl.TEST_HOST + '/frontend-fixtures/issues-project/issues/1.json'); // eslint-disable-line prefer-template
expect(req.data.issue.description).not.toBe(null);
}); });
$('.js-task-list-field').trigger('tasklist:changed');
}); });
}); });
...@@ -165,4 +162,4 @@ require('~/issue'); ...@@ -165,4 +162,4 @@ require('~/issue');
expect($('.issue_counter')).toHaveText(1); expect($('.issue_counter')).toHaveText(1);
}); });
}); });
}).call(window); });
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment