summaryrefslogtreecommitdiffstats
path: root/src/views/Profile.vue
blob: cbabbf93ba01d4b82fde012eda1a736d56f7a343 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
<!--
  - @copyright Copyright (c) 2018 Julius Härtl <jus@bitgrid.net>
  -
  - @author Julius Härtl <jus@bitgrid.net>
  -
  - @license GNU AGPL version 3 or any later version
  -
  - This program is free software: you can redistribute it and/or modify
  - it under the terms of the GNU Affero General Public License as
  - published by the Free Software Foundation, either version 3 of the
  - License, or (at your option) any later version.
  -
  - This program is distributed in the hope that it will be useful,
  - but WITHOUT ANY WARRANTY; without even the implied warranty of
  - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  - GNU Affero General Public License for more details.
  -
  - You should have received a copy of the GNU Affero General Public License
  - along with this program. If not, see <http://www.gnu.org/licenses/>.
  -
  -->

<template>
	<div :class="{'icon-loading': !accountLoaded}" class="social__wrapper">
		<profile-info v-if="accountLoaded && accountInfo" :uid="uid" />
		<!-- TODO: we have no details, timeline and follower list for non-local accounts for now -->
		<router-view v-if="accountLoaded && accountInfo && accountInfo.local" name="details" />
		<empty-content v-if="accountLoaded && !accountInfo" :item="emptyContentData" />
	</div>
</template>

<style scoped>

	.social__wrapper.icon-loading {
		margin-top: 50vh;
	}

</style>

<script>
import ProfileInfo from './../components/ProfileInfo.vue'
import EmptyContent from '../components/EmptyContent.vue'
import accountMixins from '../mixins/accountMixins'
import serverData from '../mixins/serverData'

export default {
	name: 'Profile',
	components: {
		EmptyContent,
		ProfileInfo
	},
	mixins: [
		accountMixins,
		serverData
	],
	data() {
		return {
			state: [],
			uid: null
		}
	},
	computed: {
		timeline: function() {
			return this.$store.getters.getTimeline
		},
		emptyContentData() {
			return {
				image: 'img/undraw/profile.svg',
				title: t('social', 'User not found'),
				description: t('social', 'Sorry, we could not find the account of {userId}', { userId: this.uid })
			}
		}
	},
	// Start fetching account information before mounting the component
	beforeMount() {
		this.uid = this.$route.params.account || this.serverData.account

		// Are we authenticated?
		let fetchMethod = ''
		if (this.serverData.public) {
			fetchMethod = 'fetchPublicAccountInfo'
		} else {
			fetchMethod = 'fetchAccountInfo'
		}

		// We need to update this.uid because we may have asked info for an account whose domain part was a host-meta,
		// and the account returned by the backend always uses a non host-meta'ed domain for its ID
		this.$store.dispatch(fetchMethod, this.profileAccount).then((response) => {
			this.uid = response.account
		})
	}
}
</script>