forked from srxl/akkoma-fe
Merge branch 'feature/show-who-to-follow-in-mobile-view' into 'develop'
Show who to follow in the mobile view See merge request pleroma/pleroma-fe!452
This commit is contained in:
commit
ea1d21aafa
8 changed files with 77 additions and 11 deletions
|
@ -16,6 +16,7 @@ import Notifications from 'components/notifications/notifications.vue'
|
||||||
import UserPanel from 'components/user_panel/user_panel.vue'
|
import UserPanel from 'components/user_panel/user_panel.vue'
|
||||||
import LoginForm from 'components/login_form/login_form.vue'
|
import LoginForm from 'components/login_form/login_form.vue'
|
||||||
import ChatPanel from 'components/chat_panel/chat_panel.vue'
|
import ChatPanel from 'components/chat_panel/chat_panel.vue'
|
||||||
|
import WhoToFollow from 'components/who_to_follow/who_to_follow.vue'
|
||||||
import About from 'components/about/about.vue'
|
import About from 'components/about/about.vue'
|
||||||
|
|
||||||
export default (store) => {
|
export default (store) => {
|
||||||
|
@ -47,6 +48,7 @@ export default (store) => {
|
||||||
{ name: 'chat', path: '/chat', component: ChatPanel, props: () => ({ floating: false }) },
|
{ name: 'chat', path: '/chat', component: ChatPanel, props: () => ({ floating: false }) },
|
||||||
{ name: 'oauth-callback', path: '/oauth-callback', component: OAuthCallback, props: (route) => ({ code: route.query.code }) },
|
{ name: 'oauth-callback', path: '/oauth-callback', component: OAuthCallback, props: (route) => ({ code: route.query.code }) },
|
||||||
{ name: 'user-search', path: '/user-search', component: UserSearch, props: (route) => ({ query: route.query.query }) },
|
{ name: 'user-search', path: '/user-search', component: UserSearch, props: (route) => ({ query: route.query.query }) },
|
||||||
|
{ name: 'who-to-follow', path: '/who-to-follow', component: WhoToFollow },
|
||||||
{ name: 'about', path: '/about', component: About },
|
{ name: 'about', path: '/about', component: About },
|
||||||
{ name: 'user-profile', path: '/(users/)?:name', component: UserProfile }
|
{ name: 'user-profile', path: '/(users/)?:name', component: UserProfile }
|
||||||
]
|
]
|
||||||
|
|
|
@ -23,6 +23,9 @@ const SideDrawer = {
|
||||||
},
|
},
|
||||||
unseenNotificationsCount () {
|
unseenNotificationsCount () {
|
||||||
return this.unseenNotifications.length
|
return this.unseenNotifications.length
|
||||||
|
},
|
||||||
|
suggestionsEnabled () {
|
||||||
|
return this.$store.state.instance.suggestionsEnabled
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
|
|
@ -62,12 +62,17 @@
|
||||||
</ul>
|
</ul>
|
||||||
<ul>
|
<ul>
|
||||||
<li @click="toggleDrawer">
|
<li @click="toggleDrawer">
|
||||||
<router-link :to="{ name: 'user-search'}">
|
<router-link :to="{ name: 'user-search' }">
|
||||||
{{ $t("nav.user_search") }}
|
{{ $t("nav.user_search") }}
|
||||||
</router-link>
|
</router-link>
|
||||||
</li>
|
</li>
|
||||||
|
<li v-if="currentUser && suggestionsEnabled" @click="toggleDrawer">
|
||||||
|
<router-link :to="{ name: 'who-to-follow' }">
|
||||||
|
{{ $t("nav.who_to_follow") }}
|
||||||
|
</router-link>
|
||||||
|
</li>
|
||||||
<li @click="toggleDrawer">
|
<li @click="toggleDrawer">
|
||||||
<router-link :to="{ name: 'settings'}">
|
<router-link :to="{ name: 'settings' }">
|
||||||
{{ $t("settings.settings") }}
|
{{ $t("settings.settings") }}
|
||||||
</router-link>
|
</router-link>
|
||||||
</li>
|
</li>
|
||||||
|
|
48
src/components/who_to_follow/who_to_follow.js
Normal file
48
src/components/who_to_follow/who_to_follow.js
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
import apiService from '../../services/api/api.service.js'
|
||||||
|
import UserCard from '../user_card/user_card.vue'
|
||||||
|
|
||||||
|
const WhoToFollow = {
|
||||||
|
components: {
|
||||||
|
UserCard
|
||||||
|
},
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
users: []
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mounted () {
|
||||||
|
this.getWhoToFollow()
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
showWhoToFollow (reply) {
|
||||||
|
reply.forEach((i, index) => {
|
||||||
|
const user = {
|
||||||
|
id: 0,
|
||||||
|
name: i.display_name,
|
||||||
|
screen_name: i.acct,
|
||||||
|
profile_image_url: i.avatar || '/images/avi.png'
|
||||||
|
}
|
||||||
|
this.users.push(user)
|
||||||
|
|
||||||
|
this.$store.state.api.backendInteractor.externalProfile(user.screen_name)
|
||||||
|
.then((externalUser) => {
|
||||||
|
if (!externalUser.error) {
|
||||||
|
this.$store.commit('addNewUsers', [externalUser])
|
||||||
|
user.id = externalUser.id
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
},
|
||||||
|
getWhoToFollow () {
|
||||||
|
const credentials = this.$store.state.users.currentUser.credentials
|
||||||
|
if (credentials) {
|
||||||
|
apiService.suggestions({credentials: credentials})
|
||||||
|
.then((reply) => {
|
||||||
|
this.showWhoToFollow(reply)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default WhoToFollow
|
15
src/components/who_to_follow/who_to_follow.vue
Normal file
15
src/components/who_to_follow/who_to_follow.vue
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
<template>
|
||||||
|
<div class="panel panel-default">
|
||||||
|
<div class="panel-heading">
|
||||||
|
{{$t('who_to_follow.who_to_follow')}}
|
||||||
|
</div>
|
||||||
|
<div class="panel-body">
|
||||||
|
<user-card v-for="user in users" :key="user.id" :user="user" :showFollows="true"></user-card>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script src="./who_to_follow.js"></script>
|
||||||
|
|
||||||
|
<style lang="scss">
|
||||||
|
</style>
|
|
@ -50,14 +50,6 @@ const WhoToFollowPanel = {
|
||||||
user: function () {
|
user: function () {
|
||||||
return this.$store.state.users.currentUser.screen_name
|
return this.$store.state.users.currentUser.screen_name
|
||||||
},
|
},
|
||||||
moreUrl: function () {
|
|
||||||
const host = window.location.hostname
|
|
||||||
const user = this.user
|
|
||||||
const suggestionsWeb = this.$store.state.instance.suggestionsWeb
|
|
||||||
const url = suggestionsWeb.replace(/{{host}}/g, encodeURIComponent(host))
|
|
||||||
.replace(/{{user}}/g, encodeURIComponent(user))
|
|
||||||
return url
|
|
||||||
},
|
|
||||||
suggestionsEnabled () {
|
suggestionsEnabled () {
|
||||||
return this.$store.state.instance.suggestionsEnabled
|
return this.$store.state.instance.suggestionsEnabled
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
{{user.name}}
|
{{user.name}}
|
||||||
</router-link><br />
|
</router-link><br />
|
||||||
</span>
|
</span>
|
||||||
<img v-bind:src="$store.state.instance.logo"> <a v-bind:href="moreUrl" target="_blank">{{$t('who_to_follow.more')}}</a>
|
<img v-bind:src="$store.state.instance.logo"> <router-link :to="{ name: 'who-to-follow' }">{{$t('who_to_follow.more')}}</router-link>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -39,6 +39,7 @@
|
||||||
"timeline": "Timeline",
|
"timeline": "Timeline",
|
||||||
"twkn": "The Whole Known Network",
|
"twkn": "The Whole Known Network",
|
||||||
"user_search": "User Search",
|
"user_search": "User Search",
|
||||||
|
"who_to_follow": "Who to follow",
|
||||||
"preferences": "Preferences"
|
"preferences": "Preferences"
|
||||||
},
|
},
|
||||||
"notifications": {
|
"notifications": {
|
||||||
|
|
Loading…
Reference in a new issue