misskey/src/client/app/desktop/views/components/timeline.vue

268 lines
6.0 KiB
Vue
Raw Normal View History

2018-02-11 07:52:37 +00:00
<template>
2018-02-12 23:31:03 +00:00
<div class="mk-timeline">
<header>
2018-05-15 23:22:07 +00:00
<span :data-active="src == 'home'" @click="src = 'home'">%fa:home% %i18n:@home%</span>
2018-09-11 17:48:19 +00:00
<span :data-active="src == 'local'" @click="src = 'local'" v-if="enableLocalTimeline">%fa:R comments% %i18n:@local%</span>
<span :data-active="src == 'hybrid'" @click="src = 'hybrid'" v-if="enableLocalTimeline">%fa:share-alt% %i18n:@hybrid%</span>
2018-05-15 23:22:07 +00:00
<span :data-active="src == 'global'" @click="src = 'global'">%fa:globe% %i18n:@global%</span>
<span :data-active="src == 'tag'" @click="src = 'tag'" v-if="tagTl">%fa:hashtag% {{ tagTl.title }}</span>
2018-04-26 05:38:37 +00:00
<span :data-active="src == 'list'" @click="src = 'list'" v-if="list">%fa:list% {{ list.title }}</span>
<div class="buttons">
2018-09-19 05:18:34 +00:00
<button :data-active="src == 'mentions'" @click="src = 'mentions'" title="%i18n:@mentions%">%fa:at%<i class="badge" v-if="$store.state.i.hasUnreadMentions">%fa:circle%</i></button>
<button :data-active="src == 'messages'" @click="src = 'messages'" title="%i18n:@messages%">%fa:envelope R%<i class="badge" v-if="$store.state.i.hasUnreadSpecifiedNotes">%fa:circle%</i></button>
<button @click="chooseTag" title="%i18n:@hashtag%" ref="tagButton">%fa:hashtag%</button>
<button @click="chooseList" title="%i18n:@list%" ref="listButton">%fa:list%</button>
</div>
</header>
<x-core v-if="src == 'home'" ref="tl" key="home" src="home"/>
<x-core v-if="src == 'local'" ref="tl" key="local" src="local"/>
2018-07-11 04:43:09 +00:00
<x-core v-if="src == 'hybrid'" ref="tl" key="hybrid" src="hybrid"/>
<x-core v-if="src == 'global'" ref="tl" key="global" src="global"/>
<x-core v-if="src == 'mentions'" ref="tl" key="mentions" src="mentions"/>
<x-core v-if="src == 'messages'" ref="tl" key="messages" src="messages"/>
<x-core v-if="src == 'tag'" ref="tl" key="tag" src="tag" :tag-tl="tagTl"/>
2018-04-26 09:24:14 +00:00
<mk-user-list-timeline v-if="src == 'list'" ref="tl" :key="list.id" :list="list"/>
2018-02-11 14:26:35 +00:00
</div>
2018-02-11 07:52:37 +00:00
</template>
2018-02-11 08:04:03 +00:00
<script lang="ts">
import Vue from 'vue';
import XCore from './timeline.core.vue';
import Menu from '../../../common/views/components/menu.vue';
import MkSettingsWindow from './settings-window.vue';
2018-02-11 07:52:37 +00:00
2018-02-11 08:04:03 +00:00
export default Vue.extend({
components: {
XCore
},
2018-02-13 00:12:54 +00:00
data() {
return {
2018-04-25 14:08:40 +00:00
src: 'home',
2018-09-11 17:48:19 +00:00
list: null,
tagTl: null,
2018-09-11 17:48:19 +00:00
enableLocalTimeline: false
2018-02-13 00:12:54 +00:00
};
},
2018-04-16 22:40:19 +00:00
2018-05-26 15:18:44 +00:00
watch: {
src() {
2018-05-26 17:56:54 +00:00
this.saveSrc();
2018-05-26 15:18:44 +00:00
},
list(x) {
2018-05-26 17:56:54 +00:00
this.saveSrc();
if (x != null) this.tagTl = null;
},
tagTl(x) {
this.saveSrc();
if (x != null) this.list = null;
2018-05-26 15:18:44 +00:00
}
},
created() {
2018-09-11 17:48:19 +00:00
(this as any).os.getMeta().then(meta => {
this.enableLocalTimeline = !meta.disableLocalTimeline;
});
2018-05-26 15:18:44 +00:00
if (this.$store.state.device.tl) {
this.src = this.$store.state.device.tl.src;
if (this.src == 'list') {
this.list = this.$store.state.device.tl.arg;
} else if (this.src == 'tag') {
this.tagTl = this.$store.state.device.tl.arg;
2018-05-26 15:18:44 +00:00
}
2018-05-27 04:49:09 +00:00
} else if (this.$store.state.i.followingCount == 0) {
2018-07-14 02:58:21 +00:00
this.src = 'hybrid';
}
},
2018-02-13 00:12:54 +00:00
mounted() {
(this.$refs.tl as any).$once('loaded', () => {
this.$emit('loaded');
});
2018-02-13 00:12:54 +00:00
},
2018-04-16 22:40:19 +00:00
2018-02-11 08:04:03 +00:00
methods: {
2018-05-26 17:56:54 +00:00
saveSrc() {
this.$store.commit('device/setTl', {
src: this.src,
arg: this.src == 'list' ? this.list : this.tagTl
2018-05-26 17:56:54 +00:00
});
},
focus() {
(this.$refs.tl as any).focus();
},
2018-02-19 09:26:20 +00:00
warp(date) {
(this.$refs.tl as any).warp(date);
2018-04-25 13:50:05 +00:00
},
async chooseList() {
const lists = await (this as any).api('users/lists/list');
let menu = [{
icon: '%fa:plus%',
text: '%i18n:@add-list%',
action: () => {
(this as any).apis.input({
title: '%i18n:@list-name%',
}).then(async title => {
const list = await (this as any).api('users/lists/create', {
title
});
this.list = list;
this.src = 'list';
});
}
}];
if (lists.length > 0) {
menu.push(null);
}
menu = menu.concat(lists.map(list => ({
icon: '%fa:list%',
text: list.title,
action: () => {
this.list = list;
this.src = 'list';
}
})));
this.os.new(Menu, {
source: this.$refs.listButton,
compact: false,
items: menu
});
},
chooseTag() {
let menu = [{
icon: '%fa:plus%',
text: '%i18n:@add-tag-timeline%',
action: () => {
(this as any).os.new(MkSettingsWindow, {
initialPage: 'hashtags'
});
}
}];
if (this.$store.state.settings.tagTimelines.length > 0) {
menu.push(null);
}
menu = menu.concat(this.$store.state.settings.tagTimelines.map(t => ({
icon: '%fa:hashtag%',
text: t.title,
action: () => {
this.tagTl = t;
this.src = 'tag';
}
})));
this.os.new(Menu, {
source: this.$refs.tagButton,
compact: false,
items: menu
2018-04-25 14:08:40 +00:00
});
2018-02-11 08:04:03 +00:00
}
}
2018-02-11 07:52:37 +00:00
});
</script>
<style lang="stylus" scoped>
2018-09-26 11:19:35 +00:00
2018-04-19 18:41:24 +00:00
root(isDark)
2018-09-26 11:28:13 +00:00
background var(--face)
2018-09-22 11:39:12 +00:00
box-shadow var(--shadow)
border-radius var(--round)
overflow hidden
2018-02-11 07:52:37 +00:00
> header
2018-04-17 10:32:18 +00:00
padding 0 8px
2018-04-17 11:17:00 +00:00
z-index 10
2018-09-26 11:28:13 +00:00
background var(--faceHeader)
2018-04-27 15:47:52 +00:00
box-shadow 0 1px isDark ? rgba(#000, 0.15) : rgba(#000, 0.08)
2018-02-11 07:52:37 +00:00
> .buttons
2018-04-25 13:50:05 +00:00
position absolute
z-index 2
top 0
right 0
2018-09-17 00:05:51 +00:00
padding-right 8px
2018-04-25 13:50:05 +00:00
> button
2018-09-17 00:05:51 +00:00
padding 0 8px
font-size 0.9em
line-height 42px
color isDark ? #9baec8 : #ccc
2018-09-19 05:18:34 +00:00
> .badge
position absolute
top -4px
right 4px
font-size 10px
2018-09-26 11:19:35 +00:00
color var(--primary)
2018-09-19 05:18:34 +00:00
&:hover
color isDark ? #b2c1d5 : #aaa
2018-04-25 13:50:05 +00:00
&:active
color isDark ? #b2c1d5 : #999
2018-04-25 13:50:05 +00:00
&[data-active]
2018-09-26 11:19:35 +00:00
color var(--primary)
cursor default
&:before
content ""
display block
position absolute
bottom 0
left 0
width 100%
height 2px
2018-09-26 11:19:35 +00:00
background var(--primary)
> span
2018-04-17 10:32:18 +00:00
display inline-block
padding 0 10px
line-height 42px
font-size 12px
user-select none
2018-04-26 05:38:37 +00:00
&[data-active]
2018-09-26 11:19:35 +00:00
color var(--primary)
2018-04-17 10:32:18 +00:00
cursor default
2018-04-17 10:33:43 +00:00
font-weight bold
2018-04-17 10:32:18 +00:00
&:before
content ""
display block
position absolute
bottom 0
left -8px
width calc(100% + 16px)
height 2px
2018-09-26 11:19:35 +00:00
background var(--primary)
2018-04-17 10:32:18 +00:00
2018-04-26 05:38:37 +00:00
&:not([data-active])
2018-04-19 18:41:24 +00:00
color isDark ? #9aa2a7 : #6f7477
cursor pointer
&:hover
2018-04-19 18:41:24 +00:00
color isDark ? #d9dcde : #525a5f
.mk-timeline[data-darkmode]
root(true)
.mk-timeline:not([data-darkmode])
root(false)
2018-02-11 07:52:37 +00:00
</style>