- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68
- 69
- 70
- 71
- 72
- 73
- 74
- 75
- 76
- 77
- 78
- 79
- 80
- 81
- 82
- 83
- 84
- 85
- 86
- 87
- 88
- 89
- 90
- 91
- 92
- 93
- 94
- 95
- 96
- 97
- 98
- 99
- 100
<template>
<div class="tabs" v-if="$store.state.paste.entries.length">
<a href=""
v-for="(obj,i) in $store.state.paste.entries"
:contenteditable="$store.state.mode == 'view' ? false:true"
:key=i
@click.prevent='onTabClick'
v-html='obj.title'
@blur='saveTabTitle'
:class="{active : $store.state.activeEntry == i}"
:value='$store.state.paste.entries[$store.state.activeEntry].title'
:data-index=i></a>
<a
href=""
class="add"
@click.prevent='addEntry'
v-if='$store.state.paste.entries.length && $store.state.mode == "edit"'
>+</a>
</div>
</template>
<script>
export default {
methods: {
/**
* Adds an entry to the entries array. Entries must be in format
* {title: 'a tab title', content: 'paste content}
*/
addEntry ()
{
this.$store.commit('ADD_ENTRY', { title: 'untitled', content: '' })
// Make new entry active
this.$store.commit('SET_ACTIVE_ENTRY', this.$store.state.paste.entries.length-1)
},
/**
* Because the tabs are <a> tags with contenteditable
* enabled, when we focus out of the tab, we update
* the title in the model
*/
saveTabTitle (e)
{
this.$store.commit('SET_TAB_TITLE', {
index: e.target.dataset.index,
value: e.target.innerText
.replace(/\</, '<')
.replace(/\>/, '>')
})
},
/**
* When we click a tab, we set content of the textarea
* to that tab's object's content
*/
onTabClick (e)
{
let index = parseInt(e.target.dataset.index)
this.$store.commit('SET_ACTIVE_ENTRY', index)
}
}
}
</script>
<style lang="stylus" scoped>
@require '~assets/variables'
.tabs
margin-top 7px
box-sizing border-box
position fixed
width 100%
a
text-decoration none
color $color_tab_inactive
background $bg_tab_inactive
border-radius 40px
padding 5px 20px
box-sizing border-box
display inline-block
margin-right 10px
font-size 90%
outline none
font-weight bold
&.active
background $bg_tab_active
color $color_tab_active
&.add
color #fff
background $bg_newtab
padding 4px 8px
margin-right 0
</style>