Whalebird-desktop-client-ma.../src/renderer/components/TimelineSpace/Contents/SideBar.vue

72 lines
1.5 KiB
Vue
Raw Normal View History

2018-03-29 15:41:28 +02:00
<template>
2018-04-13 11:01:19 +02:00
<transition name="slide-detail">
<div id="side_bar" v-if="openSideBar">
2018-04-13 11:01:19 +02:00
<div class="header">
<i class="el-icon-close" @click="close"></i>
</div>
<account-profile v-if="component === 1"></account-profile>
<toot-detail v-if="component === 2"></toot-detail>
2018-03-29 15:41:28 +02:00
</div>
2018-04-13 11:01:19 +02:00
</transition>
2018-03-29 15:41:28 +02:00
</template>
<script>
import { mapState } from 'vuex'
import TootDetail from './SideBar/TootDetail'
import AccountProfile from './SideBar/AccountProfile'
2018-03-29 15:41:28 +02:00
export default {
name: 'side-bar',
components: {
TootDetail,
AccountProfile
},
2018-03-29 15:41:28 +02:00
computed: {
...mapState({
openSideBar: state => state.TimelineSpace.Contents.SideBar.openSideBar,
component: state => state.TimelineSpace.Contents.SideBar.component
2018-03-29 15:41:28 +02:00
})
},
beforeDestroy () {
this.close()
},
2018-03-29 15:41:28 +02:00
methods: {
close () {
this.$store.dispatch('TimelineSpace/Contents/SideBar/close')
2018-03-29 15:41:28 +02:00
}
}
}
</script>
<style lang="scss" scoped>
#side_bar {
position: fixed;
top: 48px;
right: 0;
width: 320px;
height: calc(100% - 48px);
overflow: auto;
border-left: solid 1px var(--theme-border-color);
.header {
background-color: var(--theme-selected-background-color);
padding: 4px 8px;
border-top: solid 1px var(--theme-border-color);
border-bottom: solid 1px var(--theme-border-color);
text-align: right;
.el-icon-close {
cursor: pointer;
}
}
2018-03-29 15:41:28 +02:00
}
2018-04-13 11:01:19 +02:00
.slide-detail-enter-active, .slide-detail-leave-active {
transition: all 0.5s;
}
.slide-detail-enter, .slide-detail-leave-to {
margin-right: -320px;
opacity: 0;
}
2018-03-29 15:41:28 +02:00
</style>