aboutsummaryrefslogtreecommitdiff
path: root/src/components/user_card
diff options
context:
space:
mode:
Diffstat (limited to 'src/components/user_card')
-rw-r--r--src/components/user_card/user_card.js48
-rw-r--r--src/components/user_card/user_card.vue135
2 files changed, 5 insertions, 178 deletions
diff --git a/src/components/user_card/user_card.js b/src/components/user_card/user_card.js
index 015a5762..c09e5654 100644
--- a/src/components/user_card/user_card.js
+++ b/src/components/user_card/user_card.js
@@ -2,8 +2,8 @@ import UserAvatar from '../user_avatar/user_avatar.vue'
import RemoteFollow from '../remote_follow/remote_follow.vue'
import ProgressButton from '../progress_button/progress_button.vue'
import ModerationTools from '../moderation_tools/moderation_tools.vue'
+import AccountActions from '../account_actions/account_actions.vue'
import { hex2rgb } from '../../services/color_convert/color_convert.js'
-import { requestFollow, requestUnfollow } from '../../services/follow_manipulate/follow_manipulate'
import generateProfileLink from 'src/services/user_profile_link_generator/user_profile_link_generator'
export default {
@@ -98,48 +98,10 @@ export default {
UserAvatar,
RemoteFollow,
ModerationTools,
+ AccountActions,
ProgressButton
},
methods: {
- showRepeats () {
- this.$store.dispatch('showReblogs', this.user.id)
- },
- hideRepeats () {
- this.$store.dispatch('hideReblogs', this.user.id)
- },
- followUser () {
- const store = this.$store
- this.followRequestInProgress = true
- requestFollow(this.user, store).then(() => {
- this.followRequestInProgress = false
- })
- },
- unfollowUser () {
- const store = this.$store
- this.followRequestInProgress = true
- requestUnfollow(this.user, store).then(() => {
- this.followRequestInProgress = false
- store.commit('removeStatus', { timeline: 'friends', userId: this.user.id })
- })
- },
- blockUser () {
- this.$store.dispatch('blockUser', this.user.id)
- },
- unblockUser () {
- this.$store.dispatch('unblockUser', this.user.id)
- },
- muteUser () {
- this.$store.dispatch('muteUser', this.user.id)
- },
- unmuteUser () {
- this.$store.dispatch('unmuteUser', this.user.id)
- },
- subscribeUser () {
- return this.$store.dispatch('subscribeUser', this.user.id)
- },
- unsubscribeUser () {
- return this.$store.dispatch('unsubscribeUser', this.user.id)
- },
setProfileView (v) {
if (this.switcher) {
const store = this.$store
@@ -160,9 +122,6 @@ export default {
this.$store.state.instance.restrictedNicknames
)
},
- reportUser () {
- this.$store.dispatch('openUserReportingModal', this.user.id)
- },
zoomAvatar () {
const attachment = {
url: this.user.profile_image_url_original,
@@ -170,9 +129,6 @@ export default {
}
this.$store.dispatch('setMedia', [attachment])
this.$store.dispatch('setCurrent', attachment)
- },
- mentionUser () {
- this.$store.dispatch('openPostStatusModal', { replyTo: true, repliedUser: this.user })
}
}
}
diff --git a/src/components/user_card/user_card.vue b/src/components/user_card/user_card.vue
index f465467c..abaef85f 100644
--- a/src/components/user_card/user_card.vue
+++ b/src/components/user_card/user_card.vue
@@ -131,135 +131,12 @@
</label>
</div>
</div>
+
<div
v-if="loggedIn && isOtherUser"
class="user-interactions"
>
- <div v-if="!user.following">
- <button
- class="btn btn-default btn-block"
- :disabled="followRequestInProgress"
- :title="user.requested ? $t('user_card.follow_again') : ''"
- @click="followUser"
- >
- <template v-if="followRequestInProgress">
- {{ $t('user_card.follow_progress') }}
- </template>
- <template v-else-if="user.requested">
- {{ $t('user_card.follow_sent') }}
- </template>
- <template v-else>
- {{ $t('user_card.follow') }}
- </template>
- </button>
- </div>
- <div v-else-if="followRequestInProgress">
- <button
- class="btn btn-default btn-block pressed"
- disabled
- :title="$t('user_card.follow_unfollow')"
- @click="unfollowUser"
- >
- {{ $t('user_card.follow_progress') }}
- </button>
- </div>
- <div
- v-else
- class="btn-group"
- >
- <button
- class="btn btn-default pressed"
- :title="$t('user_card.follow_unfollow')"
- @click="unfollowUser"
- >
- {{ $t('user_card.following') }}
- </button>
- <ProgressButton
- v-if="!user.subscribed"
- class="btn btn-default"
- :click="subscribeUser"
- :title="$t('user_card.subscribe')"
- >
- <i class="icon-bell-alt" />
- </ProgressButton>
- <ProgressButton
- v-else
- class="btn btn-default pressed"
- :click="unsubscribeUser"
- :title="$t('user_card.unsubscribe')"
- >
- <i class="icon-bell-ringing-o" />
- </ProgressButton>
- <button
- v-if="user.showing_reblogs"
- class="btn btn-default"
- :title="$t('user_card.hide_repeats')"
- @click="hideRepeats"
- >
- <i class="icon-eye" />
- </button>
- <button
- v-if="!user.showing_reblogs"
- class="btn btn-default pressed"
- :title="$t('user_card.show_repeats')"
- @click="showRepeats"
- >
- <i class="icon-eye-off" />
- </button>
- </div>
-
- <div>
- <button
- class="btn btn-default btn-block"
- @click="mentionUser"
- >
- {{ $t('user_card.mention') }}
- </button>
- </div>
-
- <div>
- <button
- v-if="user.muted"
- class="btn btn-default btn-block pressed"
- @click="unmuteUser"
- >
- {{ $t('user_card.muted') }}
- </button>
- <button
- v-else
- class="btn btn-default btn-block"
- @click="muteUser"
- >
- {{ $t('user_card.mute') }}
- </button>
- </div>
-
- <div>
- <button
- v-if="user.statusnet_blocking"
- class="btn btn-default btn-block pressed"
- @click="unblockUser"
- >
- {{ $t('user_card.blocked') }}
- </button>
- <button
- v-else
- class="btn btn-default btn-block"
- @click="blockUser"
- >
- {{ $t('user_card.block') }}
- </button>
- </div>
-
- <div>
- <button
- class="btn btn-default btn-block"
- @click="reportUser"
- >
- {{ $t('user_card.report') }}
- </button>
- </div>
-
+ <AccountActions :user="user" />
<ModerationTools
v-if="loggedIn.role === &quot;admin&quot;"
:user="user"
@@ -603,15 +480,9 @@
position: relative;
display: flex;
flex-flow: row wrap;
- justify-content: space-between;
+ justify-content: flex-end;
margin-right: -.75em;
- > * {
- flex: 1 0 0;
- margin: 0 .75em .6em 0;
- white-space: nowrap;
- }
-
button {
margin: 0;