47 lines
1.1 KiB
JavaScript
47 lines
1.1 KiB
JavaScript
|
import Vue from 'vue';
|
||
|
|
||
|
const ModalStore = gl.issueBoards.ModalStore;
|
||
|
|
||
|
gl.issueBoards.ModalTabs = Vue.extend({
|
||
|
mixins: [gl.issueBoards.ModalMixins],
|
||
|
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>
|
||
|
`,
|
||
|
});
|