/* eslint-disable comma-dangle, space-before-function-paren, no-new */ /* global IssuableContext */ /* global MilestoneSelect */ /* global LabelsSelect */ /* global Sidebar */ /* global Flash */ import Vue from 'vue'; import eventHub from '../../sidebar/event_hub'; import AssigneeTitle from '../../sidebar/components/assignees/assignee_title'; import Assignees from '../../sidebar/components/assignees/assignees'; require('./sidebar/remove_issue'); const Store = gl.issueBoards.BoardsStore; window.gl = window.gl || {}; window.gl.issueBoards = window.gl.issueBoards || {}; gl.issueBoards.BoardSidebar = Vue.extend({ props: { currentUser: Object }, data() { return { detail: Store.detail, issue: {}, list: {}, loadingAssignees: false, }; }, computed: { showSidebar () { return Object.keys(this.issue).length; }, assigneeId() { return this.issue.assignee ? this.issue.assignee.id : 0; } }, watch: { detail: { handler () { if (this.issue.id !== this.detail.issue.id) { $('.js-issue-board-sidebar', this.$el).each((i, el) => { $(el).data('glDropdown').clearMenu(); }); } this.issue = this.detail.issue; this.list = this.detail.list; this.$nextTick(() => { this.endpoint = this.$refs.assigneeDropdown.dataset.issueUpdate; }); }, deep: true }, issue () { if (this.showSidebar) { this.$nextTick(() => { $('.right-sidebar').getNiceScroll(0).doScrollTop(0, 0); $('.right-sidebar').getNiceScroll().resize(); }); } this.issue = this.detail.issue; this.list = this.detail.list; }, deep: true }, methods: { closeSidebar () { this.detail.issue = {}; }, assignSelf () { // Notify gl dropdown that we are now assigning to current user this.$refs.assigneeBlock.dispatchEvent(new Event('assignYourself')); this.addAssignee(this.currentUser); this.saveAssignees(); }, removeAssignee (a) { gl.issueBoards.BoardsStore.detail.issue.removeAssignee(a); }, addAssignee (a) { gl.issueBoards.BoardsStore.detail.issue.addAssignee(a); }, removeAllAssignees () { gl.issueBoards.BoardsStore.detail.issue.removeAllAssignees(); }, saveAssignees () { this.loadingAssignees = true; gl.issueBoards.BoardsStore.detail.issue.update(this.endpoint) .then(() => { this.loadingAssignees = false; }) .catch(() => { this.loadingAssignees = false; return new Flash('An error occurred while saving assignees'); }); }, }, created () { // Get events from glDropdown eventHub.$on('sidebar.removeAssignee', this.removeAssignee); eventHub.$on('sidebar.addAssignee', this.addAssignee); eventHub.$on('sidebar.removeAllAssignees', this.removeAllAssignees); eventHub.$on('sidebar.saveAssignees', this.saveAssignees); }, beforeDestroy() { eventHub.$off('sidebar.removeAssignee', this.removeAssignee); eventHub.$off('sidebar.addAssignee', this.addAssignee); eventHub.$off('sidebar.removeAllAssignees', this.removeAllAssignees); eventHub.$off('sidebar.saveAssignees', this.saveAssignees); }, mounted () { new IssuableContext(this.currentUser); new MilestoneSelect(); new gl.DueDateSelectors(); new LabelsSelect(); new Sidebar(); gl.Subscription.bindAll('.subscription'); }, components: { removeBtn: gl.issueBoards.RemoveIssueBtn, 'assignee-title': AssigneeTitle, assignees: Assignees, }, });