67 lines
1.8 KiB
JavaScript
67 lines
1.8 KiB
JavaScript
import Popover from '../popover/popover.vue'
|
|
import TimelineMenuContent from './timeline_menu_content.vue'
|
|
import { library } from '@fortawesome/fontawesome-svg-core'
|
|
import {
|
|
faChevronDown
|
|
} from '@fortawesome/free-solid-svg-icons'
|
|
|
|
library.add(faChevronDown)
|
|
|
|
// Route -> i18n key mapping, exported and not in the computed
|
|
// because nav panel benefits from the same information.
|
|
export const timelineNames = () => {
|
|
return {
|
|
'friends': 'nav.home_timeline',
|
|
'bookmarks': 'nav.bookmarks',
|
|
'dms': 'nav.dms',
|
|
'public-timeline': 'nav.public_tl',
|
|
'public-external-timeline': 'nav.twkn'
|
|
}
|
|
}
|
|
|
|
const TimelineMenu = {
|
|
components: {
|
|
Popover,
|
|
TimelineMenuContent
|
|
},
|
|
data () {
|
|
return {
|
|
isOpen: false
|
|
}
|
|
},
|
|
created () {
|
|
if (timelineNames()[this.$route.name]) {
|
|
this.$store.dispatch('setLastTimeline', this.$route.name)
|
|
}
|
|
},
|
|
methods: {
|
|
openMenu () {
|
|
// $nextTick is too fast, animation won't play back but
|
|
// instead starts in fully open position. Low values
|
|
// like 1-5 work on fast machines but not on mobile, 25
|
|
// seems like a good compromise that plays without significant
|
|
// added lag.
|
|
setTimeout(() => {
|
|
this.isOpen = true
|
|
}, 25)
|
|
},
|
|
blockOpen (event) {
|
|
// For the blank area inside the button element.
|
|
// Just setting @click.stop="" makes unintuitive behavior when
|
|
// menu is open and clicking on the blank area doesn't close it.
|
|
if (!this.isOpen) {
|
|
event.stopPropagation()
|
|
}
|
|
},
|
|
timelineName () {
|
|
const route = this.$route.name
|
|
if (route === 'tag-timeline') {
|
|
return '#' + this.$route.params.tag
|
|
}
|
|
const i18nkey = timelineNames()[this.$route.name]
|
|
return i18nkey ? this.$t(i18nkey) : route
|
|
}
|
|
}
|
|
}
|
|
|
|
export default TimelineMenu
|