1
0
mirror of https://github.com/misskey-dev/misskey synced 2024-12-27 21:18:27 +09:00
misskey/src/client/app/desktop/views/components/timeline.vue

155 lines
3.2 KiB
Vue
Raw Normal View History

2018-02-11 16:52:37 +09:00
<template>
2018-02-13 08:31:03 +09:00
<div class="mk-timeline">
<header>
2018-05-16 08:22:07 +09:00
<span :data-active="src == 'home'" @click="src = 'home'">%fa:home% %i18n:@home%</span>
<span :data-active="src == 'local'" @click="src = 'local'">%fa:R comments% %i18n:@local%</span>
2018-07-11 13:43:09 +09:00
<span :data-active="src == 'hybrid'" @click="src = 'hybrid'">%fa:share-alt% %i18n:@hybrid%</span>
2018-05-16 08:22:07 +09:00
<span :data-active="src == 'global'" @click="src = 'global'">%fa:globe% %i18n:@global%</span>
2018-04-26 14:38:37 +09:00
<span :data-active="src == 'list'" @click="src = 'list'" v-if="list">%fa:list% {{ list.title }}</span>
2018-05-16 08:22:07 +09:00
<button @click="chooseList" title="%i18n:@list%">%fa:list%</button>
</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 13:43:09 +09: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"/>
2018-04-26 18:24:14 +09:00
<mk-user-list-timeline v-if="src == 'list'" ref="tl" :key="list.id" :list="list"/>
2018-02-11 23:26:35 +09:00
</div>
2018-02-11 16:52:37 +09:00
</template>
2018-02-11 17:04:03 +09:00
<script lang="ts">
import Vue from 'vue';
import XCore from './timeline.core.vue';
2018-04-25 23:08:40 +09:00
import MkUserListsWindow from './user-lists-window.vue';
2018-02-11 16:52:37 +09:00
2018-02-11 17:04:03 +09:00
export default Vue.extend({
components: {
XCore
},
2018-02-13 09:12:54 +09:00
data() {
return {
2018-04-25 23:08:40 +09:00
src: 'home',
list: null
2018-02-13 09:12:54 +09:00
};
},
2018-04-17 07:40:19 +09:00
2018-05-27 00:18:44 +09:00
watch: {
src() {
2018-05-27 02:56:54 +09:00
this.saveSrc();
2018-05-27 00:18:44 +09:00
},
list() {
2018-05-27 02:56:54 +09:00
this.saveSrc();
2018-05-27 00:18:44 +09:00
}
},
created() {
2018-05-27 00:18:44 +09: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;
}
2018-05-27 13:49:09 +09:00
} else if (this.$store.state.i.followingCount == 0) {
this.src = 'local';
}
},
2018-02-13 09:12:54 +09:00
mounted() {
(this.$refs.tl as any).$once('loaded', () => {
this.$emit('loaded');
});
2018-02-13 09:12:54 +09:00
},
2018-04-17 07:40:19 +09:00
2018-02-11 17:04:03 +09:00
methods: {
2018-05-27 02:56:54 +09:00
saveSrc() {
this.$store.commit('device/setTl', {
src: this.src,
arg: this.list
});
},
2018-02-19 18:26:20 +09:00
warp(date) {
(this.$refs.tl as any).warp(date);
2018-04-25 22:50:05 +09:00
},
2018-04-25 23:08:40 +09:00
chooseList() {
const w = (this as any).os.new(MkUserListsWindow);
w.$once('choosen', list => {
this.list = list;
2018-04-26 11:19:57 +09:00
this.src = 'list';
w.close();
2018-04-25 23:08:40 +09:00
});
2018-02-11 17:04:03 +09:00
}
}
2018-02-11 16:52:37 +09:00
});
</script>
<style lang="stylus" scoped>
@import '~const.styl'
2018-04-20 03:41:24 +09:00
root(isDark)
background isDark ? #282C37 : #fff
2018-04-29 08:51:17 +09:00
border solid 1px rgba(#000, 0.075)
2018-02-13 09:12:54 +09:00
border-radius 6px
2018-02-11 16:52:37 +09:00
> header
2018-04-17 19:32:18 +09:00
padding 0 8px
2018-04-17 20:17:00 +09:00
z-index 10
2018-04-20 03:41:24 +09:00
background isDark ? #313543 : #fff
border-radius 6px 6px 0 0
2018-04-28 00:47:52 +09:00
box-shadow 0 1px isDark ? rgba(#000, 0.15) : rgba(#000, 0.08)
2018-02-11 16:52:37 +09:00
2018-04-25 22:50:05 +09:00
> button
position absolute
z-index 2
top 0
right 0
padding 0
width 42px
font-size 0.9em
line-height 42px
color isDark ? #9baec8 : #ccc
&:hover
color isDark ? #b2c1d5 : #aaa
&:active
color isDark ? #b2c1d5 : #999
> span
2018-04-17 19:32:18 +09:00
display inline-block
padding 0 10px
line-height 42px
font-size 12px
user-select none
2018-04-26 14:38:37 +09:00
&[data-active]
color $theme-color
2018-04-17 19:32:18 +09:00
cursor default
2018-04-17 19:33:43 +09:00
font-weight bold
2018-04-17 19:32:18 +09:00
&:before
content ""
display block
position absolute
bottom 0
left -8px
width calc(100% + 16px)
height 2px
background $theme-color
2018-04-26 14:38:37 +09:00
&:not([data-active])
2018-04-20 03:41:24 +09:00
color isDark ? #9aa2a7 : #6f7477
cursor pointer
&:hover
2018-04-20 03:41:24 +09:00
color isDark ? #d9dcde : #525a5f
.mk-timeline[data-darkmode]
root(true)
.mk-timeline:not([data-darkmode])
root(false)
2018-02-11 16:52:37 +09:00
</style>