/* 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 */ import 'vendor/jquery.waitforimages'; import { addDelimiter } from './lib/utils/text_utility'; import Flash from './flash'; import TaskList from './task_list'; import CreateMergeRequestDropdown from './create_merge_request_dropdown'; import IssuablesHelper from './helpers/issuables_helper'; export default class Issue { constructor() { if ($('a.btn-close').length) this.initIssueBtnEventListeners(); Issue.$btnNewBranch = $('#new-branch'); Issue.createMrDropdownWrap = document.querySelector('.create-mr-dropdown-wrap'); Issue.initMergeRequests(); Issue.initRelatedBranches(); this.closeButtons = $('a.btn-close'); this.reopenButtons = $('a.btn-reopen'); this.initCloseReopenReport(); if (Issue.createMrDropdownWrap) { this.createMergeRequestDropdown = new CreateMergeRequestDropdown(Issue.createMrDropdownWrap); } } initIssueBtnEventListeners() { const issueFailMessage = 'Unable to update this issue at this time.'; return $(document).on('click', '.js-issuable-actions a.btn-close, .js-issuable-actions a.btn-reopen', (e) => { var $button, shouldSubmit, url; e.preventDefault(); e.stopImmediatePropagation(); $button = $(e.currentTarget); shouldSubmit = $button.hasClass('btn-comment'); if (shouldSubmit) { Issue.submitNoteForm($button.closest('form')); } this.disableCloseReopenButton($button); url = $button.attr('href'); return $.ajax({ type: 'PUT', url: url }) .fail(() => new Flash(issueFailMessage)) .done((data) => { const isClosedBadge = $('div.status-box-closed'); const isOpenBadge = $('div.status-box-open'); const projectIssuesCounter = $('.issue_counter'); if ('id' in data) { const isClosed = $button.hasClass('btn-close'); isClosedBadge.toggleClass('hidden', !isClosed); isOpenBadge.toggleClass('hidden', isClosed); $(document).trigger('issuable:change', isClosed); this.toggleCloseReopenButton(isClosed); let numProjectIssues = Number(projectIssuesCounter.first().text().trim().replace(/[^\d]/, '')); numProjectIssues = isClosed ? numProjectIssues - 1 : numProjectIssues + 1; projectIssuesCounter.text(addDelimiter(numProjectIssues)); if (this.createMergeRequestDropdown) { if (isClosed) { this.createMergeRequestDropdown.unavailable(); this.createMergeRequestDropdown.disable(); } else { // We should check in case a branch was created in another tab this.createMergeRequestDropdown.checkAbilityToCreateBranch(); } } } else { new Flash(issueFailMessage); } }) .then(() => { this.disableCloseReopenButton($button, false); }); }); } initCloseReopenReport() { this.closeReopenReportToggle = IssuablesHelper.initCloseReopenReport(); if (this.closeButtons) this.closeButtons = this.closeButtons.not('.issuable-close-button'); if (this.reopenButtons) this.reopenButtons = this.reopenButtons.not('.issuable-close-button'); } disableCloseReopenButton($button, shouldDisable) { if (this.closeReopenReportToggle) { this.closeReopenReportToggle.setDisable(shouldDisable); } else { $button.prop('disabled', shouldDisable); } } toggleCloseReopenButton(isClosed) { if (this.closeReopenReportToggle) this.closeReopenReportToggle.updateButton(isClosed); this.closeButtons.toggleClass('hidden', isClosed); this.reopenButtons.toggleClass('hidden', !isClosed); } static submitNoteForm(form) { var noteText; noteText = form.find("textarea.js-note-text").val(); if (noteText && noteText.trim().length > 0) { return form.submit(); } } static initMergeRequests() { var $container; $container = $('#merge-requests'); return $.getJSON($container.data('url')).fail(function() { return new Flash('Failed to load referenced merge requests'); }).done(function(data) { if ('html' in data) { return $container.html(data.html); } }); } static initRelatedBranches() { var $container; $container = $('#related-branches'); return $.getJSON($container.data('url')).fail(function() { return new Flash('Failed to load related branches'); }).done(function(data) { if ('html' in data) { return $container.html(data.html); } }); } }