BigW Consortium Gitlab

issue.js 5.05 KB
Newer Older
1
/* 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 */
2
/* global Flash */
Fatih Acet committed
3

4 5 6
import 'vendor/jquery.waitforimages';
import '~/lib/utils/text_utility';
import './flash';
7
import TaskList from './task_list';
8
import CreateMergeRequestDropdown from './create_merge_request_dropdown';
9
import IssuablesHelper from './helpers/issuables_helper';
Fatih Acet committed
10

11 12 13
class Issue {
  constructor() {
    if ($('a.btn-close').length) {
14
      this.taskList = new TaskList({
15 16 17 18 19 20 21 22
        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;
        }
      });
23
      this.initIssueBtnEventListeners();
Fatih Acet committed
24
    }
25 26

    Issue.$btnNewBranch = $('#new-branch');
27
    Issue.createMrDropdownWrap = document.querySelector('.create-mr-dropdown-wrap');
28

29 30
    Issue.initMergeRequests();
    Issue.initRelatedBranches();
31

32 33
    this.closeButtons = $('a.btn-close');
    this.reopenButtons = $('a.btn-reopen');
34

35
    this.initCloseReopenReport();
36

37 38 39
    if (Issue.createMrDropdownWrap) {
      this.createMergeRequestDropdown = new CreateMergeRequestDropdown(Issue.createMrDropdownWrap);
    }
40
  }
Fatih Acet committed
41

42
  initIssueBtnEventListeners() {
43 44
    const issueFailMessage = 'Unable to update this issue at this time.';

45
    return $(document).on('click', 'a.btn-close, a.btn-reopen', (e) => {
46
      var $button, shouldSubmit, url;
47 48
      e.preventDefault();
      e.stopImmediatePropagation();
49 50
      $button = $(e.currentTarget);
      shouldSubmit = $button.hasClass('btn-comment');
51
      if (shouldSubmit) {
52
        Issue.submitNoteForm($button.closest('form'));
53
      }
54

55
      this.disableCloseReopenButton($button);
56

57
      url = $button.attr('href');
58 59
      return $.ajax({
        type: 'PUT',
60
        url: url
61 62 63
      })
      .fail(() => new Flash(issueFailMessage))
      .done((data) => {
64 65 66 67
        const isClosedBadge = $('div.status-box-closed');
        const isOpenBadge = $('div.status-box-open');
        const projectIssuesCounter = $('.issue_counter');

68 69 70
        if ('id' in data) {
          $(document).trigger('issuable:change');

71
          const isClosed = $button.hasClass('btn-close');
72 73 74
          isClosedBadge.toggleClass('hidden', !isClosed);
          isOpenBadge.toggleClass('hidden', isClosed);

75
          this.toggleCloseReopenButton(isClosed);
76

77 78 79
          let numProjectIssues = Number(projectIssuesCounter.text().replace(/[^\d]/, ''));
          numProjectIssues = isClosed ? numProjectIssues - 1 : numProjectIssues + 1;
          projectIssuesCounter.text(gl.text.addDelimiter(numProjectIssues));
80 81 82 83 84 85 86 87 88 89

          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();
            }
          }
90 91
        } else {
          new Flash(issueFailMessage);
92
        }
93 94
      })
      .then(() => {
95
        this.disableCloseReopenButton($button, false);
Fatih Acet committed
96
      });
97 98
    });
  }
Fatih Acet committed
99

100
  initCloseReopenReport() {
101
    this.closeReopenReportToggle = IssuablesHelper.initCloseReopenReport();
102

103 104
    if (this.closeButtons) this.closeButtons = this.closeButtons.not('.issuable-close-button');
    if (this.reopenButtons) this.reopenButtons = this.reopenButtons.not('.issuable-close-button');
105 106
  }

107 108 109 110 111 112 113 114 115
  disableCloseReopenButton($button, shouldDisable) {
    if (this.closeReopenReportToggle) {
      this.closeReopenReportToggle.setDisable(shouldDisable);
    } else {
      $button.prop('disabled', shouldDisable);
    }
  }

  toggleCloseReopenButton(isClosed) {
116 117 118
    if (this.closeReopenReportToggle) this.closeReopenReportToggle.updateButton(isClosed);
    this.closeButtons.toggleClass('hidden', isClosed);
    this.reopenButtons.toggleClass('hidden', !isClosed);
119 120
  }

121 122 123 124 125 126 127
  static submitNoteForm(form) {
    var noteText;
    noteText = form.find("textarea.js-note-text").val();
    if (noteText.trim().length > 0) {
      return form.submit();
    }
  }
Fatih Acet committed
128

129 130 131
  static initMergeRequests() {
    var $container;
    $container = $('#merge-requests');
132 133 134
    return $.getJSON($container.data('url')).fail(function() {
      return new Flash('Failed to load referenced merge requests');
    }).done(function(data) {
135 136 137 138 139
      if ('html' in data) {
        return $container.html(data.html);
      }
    });
  }
Fatih Acet committed
140

141 142 143
  static initRelatedBranches() {
    var $container;
    $container = $('#related-branches');
144 145 146
    return $.getJSON($container.data('url')).fail(function() {
      return new Flash('Failed to load related branches');
    }).done(function(data) {
147 148 149 150 151 152
      if ('html' in data) {
        return $container.html(data.html);
      }
    });
  }
}
Fatih Acet committed
153

154
export default Issue;