46 lines
1.1 KiB
JavaScript
46 lines
1.1 KiB
JavaScript
import Vue from 'vue';
|
|
import ModalStore from '../../stores/modal_store';
|
|
import modalMixin from '../../mixins/modal_mixins';
|
|
|
|
gl.issueBoards.ModalTabs = Vue.extend({
|
|
mixins: [modalMixin],
|
|
data() {
|
|
return ModalStore.store;
|
|
},
|
|
computed: {
|
|
selectedCount() {
|
|
return ModalStore.selectedCount();
|
|
},
|
|
},
|
|
destroyed() {
|
|
this.activeTab = 'all';
|
|
},
|
|
template: `
|
|
<div class="top-area prepend-top-10 append-bottom-10">
|
|
<ul class="nav-links issues-state-filters">
|
|
<li :class="{ 'active': activeTab == 'all' }">
|
|
<a
|
|
href="#"
|
|
role="button"
|
|
@click.prevent="changeTab('all')">
|
|
Open issues
|
|
<span class="badge">
|
|
{{ issuesCount }}
|
|
</span>
|
|
</a>
|
|
</li>
|
|
<li :class="{ 'active': activeTab == 'selected' }">
|
|
<a
|
|
href="#"
|
|
role="button"
|
|
@click.prevent="changeTab('selected')">
|
|
Selected issues
|
|
<span class="badge">
|
|
{{ selectedCount }}
|
|
</span>
|
|
</a>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
`,
|
|
});
|