2018-03-08 10:36:09 +01:00
|
|
|
<template>
|
2019-05-11 16:01:59 +02:00
|
|
|
<div
|
|
|
|
id="timeline_space"
|
|
|
|
v-loading="loading"
|
|
|
|
:element-loading-text="$t('message.loading')"
|
|
|
|
element-loading-spinner="el-icon-loading"
|
|
|
|
element-loading-background="rgba(0, 0, 0, 0.8)"
|
2018-07-05 15:15:31 +02:00
|
|
|
>
|
2019-05-11 16:01:59 +02:00
|
|
|
<side-menu></side-menu>
|
|
|
|
<div :class="collapse ? 'page-narrow' : 'page'">
|
2020-10-14 18:01:55 +02:00
|
|
|
<header class="header" style="-webkit-app-region: drag">
|
2019-05-11 16:01:59 +02:00
|
|
|
<header-menu></header-menu>
|
|
|
|
</header>
|
|
|
|
<contents></contents>
|
|
|
|
</div>
|
|
|
|
<modals></modals>
|
|
|
|
<receive-drop v-show="droppableVisible"></receive-drop>
|
2018-03-09 07:21:25 +01:00
|
|
|
</div>
|
2018-03-08 10:36:09 +01:00
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2018-08-23 17:17:47 +02:00
|
|
|
import { mapState, mapGetters } from 'vuex'
|
2018-03-09 07:21:25 +01:00
|
|
|
import SideMenu from './TimelineSpace/SideMenu'
|
2018-03-22 10:09:58 +01:00
|
|
|
import HeaderMenu from './TimelineSpace/HeaderMenu'
|
2018-03-29 17:20:15 +02:00
|
|
|
import Contents from './TimelineSpace/Contents'
|
2018-03-29 17:20:35 +02:00
|
|
|
import Modals from './TimelineSpace/Modals'
|
2018-06-06 13:25:28 +02:00
|
|
|
import Mousetrap from 'mousetrap'
|
2018-07-05 15:15:31 +02:00
|
|
|
import ReceiveDrop from './TimelineSpace/ReceiveDrop'
|
2019-05-16 16:02:05 +02:00
|
|
|
import { AccountLoadError } from '@/errors/load'
|
|
|
|
import { TimelineFetchError } from '@/errors/fetch'
|
2021-01-23 17:38:19 +01:00
|
|
|
import { NewTootAttachLength } from '@/errors/validations'
|
2020-07-30 19:03:21 +02:00
|
|
|
import { Event } from '~/src/renderer/components/event'
|
2018-03-09 07:21:25 +01:00
|
|
|
|
2018-03-08 10:36:09 +01:00
|
|
|
export default {
|
2018-03-08 16:24:18 +01:00
|
|
|
name: 'timeline-space',
|
2018-07-05 15:15:31 +02:00
|
|
|
components: { SideMenu, HeaderMenu, Modals, Contents, ReceiveDrop },
|
2019-05-11 16:01:59 +02:00
|
|
|
data() {
|
2018-07-05 15:15:31 +02:00
|
|
|
return {
|
|
|
|
dropTarget: null,
|
2022-04-19 17:57:25 +02:00
|
|
|
droppableVisible: false
|
2018-07-05 15:15:31 +02:00
|
|
|
}
|
|
|
|
},
|
2018-07-02 14:53:09 +02:00
|
|
|
computed: {
|
|
|
|
...mapState({
|
2022-04-19 17:57:25 +02:00
|
|
|
loading: state => state.TimelineSpace.loading,
|
|
|
|
collapse: state => state.TimelineSpace.SideMenu.collapse
|
2018-08-23 17:17:47 +02:00
|
|
|
}),
|
2019-05-11 16:01:59 +02:00
|
|
|
...mapGetters('TimelineSpace/Modals', ['modalOpened']),
|
2020-07-30 19:03:21 +02:00
|
|
|
shortcutEnabled: function () {
|
2018-08-23 17:17:47 +02:00
|
|
|
return !this.modalOpened
|
2022-04-19 17:57:25 +02:00
|
|
|
}
|
2018-07-02 14:53:09 +02:00
|
|
|
},
|
2019-05-11 16:01:59 +02:00
|
|
|
async created() {
|
2018-12-12 01:49:24 +01:00
|
|
|
this.$store.dispatch('TimelineSpace/Contents/SideBar/close')
|
2019-05-11 16:01:59 +02:00
|
|
|
await this.initialize().finally(() => {
|
|
|
|
this.$store.commit('GlobalHeader/updateChanging', false)
|
|
|
|
})
|
2018-03-21 02:41:53 +01:00
|
|
|
},
|
2019-05-11 16:01:59 +02:00
|
|
|
mounted() {
|
2018-07-05 15:15:31 +02:00
|
|
|
window.addEventListener('dragenter', this.onDragEnter)
|
|
|
|
window.addEventListener('dragleave', this.onDragLeave)
|
|
|
|
window.addEventListener('dragover', this.onDragOver)
|
|
|
|
window.addEventListener('drop', this.handleDrop)
|
2018-06-06 13:25:28 +02:00
|
|
|
Mousetrap.bind(['command+t', 'ctrl+t'], () => {
|
|
|
|
this.$store.commit('TimelineSpace/Modals/Jump/changeModal', true)
|
|
|
|
})
|
|
|
|
},
|
2022-04-20 10:48:34 +02:00
|
|
|
beforeUnmount() {
|
2018-07-05 15:15:31 +02:00
|
|
|
window.removeEventListener('dragenter', this.onDragEnter)
|
|
|
|
window.removeEventListener('dragleave', this.onDragLeave)
|
|
|
|
window.removeEventListener('dragover', this.onDragOver)
|
|
|
|
window.removeEventListener('drop', this.handleDrop)
|
2018-11-08 00:12:51 +01:00
|
|
|
this.$store.dispatch('TimelineSpace/stopStreamings')
|
2018-11-17 13:03:56 +01:00
|
|
|
this.$store.dispatch('TimelineSpace/unbindStreamings')
|
2018-03-21 02:41:53 +01:00
|
|
|
},
|
|
|
|
methods: {
|
2019-05-11 16:01:59 +02:00
|
|
|
async clear() {
|
2019-06-26 16:32:06 +02:00
|
|
|
this.$store.dispatch('TimelineSpace/unbindStreamings')
|
2018-03-21 02:41:53 +01:00
|
|
|
await this.$store.dispatch('TimelineSpace/clearAccount')
|
2018-11-08 00:12:51 +01:00
|
|
|
this.$store.dispatch('TimelineSpace/clearContentsTimelines')
|
2018-03-21 02:41:53 +01:00
|
|
|
await this.$store.dispatch('TimelineSpace/removeShortcutEvents')
|
2018-05-17 15:02:59 +02:00
|
|
|
await this.$store.dispatch('TimelineSpace/clearUnread')
|
2018-03-21 02:41:53 +01:00
|
|
|
return 'clear'
|
|
|
|
},
|
2019-05-11 16:01:59 +02:00
|
|
|
async initialize() {
|
2018-03-21 02:41:53 +01:00
|
|
|
await this.clear()
|
|
|
|
|
2019-05-16 16:02:05 +02:00
|
|
|
try {
|
2022-04-19 17:57:25 +02:00
|
|
|
await this.$store.dispatch('TimelineSpace/initLoad', this.$route.params.id)
|
2019-05-16 16:02:05 +02:00
|
|
|
} catch (err) {
|
|
|
|
if (err instanceof AccountLoadError) {
|
|
|
|
this.$message({
|
|
|
|
message: this.$t('message.account_load_error'),
|
2022-04-19 17:57:25 +02:00
|
|
|
type: 'error'
|
2019-05-16 16:02:05 +02:00
|
|
|
})
|
|
|
|
} else if (err instanceof TimelineFetchError) {
|
|
|
|
this.$message({
|
|
|
|
message: this.$t('message.timeline_fetch_error'),
|
2022-04-19 17:57:25 +02:00
|
|
|
type: 'error'
|
2019-05-16 16:02:05 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2019-06-26 16:32:06 +02:00
|
|
|
|
|
|
|
await this.$store.dispatch('TimelineSpace/prepareSpace')
|
2018-07-05 15:15:31 +02:00
|
|
|
},
|
2019-05-11 16:01:59 +02:00
|
|
|
handleDrop(e) {
|
2018-07-05 15:15:31 +02:00
|
|
|
e.preventDefault()
|
|
|
|
e.stopPropagation()
|
|
|
|
this.droppableVisible = false
|
2022-04-19 17:57:25 +02:00
|
|
|
if (e.dataTransfer.files.item(0) === null || e.dataTransfer.files.item(0) === undefined) {
|
2018-07-05 15:15:31 +02:00
|
|
|
return false
|
|
|
|
}
|
|
|
|
const file = e.dataTransfer.files.item(0)
|
|
|
|
if (!file.type.includes('image') && !file.type.includes('video')) {
|
|
|
|
this.$message({
|
2018-08-13 08:27:53 +02:00
|
|
|
message: this.$t('validation.new_toot.attach_image'),
|
2022-04-19 17:57:25 +02:00
|
|
|
type: 'error'
|
2018-07-05 15:15:31 +02:00
|
|
|
})
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
this.$store.dispatch('TimelineSpace/Modals/NewToot/openModal')
|
2019-05-27 15:56:54 +02:00
|
|
|
this.$store.dispatch('TimelineSpace/Modals/NewToot/incrementMediaCount')
|
2020-07-30 19:03:21 +02:00
|
|
|
this.$store
|
|
|
|
.dispatch('TimelineSpace/Modals/NewToot/uploadImage', file)
|
|
|
|
.then(() => {
|
|
|
|
Event.$emit('image-uploaded')
|
|
|
|
})
|
2022-04-19 17:57:25 +02:00
|
|
|
.catch(err => {
|
2021-01-23 17:38:19 +01:00
|
|
|
if (err instanceof NewTootAttachLength) {
|
|
|
|
this.$message({
|
|
|
|
message: this.$t('validation.new_toot.attach_length', { max: 4 }),
|
2022-04-19 17:57:25 +02:00
|
|
|
type: 'error'
|
2021-01-23 17:38:19 +01:00
|
|
|
})
|
|
|
|
} else {
|
|
|
|
this.$message({
|
|
|
|
message: this.$t('message.attach_error'),
|
2022-04-19 17:57:25 +02:00
|
|
|
type: 'error'
|
2021-01-23 17:38:19 +01:00
|
|
|
})
|
|
|
|
}
|
2018-07-05 15:15:31 +02:00
|
|
|
})
|
|
|
|
return false
|
|
|
|
},
|
2019-05-11 16:01:59 +02:00
|
|
|
onDragEnter(e) {
|
2019-09-28 16:21:13 +02:00
|
|
|
if (e.dataTransfer.types.indexOf('Files') >= 0) {
|
|
|
|
this.dropTarget = e.target
|
|
|
|
this.droppableVisible = true
|
|
|
|
}
|
2018-07-05 15:15:31 +02:00
|
|
|
},
|
2019-05-11 16:01:59 +02:00
|
|
|
onDragLeave(e) {
|
2018-07-05 15:15:31 +02:00
|
|
|
if (e.target === this.dropTarget) {
|
|
|
|
this.droppableVisible = false
|
|
|
|
}
|
|
|
|
},
|
2019-05-11 16:01:59 +02:00
|
|
|
onDragOver(e) {
|
2018-07-05 15:15:31 +02:00
|
|
|
e.preventDefault()
|
2018-08-22 16:30:49 +02:00
|
|
|
},
|
2019-05-11 16:01:59 +02:00
|
|
|
handleKey(event) {
|
2018-08-22 16:30:49 +02:00
|
|
|
switch (event.srcKey) {
|
|
|
|
case 'help':
|
|
|
|
this.$store.commit('TimelineSpace/Modals/Shortcut/changeModal', true)
|
|
|
|
break
|
|
|
|
}
|
2022-04-19 17:57:25 +02:00
|
|
|
}
|
|
|
|
}
|
2018-03-08 10:36:09 +01:00
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
2018-03-29 15:41:28 +02:00
|
|
|
#timeline_space {
|
|
|
|
height: 100%;
|
|
|
|
}
|
2018-03-22 10:09:58 +01:00
|
|
|
.page {
|
2018-03-09 09:36:57 +01:00
|
|
|
margin-left: 180px;
|
2018-03-29 15:41:28 +02:00
|
|
|
height: 100%;
|
|
|
|
box-sizing: border-box;
|
2018-03-22 10:09:58 +01:00
|
|
|
|
|
|
|
.header {
|
2018-11-21 16:40:05 +01:00
|
|
|
width: calc(100% - 180px);
|
2018-03-22 10:09:58 +01:00
|
|
|
position: fixed;
|
|
|
|
top: 0;
|
2018-04-13 02:09:51 +02:00
|
|
|
border-bottom: solid 1px var(--theme-border-color);
|
2018-03-22 10:09:58 +01:00
|
|
|
}
|
2018-03-09 07:21:25 +01:00
|
|
|
}
|
2018-03-12 17:42:47 +01:00
|
|
|
|
2018-07-02 18:01:46 +02:00
|
|
|
.page-narrow {
|
2018-10-23 01:49:53 +02:00
|
|
|
margin-left: 64px;
|
2018-07-02 18:01:46 +02:00
|
|
|
height: 100%;
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
|
|
|
.header {
|
2018-11-14 23:57:12 +01:00
|
|
|
width: calc(100% - 64px);
|
2018-07-02 18:01:46 +02:00
|
|
|
position: fixed;
|
|
|
|
top: 0;
|
|
|
|
height: 48px;
|
|
|
|
border-bottom: solid 1px var(--theme-border-color);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-14 23:57:12 +01:00
|
|
|
.with-global-header {
|
2018-11-23 11:12:26 +01:00
|
|
|
.page .header {
|
|
|
|
width: calc(100% - 245px);
|
|
|
|
}
|
|
|
|
|
2018-11-15 01:58:30 +01:00
|
|
|
.page-narrow .header {
|
2018-11-14 23:57:12 +01:00
|
|
|
width: calc(100% - 65px - 64px);
|
|
|
|
}
|
|
|
|
}
|
2018-03-08 10:36:09 +01:00
|
|
|
</style>
|