Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'app/assets/javascripts/issues/issue.js')
-rw-r--r--app/assets/javascripts/issues/issue.js113
1 files changed, 113 insertions, 0 deletions
diff --git a/app/assets/javascripts/issues/issue.js b/app/assets/javascripts/issues/issue.js
new file mode 100644
index 00000000000..c471875654b
--- /dev/null
+++ b/app/assets/javascripts/issues/issue.js
@@ -0,0 +1,113 @@
+import $ from 'jquery';
+import { joinPaths } from '~/lib/utils/url_utility';
+import CreateMergeRequestDropdown from '~/create_merge_request_dropdown';
+import createFlash from '~/flash';
+import { EVENT_ISSUABLE_VUE_APP_CHANGE } from '~/issuable/constants';
+import axios from '~/lib/utils/axios_utils';
+import { addDelimiter } from '~/lib/utils/text_utility';
+import { __ } from '~/locale';
+
+export default class Issue {
+ constructor() {
+ if ($('.js-alert-moved-from-service-desk-warning').length) {
+ Issue.initIssueMovedFromServiceDeskDismissHandler();
+ }
+
+ if (document.querySelector('#related-branches')) {
+ Issue.initRelatedBranches();
+ }
+
+ Issue.createMrDropdownWrap = document.querySelector('.create-mr-dropdown-wrap');
+
+ if (Issue.createMrDropdownWrap) {
+ this.createMergeRequestDropdown = new CreateMergeRequestDropdown(Issue.createMrDropdownWrap);
+ }
+
+ // Listen to state changes in the Vue app
+ this.issuableVueAppChangeHandler = (event) =>
+ this.updateTopState(event.detail.isClosed, event.detail.data);
+ document.addEventListener(EVENT_ISSUABLE_VUE_APP_CHANGE, this.issuableVueAppChangeHandler);
+ }
+
+ dispose() {
+ document.removeEventListener(EVENT_ISSUABLE_VUE_APP_CHANGE, this.issuableVueAppChangeHandler);
+ }
+
+ /**
+ * This method updates the top area of the issue.
+ *
+ * Once the issue state changes, either through a click on the top area (jquery)
+ * or a click on the bottom area (Vue) we need to update the top area.
+ *
+ * @param {Boolean} isClosed
+ * @param {Array} data
+ * @param {String} issueFailMessage
+ */
+ updateTopState(
+ isClosed,
+ data,
+ issueFailMessage = __('Unable to update this issue at this time.'),
+ ) {
+ if ('id' in data) {
+ const isClosedBadge = $('div.status-box-issue-closed');
+ const isOpenBadge = $('div.status-box-open');
+ const projectIssuesCounter = $('.issue_counter');
+
+ isClosedBadge.toggleClass('hidden', !isClosed);
+ isOpenBadge.toggleClass('hidden', isClosed);
+
+ $(document).trigger('issuable:change', isClosed);
+
+ let numProjectIssues = Number(
+ projectIssuesCounter.first().text().trim().replace(/[^\d]/, ''),
+ );
+ numProjectIssues = isClosed ? numProjectIssues - 1 : numProjectIssues + 1;
+ projectIssuesCounter.text(addDelimiter(numProjectIssues));
+
+ if (this.createMergeRequestDropdown) {
+ this.createMergeRequestDropdown.checkAbilityToCreateBranch();
+ }
+ } else {
+ createFlash({
+ message: issueFailMessage,
+ });
+ }
+ }
+
+ static initIssueMovedFromServiceDeskDismissHandler() {
+ const alertMovedFromServiceDeskWarning = $('.js-alert-moved-from-service-desk-warning');
+
+ const trimmedPathname = window.location.pathname.slice(1);
+ const alertMovedFromServiceDeskDismissedKey = joinPaths(
+ trimmedPathname,
+ 'alert-issue-moved-from-service-desk-dismissed',
+ );
+
+ if (!localStorage.getItem(alertMovedFromServiceDeskDismissedKey)) {
+ alertMovedFromServiceDeskWarning.show();
+ }
+
+ alertMovedFromServiceDeskWarning.on('click', '.js-close', (e) => {
+ e.preventDefault();
+ e.stopImmediatePropagation();
+ alertMovedFromServiceDeskWarning.remove();
+ localStorage.setItem(alertMovedFromServiceDeskDismissedKey, true);
+ });
+ }
+
+ static initRelatedBranches() {
+ const $container = $('#related-branches');
+ axios
+ .get($container.data('url'))
+ .then(({ data }) => {
+ if ('html' in data) {
+ $container.html(data.html);
+ }
+ })
+ .catch(() =>
+ createFlash({
+ message: __('Failed to load related branches'),
+ }),
+ );
+ }
+}