42 lines
817 B
Vue
42 lines
817 B
Vue
<script>
|
|
import Vue from 'vue';
|
|
import Store from './repo_store';
|
|
import RepoTab from './repo_tab.vue';
|
|
import RepoMixin from './repo_mixin';
|
|
|
|
const RepoTabs = {
|
|
mixins: [RepoMixin],
|
|
|
|
components: {
|
|
'repo-tab': RepoTab,
|
|
},
|
|
|
|
data: () => Store,
|
|
|
|
methods: {
|
|
isOverflow() {
|
|
return this.$el.scrollWidth > this.$el.offsetWidth;
|
|
},
|
|
|
|
xclicked(file) {
|
|
Store.removeFromOpenedFiles(file);
|
|
}
|
|
},
|
|
|
|
watch: {
|
|
openedFiles() {
|
|
Vue.nextTick(() => {
|
|
this.tabsOverflow = this.isOverflow();
|
|
});
|
|
},
|
|
},
|
|
};
|
|
|
|
export default RepoTabs;
|
|
</script>
|
|
|
|
<template>
|
|
<ul id="tabs" v-if="isMini" v-cloak :class="{'overflown': tabsOverflow}">
|
|
<repo-tab v-for="tab in openedFiles" :key="tab.id" :tab="tab" :class="{'active' : tab.active}" @xclicked="xclicked"/>
|
|
</ul>
|
|
</template>
|